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 98c0c1ed53 Implement $config['site']['logdebug'] 4 years ago
DOCUMENTATION 2740ff8c4c [DOCUMENTATION] Minor corrections 4 years ago
actions 83a05724b8 [CORE] Fix subscriptions and subscribers list (related to 44653d339d) 4 years ago
classes 306d80de94 [DATABASE] Revert accidental regression introduced with 9a39ebe66f 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 b17e0b4169 Update PEAR to v1.10.9 and patch it so it works quietly 4 years ago
js 980085a8a3 Merge branch 'master' of git.gnu.io:gnu/gnu-social into mmn_fixes 8 years ago
lib 98c0c1ed53 Implement $config['site']['logdebug'] 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 44653d339d [Poll] Refactoring and minor bug fixes 4 years ago
scripts 45479c90a3 Add option to send email to --all users on sendemail.php script 5 years ago
tests 550606177b Merge branch 'fixtests' into 'nightly' 7 years ago
theme a1041a53f7 [THEME] Fix OpenID settings styles 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