Last updated 07/08/2024
To integrate Bread & Butter into your website, you’ll need to use our JavaScript Library (JSL) for the frontend UI/interface, and our PHP library to connect to your backend (if needed).
Our JavaScript Library can be found here:
https://github.com/breadbutter/breadbutter-js
The following snippet initializes Bread & Butter on your website and prompts the user to authenticate with the ‘Continue with’ tool. This is usually placed in the header or template page to make sure it is run on all pages of your website.
<script> window.initBreadButter = function() { BreadButter.configure({ app_id: APP_ID }); BreadButter.ui.continueWith(); }; (function(d, s, id){ var js,fjs=d.getElementsByTagName(s)[0]; if(d.getElementById(id)) {return;} js = d.createElement(s); js.id = id; js.src = 'https://cdn.breadbutter.io/dist/breadbutter.7.4.0.1004.min.js'; fjs.parentNode.insertBefore(js, fjs); }(document, 'script', 'breadbutter-js')); </script>
NOTE: The version of the Bread & Butter library is statically set in the following line of the code snippet:
https://cdn.breadbutter.io/dist/breadbutter.7.4.0.1004.min.js
You will need to update the version to take advantage of new features
Code within the initBreadButter method will be called once the JSL is loaded.
The following will configure the JSL for your app. Every page that has the JSL configured will gather user analytics that will be displayed in your dashboard.
BreadButter.configure({ app_id: APP_ID });
NOTE: APP_ID needs to be replaced by the app id corresponding to your app. It can be found here:
https://app.breadbutter.io/app/#/app-settings
The following will trigger the ‘Continue with’ tool to prompt users that are not logged in to do so. This can be removed on pages where you don’t want your users to be prompted to sign in. It can also be removed altogether if you prefer not use this tool.
BreadButter.ui.continueWith();
You can use it to display login options on your website and allow users to authenticate with different providers like Google, etc.
Once the user’s authentication is processed by Bread & Butter, the user is redirected to a callback interface defined in your Bread & Butter app. The example below is a simple interface that accepts the request from Bread & Butter and processes the authentication.
After the interface is created you will need to update and enable the Callback URL with the URL to this interface in your app settings here:
https://app.breadbutter.io/app/#/app-settings
You can find the PHP server library here:
https://github.com/breadbutter/breadbutter-php
Create a new Bread & Butter client
APP_ID can be found at:
https://app.breadbutter.io/app/#/app-settings
APP_SECRET can be created under Advanced Settings at:
https://app.breadbutter.io/app/#/app-settings
use BreadButter\API\BreadButterClient; $breadButterClient = new BreadButterClient(array( 'app_id' => '{APP_ID}', 'app_secret' => '{APP_SECRET}', ));
Retrieve authentication from Bread & Butter server:
You can find the detailed API response here:
https://breadbutter.io/api/server-api/
$authenticationToken = $_REQUEST['authentication_token']; $loginData = $breadButterClient->getAuthentication($authenticationToken); $body = $loginData['body']; $authData = $body['auth_data']; $email = $authData['email_address']; $firstName = $authData['first_name']; $lastName = $authData['last_name']; $profileImage = $authData['profile_image_url']; $destinationURL = $authData['options']['destination_url']; //Use information above to create user in your system, create a session, etc
Redirect the user back to your website
header( "Location: $destinationURL" );
Don’t use Bread & Butter? Want to learn more about how Bread & Butter solves the four biggest problems facing marketers today? Book a demo and see how Bread & Butter is helping marketers make the most of their first-party data
Add authentication & API event tracking to your website/app with a script tag & configuration