GNU social is social communication software for both public and private communications.
PHP JavaScript CSS Other
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
actions Split up source and source_link. Never trust HTML! Sep 1, 2016
classes Revert some of 8a4bec8 May 6, 2017
db ...and make sure we checkschema on Notice_prefs on upgrade... May 6, 2017
doc-src fix a link of doc/twitterapi May 29, 2017
extlib Fix OpenID discovery in pages using uppercase <HEAD> tag Apr 8, 2017
js Remove Google References Mar 20, 2016
lib Merge branch 'cache-html-sanitizer' into 'master' Dec 17, 2017
locale Remove Google References Mar 20, 2016
mail-src better indenting in invite email Apr 18, 2011
plugins Fix PHP incompatibilities in XMPPHP Aug 19, 2017
scripts Don't write the config file when --skip-config flag is given to the i… Nov 26, 2017
socialfy-another-domain Some Google stuff that need to be there (or comments) Mar 21, 2016
tests Some Google stuff that need to be there (or comments) Mar 21, 2016
theme Merge branch 'new-avatar' into 'master' Mar 21, 2016
.gitignore Ignore whole directory, not only inner contents Apr 29, 2017
CONFIGURE set the html sanitizer cache directory to ['cache']['dir'] from the c… Dec 6, 2017
COPYING add license file Oct 27, 2010
EVENTS.txt Remove Google References Mar 20, 2016
INSTALL Update INSTALL Jun 18, 2017
Makefile New _m() gettext wrapper with smart detection of plugin domains. Plug… Dec 8, 2009
PLUGINS.txt Remove Google References Mar 20, 2016
README.md Remove Google References Mar 20, 2016
TODO.SOCIAL add todo list Jun 7, 2010
UPGRADE NSTALL/UPGRADE documentation edits Jan 10, 2016
apple-touch-icon.png Add `apple-touch-icon.png` support; favicons for the iPhone OS. Mar 16, 2009
favicon.ico Favicon updated to match new theme images Mar 6, 2014
htaccess.sample More automated htaccess.sample May 10, 2015
index.php Use config site/sslproxy to force HTTPS (i.e. using reverse proxy to … Feb 10, 2016
install.php Either use or don't use HTTPS Feb 9, 2016
lighttpd.conf.example Lighttpd config example updated. May 9, 2014
nginx.conf.sample minor tuning to nginx example config Dec 27, 2015

README.md

GNU social 1.2.x

2015

(c) Free Software Foundation, Inc (c) StatusNet, 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.

Some other files to review:

  • INSTALL: instructions on how to install the software.
  • UPGRADE: upgrading from earlier versions
  • CONFIGURE: configuration options in gruesome detail.
  • PLUGINS.txt: how to install and configure plugins.
  • EVENTS.txt: events supported by the plugin system
  • COPYING: full text of the software license

Information on using GNU social can be found in the "doc" subdirectory or in the "help" section on-line, or you can catch us on IRC in #social on the freenode network.

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 an open standard called 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.

New this version

This is the development branch for the 1.2.x version of GNU social. All daring 1.1.x admins should upgrade to this version.

So far it includes the following changes:

  • Backing up a user's account is more and more complete.
  • Emojis 😸 (utf8mb4 support)

The last release, 1.1.3, gave us these improvements:

Upgrades from StatusNet 1.1.1 will also experience these improvements:

  • Fixes for SQL injection errors in profile lists.
  • Improved ActivityStreams JSON representation of activities and objects.
  • Upgrade to the Twitter 1.1 API.
  • More robust handling of errors in distribution.
  • Fix error in OStatus subscription for remote groups.
  • Fix error in XMPP distribution.
  • Tracking of conversation URI metadata (more coherent convos)

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@git.gnu.io:gnu/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.2.x "stable", few updates, well tested code
  • master "testing", more updates, usually working well
  • nightly "unstable", most updates, not always working

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

Further information

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

Credits

The following is an incomplete list of developers who've worked on GNU social, or its predecessors StatusNet and Free Social. Apologies for any oversight; please let mattl@gnu.org know if anyone's been overlooked in error.

Project Founders

  • Matt Lee (GNU social)
  • Evan Prodromou (StatusNet)
  • Mikael Nordfeldth (Free Social)

Thanks to all of the StatusNet developers:

  • Zach Copley, StatusNet, Inc.
  • Earle Martin, StatusNet, Inc.
  • Marie-Claude Doyon, designer, StatusNet, Inc.
  • Sarven Capadisli, StatusNet, Inc.
  • Robin Millette, StatusNet, Inc.
  • Ciaran Gultnieks
  • Michael Landers
  • Ori Avtalion
  • Garret Buell
  • Mike Cochrane
  • Matthew Gregg
  • Florian Biree
  • Erik Stambaugh
  • 'drry'
  • Gina Haeussge
  • Tryggvi Björgvinsson
  • Adrian Lang
  • Ori Avtalion
  • Meitar Moscovitz
  • Ken Sheppardson (Trac server, man-about-town)
  • Tiago 'gouki' Faria (i18n manager)
  • Sean Murphy
  • Leslie Michael Orchard
  • Eric Helgeson
  • Ken Sedgwick
  • Brian Hendrickson
  • Tobias Diekershoff
  • Dan Moore
  • Fil
  • Jeff Mitchell
  • Brenda Wallace
  • Jeffery To
  • Federico Marani
  • mEDI
  • Brett Taylor
  • Brigitte Schuster
  • Siebrand Mazeland and the amazing volunteer translators at translatewiki.net
  • Brion Vibber, StatusNet, Inc.
  • James Walker, StatusNet, Inc.
  • Samantha Doherty, designer, StatusNet, Inc.
  • Simon Waters, Surevine
  • Joshua Judson Rosen (rozzin)

Extra special thanks to the GNU socialites

  • Craig Andrews
  • Donald Robertson
  • Deb Nicholson
  • Ian Denhart
  • Steven DuBois
  • Blaine Cook
  • Henry Story
  • Melvin Carvalho

Thanks also to the developers of our upstream library code and to the thousands of people who have tried out GNU social, told their friends, and built the fediverse network to what it is today.

License help from

  • Bradley M. Kuhn