Skip to main content

Facebook authentication plugin for Plone

Project description

Introduction

A PAS plugin to login into a Plone Site using Facebook.

  • Log in to a Plone site through Facebook: when a user requests to log in to the Plone site he will be redirected to Facebook so that he provides the credentials there, then he will be redirected back to the Plone site and will be identified there.

  • The user will be a standard Plone user, so Roles or Group membership can be set.

  • Minimal user information is kept in Plone such as full name, Facebook ID, photo and e-mail (if available) of the user. This is kept to avoid permanent requests to Facebook API. This information is refreshed each time the user logs in to the site.

Installation and getting started

  1. Buildout

    Add cs.auth.facebook to your buildout.cfg eggs list:

    [buildout]
    ...
    eggs =
        cs.auth.facebook

    Or as a required install dependency of your own addon setup.py:

    install_requires=[
        ...
        'cs.auth.facebook',
    ],
  2. Create a new Facebook app at https://developers.facebook.com/app and fill in the required data in the plugin’s control panel form.

  3. Install the product in the Plone Control Panel and provide the app_id and app_secret in the configuration panel.

    Now you see the “Facebook Login” button viewlet. To customize the placement of this viewlet please check out the Plone Viewlet Documentation

  4. Alternatively you can enable an action in portal_actions with the following configuration (see profiles/default/actions.xml within this package):

    <object name="portal_actions" meta_type="Plone Actions Tool"
       xmlns:i18n="http://xml.zope.org/namespaces/i18n">
        <object name="user" meta_type="CMF Action Category">
            <object name="login_facebook" meta_type="CMF Action" i18n:domain="cs.auth.facebook">
                <property name="title" i18n:translate="">Log in with Facebook</property>
                <property name="description" i18n:translate=""></property>
                <property name="url_expr">string:${globals_view/navigationRootUrl}/@@facebook-login</property>
                <property name="icon_expr"></property>
                <property name="available_expr">python:member is None</property>
                <property name="permissions">
                    <element value="View"/>
                </property>
                <property name="visible">False</property>
            </object>
        </object>
    </object>

Behind the scenes

The Facebook Login Viewlet uses the new Facebook JavaScript SDK v2.1 to ensure the proper popup for every target device. You don’t have to care about this.

For more information on FB JSDK checkout the Facebook Developers Login Documentation

Credit

This product re-distributes a lot of code written by Martin Aspeli (aka @optilude) in his book “Professional Plone 4 Development” and available under GPL license in his personal GitHub account with the name ‘optilux.facebookauth’:

https://github.com/optilude/optilux/tree/chapter-16/src/optilux.facebookauth

Compatibility

Plone 4.x

Changelog

1.1 (2017-05-10)

  • Facebook Login with JavaScript SDK v2.1 [petschki]

  • add Facebook Login Viewlet [petschki]

  • disable old style portal_action by default. code is still there (see documentation) [petschki]

  • Fix access_token processing

  • Remove Welcome message

1.1b1 (2014-10-22)

1.0.3 (2014-10-21)

  • Add german translation [petschki]

  • Encoding unicode user credentials. see http://goo.gl/63Kyuo for more info [petschki]

1.0.2 (2014-10-10)

  • Fix dependencies includes [erral]

1.0.1 (2014-10-10)

  • Fix docs [erral]

1.0 (2014-10-10)

  • Fix user search [erral]

  • Fix to be able to add the plugin through the ZMI [erral]

1.0b2 (2012-10-16)

  • FaceBook users are now PloneUsers [erral]

  • Implement user search in storage [erral]

  • Get properties from self data storage instead of relying on Session [erral]

  • Change user action name not to clash with Plone’s login [erral]

1.0b1 (2012-07-13)

  • Initial release [erral]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cs.auth.facebook-1.1.tar.gz (24.0 kB view details)

Uploaded Source

File details

Details for the file cs.auth.facebook-1.1.tar.gz.

File metadata

File hashes

Hashes for cs.auth.facebook-1.1.tar.gz
Algorithm Hash digest
SHA256 ebd57244e05bd575243340d55c435cfb1eee9caeced1595740528eb09ba4f178
MD5 7f0193a0c3e9d8194e9c74e3777433f4
BLAKE2b-256 6e818650a6e5c676081b229d535691bac3f96e5cfd602d7491c54cd93c59717c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page