ProcessWire 3.0.69 plus Login for Facebook module

ProcessWire 3.0.69

This week's version of ProcessWire on the dev branch is 3.0.69 and it includes several minor bug fixes. For more details on that see the dev branch commit log. This week we'll focus on a new module released today, which was actually developed for a friend of mine, but he gave me permission to release it. I'm thinking a lot of people might find this one quite useful.

ProcessWire Login for Facebook

This is a new module for ProcessWire 3.x (3.0.42 or newer) that enables users to log-in to your ProcessWire site via their Facebook account. Once logged in, you can pull and use data from their Facebook account for output in your ProcessWire site. You can choose to have all Facebook logins map to the same user account, but the default behavior is to have it automatically create new ProcessWire user accounts for each Facebook user.

Benefits

One of the benefits of using a Facebook login (or other social network logins, except maybe Twitter) is that such an account gives a certain level of legitimacy to a user, in that you know they have gone through the approval process of the social network. Another benefit is that it gives you the potential of accessing more information about the user without them having to manually enter it. Lastly, it saves a lot of time for the user when all they have to do is click once to approve the request (at Facebook) … no need for the user to enter the first name, last name, email, and so on.

This module was made possible thanks to to the direction and sponsorship of Michael Barón. He and I are working on other related modules as well. This module also takes some inspiration from an older module developed by Antti Peisa called FacebookLogin. Below we'll cover more details on how to install and use this module. Note that this module is fully functional but also still considered in beta, so use caution, test, and please let us know how it works for you.

How it works

This module creates a new page named /login-facebook/, which you can move or rename as needed. When a user accesses this page, it asks them to login to Facebook. If they are already logged in to Facebook, it will ask them to approve access by clicking a button. Upon approval, they are redirected back to your site and are now logged in to ProcessWire with a user having the role “login-facebook”. If the user has not previously done this before, a new account will be created for them. The created account uses the name of their Facebook account. If preferred, you can also configure the module to use the same user for all Facebook logins.

Installation

  1. Download from the LoginFacebook GitHub repository. Unzip and copy the module’s files to /site/modules/LoginFacebook/.

  2. Copy the included login-facebook.php to your /site/templates/ folder (if not already present).

  3. Create a new app from Facebook Developers site. You will need to obtain a Facebook App ID and App Secret. Facebook will also ask for some other information, such as the following:

    • Display Name: Enter whatever you'd like, i.e. “Login for my site”.

    • Namespace: I left this one blank.

    • App domains: Enter your web site’s domain name(s). Note that if “localhost” is needed, Facebook won't take it until you've completed the “Website” first (see next item).

    • Click the “Add Platform” at the bottom, and add “Website”, along with the full http URL to it. If testing on localhost, enter “http://localhost". In my case using MAMP on localhost, it was “http://localhost:8888”.

    • For the rest of the fields, you can leave them blank or populate them as you see fit.

  4. Configure the module in the ProcessWire admin (Modules > Site > Login Facebook). Add the Facebook App ID and App Secret you obtained in the last step, to the indicated fields.

  5. While still in the module configuration, configure the “Page where user is redirected to after successful login”. Leave the rest of the configuration as-is with the defaults for now. You can come back later to configure and adjust things as needed, but it's a good idea to get the module functional with the defaults first.

  6. Now lets test things out. Log out of ProcessWire (if you are logged in). Then access the /login-facebook/ URL on your website where the module is installed. It should redirect to Facebook and ask you to login, or ask you to approve the request if you are already logged in. Upon login/approval, Facebook will redirect to your designated page, a new user account will be created in ProcessWire (if not already created), and the user will be logged in.

Configuration

The module configuration screen gives you a lot of options, and I think the best way to highlight them is just to show a screenshot:

Usage

When a user is logged in from Facebook, you can access properties from their Facebook information via the ProcessWire API. The fields that you want to work with are configured from the module configuration screen. As an example, lets say that you wanted to output a welcome message that contains the user's first name and picture, as stored in the Facebook data:

$facebook = $modules->get('LoginFacebook');
echo "<h2>Welcome $facebook->first_name</h2>";
if($facebook->picture_url) {
  echo "<p><img src='$facebook->picture_url'></p>";
}

If you want to retrieve all user data, use the getAll() method, which returns an associative array of all Facebook data that you've configured for the module to retrieve.

$facebook = $modules->get('LoginFacebook');
$data = $facebook->getAll(); 

In either case, any strings in the returned data are automatically entity encoded when the current page’s output formatting state is enabled.

When making API calls like above, if the user is not logged-in via Facebook, then it will automatically redirect to Facebook to log them in, and return to your page (where the API call exists) once logged in. If you would instead rather check if they are logged in via Facebook before outputting data, use the isLoggedIn() method:

$facebook = $modules->get('LoginFacebook');
if($facebook->isLoggedIn()) {
  // user is logged in and Facebook data available
  echo "<h2>Welcome $facebook->first_name</h2>";
} else {
  // user not logged in via Facebook, ask them to login
  echo "<a href='$facebook->url'>Login with Facebook</a>";
}

This module also enables you to mirror data from Facebook to ProcessWire fields. This can add convenience, especially in cases where the user might be able to login through either ProcessWire or through Facebook. This ensures the Facebook data is stored in their ProcessWire user profile, even when not logged in via Facebook. This is useful for fields like email and names.

If you want to give this module a try, go ahead and download it from GitHub, and please let us know how it works for you. That's all for this week. Have a great weekend, read the ProcessWire Weekly, and we'll see you again next week!

Comments

  • Joe Regan

    Joe Regan

    • 7 years ago
    • 20

    This is awesome! I will figure out some way to use this! :D

  • Ivan

    Ivan

    • 7 years ago
    • 40

    And for Google as well!

  • ngon

    ngon

    • 7 years ago
    • 10

    Thank you both for sharing this!

  • Vayu Robins

    Vayu Robins

    • 7 years ago
    • 21

    This looks great! A similar module for LinkedIn would fantastic! :-)

     

    Latest news

    • ProcessWire Weekly #556
      In the 556th issue of ProcessWire Weekly we're going to share the latest core development news, highlight a new third party module, and more. Read on!
      Weekly.pw / 4 January 2025
    • Custom Fields Module
      This week we look at a new ProFields module named Custom Fields. This module provides a way to rapidly build out ProcessWire fields that contain any number of subfields/properties within them.
      Blog / 30 August 2024
    • Subscribe to weekly ProcessWire news

    “We chose ProcessWire because of its excellent architecture, modular extensibility and the internal API. The CMS offers the necessary flexibility and performance for such a complex website like superbude.de. ProcessWire offers options that are only available for larger systems, such as Drupal, and allows a much slimmer development process.” —xport communication GmbH