forked from GNUsocial/gnu-social
135 lines
4.5 KiB
Plaintext
135 lines
4.5 KiB
Plaintext
|
OpenID Example Code
|
||
|
-------------------
|
||
|
|
||
|
After you've installed this package (see ../README), you can use these
|
||
|
example packages to get started. They'll show you what this package
|
||
|
can do, and you can use them as the basis for your own OpenID support.
|
||
|
|
||
|
consumer/: OpenID Example Consumer
|
||
|
==================================
|
||
|
|
||
|
NOTE: If you want to try the example consumer without installing this
|
||
|
package, just make sure you add the package's 'Auth' directory to your
|
||
|
PHP include path.
|
||
|
|
||
|
To try the example consumer implementation, just copy the consumer/
|
||
|
directory into a place on your web server and point your browser at
|
||
|
the new directory.
|
||
|
|
||
|
1. Check to be sure that /tmp is in your "open_basedir" configuration,
|
||
|
if open_basedir is being used to restrict PHP's file I/O. See
|
||
|
http://us2.php.net/features.safe-mode for more information. For
|
||
|
example, in your php.ini, change
|
||
|
|
||
|
open_basedir = "..."
|
||
|
|
||
|
to
|
||
|
|
||
|
open_basedir = "/tmp:..."
|
||
|
|
||
|
(If you really don't want to add /tmp to your open_basedir, you can
|
||
|
modify consumer/common.php and change $store_path so it doesn't
|
||
|
create the store directory in /tmp.)
|
||
|
|
||
|
2. Copy or symlink the consumer/ directory into a part of your
|
||
|
webserver's docroot. For example, if your DocumentRoot is
|
||
|
/var/www/, do this:
|
||
|
|
||
|
# cd /var/www
|
||
|
# ln -s /path/to/PHP-OpenID-X.Y.Z/examples/consumer
|
||
|
|
||
|
3. Navigate to http://www.example.com/consumer and enter an OpenID
|
||
|
into the form presented there and click "Verify".
|
||
|
|
||
|
consumer/ Files
|
||
|
===============
|
||
|
|
||
|
The 'index.php' file will render a form and get you started. These
|
||
|
are the example consumer files:
|
||
|
|
||
|
consumer/index.php - Renders a form so you can begin the OpenID auth
|
||
|
process. The form submits the OpenID to try_auth.php.
|
||
|
|
||
|
consumer/try_auth.php - Starts the authentication with the OpenID
|
||
|
server that manages your OpenID and redirects your browser to the
|
||
|
server's login page. Instructs the server to return to
|
||
|
finish_auth.php when you're done authenticating.
|
||
|
|
||
|
consumer/finish_auth.php - Finishes the authentication by checking
|
||
|
the server's response. Tells you if the authentication was
|
||
|
successful.
|
||
|
|
||
|
consumer/common.php - Includes the setup code you'll need to create
|
||
|
a Consumer object and participate in an OpenID authentication.
|
||
|
|
||
|
server/: OpenID Example Server
|
||
|
==============================
|
||
|
|
||
|
To try the example server, follow these steps:
|
||
|
|
||
|
1. Copy or symlink the server/ directory into a part of your
|
||
|
webserver's docroot. For example, if your DocumentRoot is
|
||
|
/var/www/, do this:
|
||
|
|
||
|
# cd /var/www
|
||
|
# ln -s /path/to/PHP-OpenID-X.Y.Z/examples/server
|
||
|
|
||
|
2. Navigate to the server example. You'll be redirected to
|
||
|
server/setup.php where you can choose some configuration options to
|
||
|
generate a configuration. Once finished, you can download a file
|
||
|
"config.php." Save that file in the example server directory.
|
||
|
|
||
|
The example server has the following features:
|
||
|
|
||
|
- It serves its own identity pages, whose URLs are of the form
|
||
|
|
||
|
http://.../server/server.php/idpage?user=USERNAME
|
||
|
|
||
|
- It does not require passwords.
|
||
|
|
||
|
- It does not support a "trusted sites" page, as you pointed out.
|
||
|
|
||
|
In general, the example server is NOT supposed to be treated as a
|
||
|
fully-equiped OpenID server (i.e., with user accounts and other
|
||
|
state). It is supposed to demonstrate how to write PHP applications
|
||
|
that use the library.
|
||
|
|
||
|
Upgrading from the 1.X.X example server
|
||
|
=======================================
|
||
|
|
||
|
The 2.X.X library's example server is different from the 1.X.X example
|
||
|
server in the following ways:
|
||
|
|
||
|
- The new example server does not support authenticating arbitrary
|
||
|
URLs. It serves its own URLs. This makes it easier to set up and
|
||
|
test.
|
||
|
|
||
|
- The new example server does not support password authentication.
|
||
|
This makes it easier to set up and is not necessary for
|
||
|
illustrating the use of the library.
|
||
|
|
||
|
- The new example server does not have a "trusted sites" page.
|
||
|
|
||
|
server/ Files
|
||
|
=============
|
||
|
|
||
|
These files make up the server example code:
|
||
|
|
||
|
config.php - The configuration file you'll need to customize to run
|
||
|
the example server.
|
||
|
|
||
|
server.php - The PHP rendering script that takes care of handling
|
||
|
server requests from both regular user agents and consumers.
|
||
|
|
||
|
lib/actions.php - Handles the various types of requests that the
|
||
|
server supports.
|
||
|
|
||
|
lib/common.php - Supplies functions that wrap the OpenID API calls
|
||
|
to make them easier to use.
|
||
|
|
||
|
lib/render.php - Miscellaneous page rendering code.
|
||
|
|
||
|
lib/session.php - Code to handle session data for user settings.
|
||
|
|
||
|
lib/render/*.php - Files for each page presented by the server.
|