brandonbraner/auth-test

There is no license information available for the latest version (1.0.6) of this package.

Authentication package for interfacing with Leadpages API's

This package's canonical repository appears to be gone and the package has been frozen as a result. Email us for help if needed.

Installs: 150

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Language:HTML

pkg:composer/brandonbraner/auth-test

1.0.6 2016-08-22 22:12 UTC

This package is not auto-updated.

Last update: 2021-04-07 02:48:43 UTC


README

Build Status

This is beta. Please do not use as it will be removed

Synopsis

Leadpages Auth is meant to make it simple to get your integration into Leadpages off the ground quickly.

  • Abstracts away the required methods to call Leadpages to retrieve your security token.
  • Built in minimal storage abstraction to allow Leadpages extensions to follow known sets of standards.
  • Uses Guzzle5 to allow a consistant Http abstraction layer across all platforms. Guzzle5 chosen for PHP 5.4 support

Code Example - WordPress

<?php

/**
 * require composer autoload this path will probably change for your implementation
 * wordpress would suggest using plugin_dir_path
 * example require plugin_dir_path(dirname(dirname(dirname(__FILE__))))."/vendor/autoload.php";
*/

require dirname(dirname(dirname(__FILE__))) . "/vendor/autoload.php";

use GuzzleHttp\Client;
use Leadpages\Auth\LeadpagesLogin;

/**
 * Extend the Leadpages login abstract class
 * and fill out the required methods to store and retrieve your token
 * Class WordPressLeadpagesLogin
 */
class WordPressLeadpagesLogin extends LeadpagesLogin
{

    /**
     * store token in Wordpress Database
     *
     * @return mixed
     */
    public function storeToken()
    {
        update_option($this->tokenLabel, $this->token);
    }


    /**
     * get token form WordPress Database and set the $this->token
     * $this->token needs to be set on this method
     */
    public function getToken()
    {
        $this->token = get_option($this->tokenLabel);
    }

    /**
     * Delete token from WordPress Database
     * @return mixed
     */
     
    public function deleteToken()
    {
        delete_options($this->tokenLabel);
    }

    /**
     * method to check if token is empty
     *
     * @return mixed
     */
    public function checkIfTokenIsEmpty()
    {
        // TODO: Implement checkIfTokenIsEmpty() method.
    }
}

//instantiate Class
$leadpagesLogin = new WordPressLeadpagesLogin(new Client());
//call get user pipe into parseResponse
$response = $leadpagesLogin->getUser('example@example.com', 'password')->parseResponse();

if($response == 'success'){
    $this->storeToken();
}else{
    //this->response holds a json object with response codes
    return $this->response;
}


//will return true of false if the users stored token retrieves a proper response
$isLoggedIn = $leadpagesLogin->checkCurrentUserToken();


//this will set the response for checkIfUserIsloggedIn to verify against.
//could also chain them as they are fluent $leadpagesLogin->getCurrentUserToken()->checkIfUserIsLoggedIn()
//isLoggedIn should be true if the current token call resulted in a proper response from auth api
$isLoggedIn = $leadpagesLogin->checkIfUserIsLoggedIn();


Installation

Package can be installed via Composer

#install composer
curl -sS https://getcomposer.org/installer | php

Run composer to require the package

php composer.phar require leadpages/leadpages-auth

Next insure that you are included the composer autoloader into your project. Package uses PSR-4 Autoloading

require 'vendor/autoload.php';

API Reference

Docs to come

Tests

Tests are run via PHPUnit

Contributors

License