GNU social is a social communication software used in federated social networks. It is widely supported and has a large userbase. It is already used by the Free Software Foundation.

Diogo Cordeiro 518431ad72 [CORE] Use random_bytes() if available and improve common_confirmation_code() randomness. 4 years ago
DOCUMENTATION c0342b1482 [DOCUMENTATION] Allow install.php to be ran with sample nginx conf 4 years ago
actions 46be9b76ef [CORE] Fix wrong Profile_list schema and set created in user_im_prefs properly - by XRevan86 4 years ago
classes 46be9b76ef [CORE] Fix wrong Profile_list schema and set created in user_im_prefs properly - by XRevan86 4 years ago
db f89c052cf8 Set default value of datetime columns to CURRENT_TIMESTAMP 5 years ago
doc-src b9a4053eec fix a link of doc/twitterapi 6 years ago
extlib 5eb61c17d4 Regression introduced in daa5f87f fixed by XRevan86 4 years ago
js 980085a8a3 Merge branch 'master' of git.gnu.io:gnu/gnu-social into mmn_fixes 8 years ago
lib d705bcbd98 [CORE] Use random_bytes() if available and improve common_confirmation_code() randomness. 4 years ago
locale f2705180e0 [TagSub] Fix User's tags list issue 4 years ago
mail-src 17424f49cd better indenting in invite email 13 years ago
plugins d1fc7c0774 [CORE] MySQL 5.5 support fully restored 4 years ago
scripts f0f5ecb756 [SCRIPTS] Fix sessiongc by XRevan86 4 years ago
tests 550606177b Merge branch 'fixtests' into 'nightly' 7 years ago
theme 5ea0d74a57 [UI] Long strings/words in dents weren't being wrapped 4 years ago
.gitignore 25eb06ac46 Remove from .gitignore stuff that should clearly go to developer's global gitignore instead 5 years ago
CODE_OF_CONDUCT.md 2740ff8c4c [DOCUMENTATION] Minor corrections 4 years ago
CONTRIBUTING.md 2740ff8c4c [DOCUMENTATION] Minor corrections 4 years ago
COPYING b6cfd2dffe license block for source code 16 years ago
CREDITS.md 2740ff8c4c [DOCUMENTATION] Minor corrections 4 years ago
INSTALL.md 7cf4e1bb09 [DOCUMENTATION] Convert INSTALL to markdown and update the requirements 4 years ago
Makefile 4b5e977a7b New _m() gettext wrapper with smart detection of plugin domains. Plugin base class registers your gettext files if present at initialization. 14 years ago
README.md 2740ff8c4c [DOCUMENTATION] Minor corrections 4 years ago
apple-touch-icon.png 91b0fb8028 Add `apple-touch-icon.png` support; favicons for the iPhone OS. 15 years ago
favicon.ico c5c4bc10dc Favicon updated to match new theme images 10 years ago
index.php a45d9471ed If $_REQUEST is empty, array_merge == null. 6 years ago
install.php ec257d940a Either use or don't use HTTPS 8 years ago

README.md

GNU social 1.20.x

(c) 2010-2019 Free Software Foundation, Inc

This is the README file for GNU social, the free software social networking platform. It includes general information about the software and the project.

The file INSTALL.md has useful instructions on how to install this software.

System administrators may find the DOCUMENTATION/SYSTEM_ADMINISTRATORS directory useful, namely:

  • upgrade_from: upgrading from different software
  • CONFIGURE.md: configuration options in gruesome detail.
  • PLUGINS.md: how to install and configure plugins.

Developers may find the DOCUMENTATION/DEVELOPERS directory useful.

About

GNU social is a free social networking platform. It helps people in a community, company or group to exchange short status updates, do polls, announce events, or other social activities (and you can add more!). Users can choose which people to "follow" and receive only their friends' or colleagues' status messages. It provides a similar service to proprietary social network sites, but is much more awesome.

With a little work, status messages can be sent to mobile phones, instant messenger programs (using XMPP), and specially-designed desktop clients that support the Twitter API.

GNU social supports open standards (such as OStatus https://www.w3.org/community/ostatus/) that lets users in different networks follow each other. It enables a distributed social network spread all across the Web.

GNU social was originally developed as "StatusNet" by StatusNet, Inc. with Evan Prodromou as lead developer.

It is shared with you in hope that you too make an service available to your users. To learn more, please see the Open Software Service Definition 1.1: http://www.opendefinition.org/ossd

License

This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program, in the file "COPYING". If not, see http://www.gnu.org/licenses/.

IMPORTANT NOTE: The GNU Affero General Public License (AGPL) has
*different requirements* from the "regular" GPL. In particular, if
you make modifications to the GNU social source code on your server,
you *MUST MAKE AVAILABLE* the modified version of the source code
to your users under the same license. This is a legal requirement
of using the software, and if you do not wish to share your
modifications, *YOU MAY NOT INSTALL GNU SOCIAL*.

Documentation in the /doc-src/ directory is available under the Creative Commons Attribution 3.0 Unported license, with attribution to "GNU social". See http://creativecommons.org/licenses/by/3.0/ for details.

CSS and images in the /theme/ directory are available under the Creative Commons Attribution 3.0 Unported license, with attribution to "GNU social". See http://creativecommons.org/licenses/by/3.0/ for details.

Our understanding and intention is that if you add your own theme that uses only CSS and images, those files are not subject to the copyleft requirements of the Affero General Public License 3.0. See http://wordpress.org/news/2009/07/themes-are-gpl-too/. This is not legal advice; consult your lawyer.

Additional library software has been made available in the 'extlib' directory. All of it is Free Software and can be distributed under liberal terms, but those terms may differ in detail from the AGPL's particulars. See each package's license file in the extlib directory for additional terms.

Refer to COPYING.md for full text of the software license..

Troubleshooting

The primary output for GNU social is syslog, unless you configured a separate logfile. This is probably the first place to look if you're getting weird behaviour from GNU social.

If you're tracking the unstable version of GNU social in the git repository (see below), and you get a compilation error ("unexpected T_STRING") in the browser, check to see that you don't have any conflicts in your code.

Unstable version

If you're adventurous or impatient, you may want to install the development version of GNU social. To get it, use the git version control tool http://git-scm.com/ like so:

git clone git@notabug.org:diogo/gnu-social.git

In the current phase of development it is probably recommended to use git as a means to stay up to date with the source code. You can choose between these branches:

  • 1.20.x "oldstable", few updates, well tested coded
  • master "stable", usually working well
  • nightly "testing", most updates, not always working as expected

To keep it up-to-date, use git pull. Watch for conflicts!

As in any upgrade, do not forget to run /scripts/upgrade.php.

Further information

There are several ways to get more information about GNU social.

Credits

An incomplete list of developers who've worked on GNU social, or its predecessors StatusNet and Free Social has been made available in CREDITS.md.

Current team

  • Matt Lee
  • Mikael Nordfeldth
  • Diogo Cordeiro
  • Bruno Casteleiro
  • Miguel Dantas
  • Alexei Sorokin