Mikael Nordfeldth 69e04e5cbd extlib Michelf\Markdown updated 1.4.0 to 1.4.1 9 years ago
..
Auth 49b755912f Updating Janrain OpenID auth library 10 years ago
Console d1d5d234f8 upgrade Console_GetOpt to 1.9.2 13 years ago
DB a66973e158 DB_DataObject updated to 1.11.3 9 years ago
HTTP e328fd7901 PEAR::HTTP_Request2 updated to 2.2.1 9 years ago
Mail 081ee9b29c extlibs updates: PEAR::Mail to 1.2.0, PEAR::Net_SMTP to 1.4.2 (need to go together as a pair) 14 years ago
Mf2 c2998e26ec Latest Mf2/Parser.php is compatible with PHP5.3 9 years ago
Michelf 69e04e5cbd extlib Michelf\Markdown updated 1.4.0 to 1.4.1 9 years ago
Net c51086b302 Updating external libraries for net access 10 years ago
PEAR e4084d0f5a PEAR lib updated to 1.9.4 (seems only installation stuff changed) 10 years ago
Stomp 5b51eeeebb Bump to version 1.0.0 14 years ago
System ccd9cdd618 Add System_Command so MIME type fallback works for uploaded files 15 years ago
data c51086b302 Updating external libraries for net access 10 years ago
htmLawed 35a9c65e4a htmLawed extlib updated from 1.1.16 to 1.1.19 9 years ago
php-gettext 21e17e3738 Fix a logic error in php-gettext's setlocale() check; if setlocale() failed to return, we fall back to checking LANG environment variable. Now actually works when doing a setlocale *check* instead of a *set*. 14 years ago
Apache2.0.txt a73d800100 add additional licenses into extlib subdir 15 years ago
DB.php 10f2cde0b1 DB updated to 1.8.2 9 years ago
HTTP_Request2_LICENSE e328fd7901 PEAR::HTTP_Request2 updated to 2.2.1 9 years ago
Mail.php 081ee9b29c extlibs updates: PEAR::Mail to 1.2.0, PEAR::Net_SMTP to 1.4.2 (need to go together as a pair) 14 years ago
OAuth.php bf94154c96 Class names are strings. Also, sorry we're touching extlib 9 years ago
OAuth_LICENSE.txt a73d800100 add additional licenses into extlib subdir 15 years ago
PEAR.php e4084d0f5a PEAR lib updated to 1.9.4 (seems only installation stuff changed) 10 years ago
PEAR5.php 75baffc970 Upgrade PEAR to 1.9.2 13 years ago
PHP_License_2_02.txt a73d800100 add additional licenses into extlib subdir 15 years ago
PHP_License_3.01.txt a73d800100 add additional licenses into extlib subdir 15 years ago
PHP_Markdown_License.text a73d800100 add additional licenses into extlib subdir 15 years ago
README 85c3f82ff3 Documentation updates 9 years ago
Stomp.php 5b51eeeebb Bump to version 1.0.0 14 years ago
System.php 44d292b33b PEAR System.php updated to 1.9.4 10 years ago
Validate.php c62c0602fe Added PEAR Services/oEmbed and its dependencies for multimedia integration. 15 years ago
get_temp_dir.php 537819ba8a Add a sys_get_temp_dir substitute to extlib for easier installation on versions that lack it 15 years ago
gpl-2.0.txt a73d800100 add additional licenses into extlib subdir 15 years ago
lgpl-2.1.txt 8679bc6c7b add LGPL 14 years ago

README

DO NOT "FIX" CODE IN THIS DIRECTORY.

ONLY UPSTREAM VERSIONS OF SOFTWARE GO IN THIS DIRECTORY.

This directory is provided as a courtesy to our users who might be
unable or unwilling to find and install libraries we depend on.

If we "fix" software in this directory, we hamstring users who do the
right thing and keep a single version of upstream libraries in a
system-wide library. We introduce subtle and maddening bugs where
our code is "accidentally" using the "wrong" library version. We may
unwittingly interfere with other software that depends on the
canonical release versions of those same libraries!

Forking upstream software for trivial reasons makes us bad citizens in
the Open Source community and adds unnecessary heartache for our
users. Don't make us "that" project.

Frequently Asked Questions
--------------------------

Q: What should we do when we find a bug in upstream software?

A: First and foremost, REPORT THE BUG, and if possible send in a patch.

Watch for a release of the upstream software and integrate with it
when it's released.

In the meantime, work around the bug, if at all possible. Usually,
it's quite possible, if slightly harder or less efficient.

Q: What if the bug can't be worked around?

A: If the upstream developers have accepted a bug patch, it's
undesirable but acceptable to apply that patch to the library in
the extlib dir. Ideally, use a release version for upstream or a
version control system snapshot.

Note that this is a last resort.

Q: What if upstream is unresponsive or won't accept a patch?

A: Try again.

Q: I tried again, and upstream is still unresponsive and nobody's
checked on my patch. Now what?

A: If the upstream project is moribund and there's a way to adopt it,
propose having the GNU social dev team adopt the project. Or, adopt
it yourself.

Q: What if there's no upstream authority and it can't be adopted?

A: Then we fork it. Make a new name and a new version. Include it in
lib/ instead of extlib/, and use the GNUsocial_* prefix to change
the namespace to avoid collisions.

This is a last resort; consult with the rest of the dev group
before taking this radical step.

List of external libraries
--------------------------

A number of external PHP libraries are used to provide basic
functionality and optional functionality for your system. For your
convenience, they are available in the "extlib" directory of this
package, and you do not have to download and install them. However,
you may want to keep them up-to-date with the latest upstream version,
and the URLs are listed here for your convenience.

- DB_DataObject http://pear.php.net/package/DB_DataObject
- Validate http://pear.php.net/package/Validate
- OpenID by Janrain, http://janrain.com/openid-enabled/
- PEAR DB. Although this is an older data access system (new
packages should use PDO), the OpenID libraries depend on PEAR DB
or MDB2.
- OAuth.php from http://oauth.googlecode.com/svn/code/php/
(has been edited to avoid colliding autoload)
- markdown.php from http://michelf.com/projects/php-markdown/
- PEAR Mail, for sending out mail notifications
http://pear.php.net/package/Mail
- PEAR Net_SMTP, if you use the SMTP factory for notifications
http://pear.php.net/package/Net_SMTP
- PEAR Net_Socket, if you use the SMTP factory for notifications
http://pear.php.net/package/Net_Socket
- XMPPHP, the follow-up to Class.Jabber.php. Probably the best XMPP
library available for PHP. http://xmpphp.googlecode.com/. Note that
as of this writing the version of this library that is available in
the extlib directory is *significantly different* from the upstream
version (patches have been submitted). Upgrading to the upstream
version may render your GNU social site unable to send or receive XMPP
messages.
- Facebook library. Used for the Facebook application.
- PEAR Validate is used for URL and email validation.
- Console_GetOpt for parsing command-line options.
- HTTP_Request2, a library for making HTTP requests.
- PEAR Net_URL2 is an HTTP_Request2 dependency.
- Michelf/Markdown.php Markdown parser library
- Mf2/Parser.php microformats2 parser library

A design goal of GNU Social is that the basic Web functionality should
work on even the most restrictive commercial hosting services.
However, additional functionality, such as receiving messages by XMPP,
require that you be able to run long-running processes on your account.
In addition, posting by email require that you be able to install a mail
filter in your mail server.