Clef is secure two-factor auth without passwords. With the wave of their phone, users can log in to your site — it's like ✨ magic ✨!
Get started in three easy steps:
- Download the iOS or Android app on your phone
- Sign up for a Clef developer account at https://www.getclef.com/developer and create an application. That's where you'll get your API credentials (
app_id
andapp_secret
) and manage settings for your Clef integration. - Follow the directions below to integrate Clef into your site's log in flow.
We'll walk you through the full Clef integration with PHP below. You can also run this sample app locally.
The Clef button is the entry point into the Clef experience. Adding it to your site is as easy as dropping a script
tag wherever you want the button to show up.
Set the data-redirect-url
to the URL in your app where you will complete the OAuth handshake. You'll also want to set data-state
to an unguessable random string.
<script type='text/javascript'
class='clef-button'
src='https://clef.io/v3/clef.js'
data-app-id='<?php echo APP_ID ?>'
data-redirect-url='http://localhost:8888/clef.php'
data-state='<?php echo $state ?>'>
</script>
See the code in action or read more here.
Once you've set up the Clef button, you need to be able to handle the OAuth handshake. This is what lets you retrieve information about a user after they authenticate with Clef. The easiest way to do this is to use the Clef API wrapper for PHP, which you can install via Composer
or by manually including the files.
To use it, pass your app_id
and app_secret
to the initializer:
\Clef\Clef::initialize(APP_ID, APP_SECRET);
Then at the route you created for the OAuth callback, access the code
URL parameter and exchange it for user information.
Before exchanging the code
for user information, you first need to verify the state
parameter sent to the callback to make sure it's the same one as the one you set in the button. (You can find implementations of the validate_state
and generate_state_parameter
functions in clef.php
and index.php
.)
<?php
require_once('config.php');
require_once('vendor/autoload.php');
if (!session_id()) {
session_start();
}
if (isset($_GET["code"]) && $_GET["code"] != "") {
validate_state($_GET["state"]);
\Clef\Clef::initialize(APP_ID, APP_SECRET);
try {
$response = \Clef\Clef::get_login_information($_GET["code"]);
$result = $response->info;
// reset the user's session
if (isset($result->id) && ($result->id != '')) {
//remove all the variables in the session
session_unset();
// destroy the session
session_destroy();
if (!session_id())
session_start();
$clef_id = $result->id;
$_SESSION['name'] = $result->first_name .' '. $result->last_name;
$_SESSION['email'] = $result->email;
$_SESSION['user_id'] = $clef_id;
$_SESSION['logged_in_at'] = time(); // timestamp in unix time
require_once('mysql.php');
$user = get_user($clef_id, $mysql);
if (!$user) {
insert_user($clef_id, $result->first_name, $mysql);
}
// send them to the member's area!
header("Location: members_area.php");
}
} catch (Exception $e) {
echo "Login with Clef failed: " . $e->getMessage();
}
}
?>
See the code in action or read more here.
Logout with Clef allows users to have complete control over their authentication sessions. Instead of users individually logging out of each site, they log out once with their phone and are automatically logged out of every site they used Clef to log into.
To make this work, you need to set up timestamped logins, handle the logout webhook and compare the two every time you load the user from your database.
Setting up timestamped logins is easy. You just add a timestamp to the session everywhere in your application code that you do the Clef OAuth handshake:
$_SESSION['logged_in_at'] = time();
See the code in action or read more here
Every time a user logs out of Clef on their phone, Clef will send a POST
to your logout hook with a logout_token
. You can exchange this for a Clef ID:
<?php
require('config.php');
require_once('vendor/autoload.php');
if(isset($_POST['logout_token'])) {
\Clef\Clef::initialize(APP_ID, APP_SECRET);
try {
$clef_id = \Clef\Clef::get_logout_information($_POST["logout_token"]);
require('mysql.php');
update_logged_out_at($clef_id, time(), $mysql);
die(json_encode(array('success' => true)));
} catch (Exception $e) {
die(json_encode(array('error' => $e->getMessage())));
}
}
?>
See the code in action or read more here.
You'll want to make sure you have a logged_out_at
attribute on your User
model. Also, don't forget to specify this URL as the logout_hook
in your Clef application settings so Clef knows where to notify you.
Every time you load user information from the database, you'll want to compare the logged_in_at
session variable to the user logged_out_at
field. If logged_out_at
is after logged_in_at
, the user's session is no longer valid and they should be logged out of your application.
<?php
require('config.php');
session_start();
// don't let those filthy nonmembers in here
if(!isset($_SESSION["user_id"])) {
header("Location: index.php");
}
require('mysql.php');
$user = get_user($_SESSION['user_id'], $mysql);
if (!$user) header("Location: index.php");
if (isset($user['logged_out_at'])) {
$logged_out_at = $user['logged_out_at'];
if (!isset($_SESSION['logged_in_at']) || $_SESSION['logged_in_at'] < $logged_out_at) {
session_destroy();
header('Location: index.php');
}
}
?>
See the code in action here or read more here
To run this sample app, clone the repo:
$ git clone https://github.com/clef/sample-php.git
Then configure your local database and run on localhost:8000.
# create clef database with MySQL command line
mysql > CREATE DATABASE clef_test;
mysql > USE clef_test;
mysql > CREATE TABLE users (clef_id VARCHAR(32), name VARCHAR(64));
mysql > exit;
$ php -S localhost:8000
You can find our most up-to-date documentation at http://docs.getclef.com. It covers additional topics like customizing the Clef button and testing your integration.
Have a question or just want to chat? Send an email to [support@getclef.com](mailto: support@getclef.com).
We're always around, but we do an official Q&A every Friday from 10am to noon PST :) — would love to see you there!
Clef is an Oakland-based company building a better way to log in online. We power logins on more than 80,000 websites and are building a beautiful experience and inclusive culture. Read more about our values, and if you like what you see, come work with us!