BoxLang 🚀 A New JVM Dynamic Language Learn More...

OAuth Support Module

v1.0.0 Modules

Coldbox Module to allow OAuth Support

Currently this module only supports OAuth v1. I'm working on modularizing OAuth v2 and hopefully will release it soon.

Setup & Installation

Here is an example handler that will inject the module service and handle login to twitter

component {

    property name="oauthService" inject="oauthV1Service@oauth";

    function index(event,rc,prc){
        var data = getSetting('twitter')['oauth'];

        if(!structKeyExists(session,'twitterOAuth')){
            session['twitterOAuth'] = structNew();
        }

        if( event.getValue('id','doNothing') == 'activateUser' ){
            var results = duplicate(session['twitterOAuth']);

            oauthService.init();
            oauthService.setRequestMethod('GET');
            oauthService.setConsumerKey(data['key']);
            oauthService.setConsumerSecret(data['secret']);
            oauthService.setAccessToken(session['twitterOAuth']['oauth_token']);
            oauthService.setAccessTokenSecret(session['twitterOAuth']['oauth_token_secret']);
            oauthService.setRequestURL('https://api.twitter.com/1.1/users/show.json');
            oauthService.addParam(name="user_id",value=results['referenceID']);
            var data = deserializeJSON(oauthService.send()['fileContent']);

            announceInterception( state='socialLoginSuccess', interceptData=results );

            location(url="/",addToken=false);

        }else if( event.valueExists('oauth_token') ){
            session['twitterOAuth']['oauth_token'] = event.getValue('oauth_token');
            session['twitterOAuth']['oauth_verifier'] = event.getValue('oauth_verifier');

            oauthService.init();
            oauthService.setConsumerKey(data['key']);
            oauthService.setConsumerSecret(data['secret']);
            oauthService.setRequestURL('https://api.twitter.com/oauth/access_token');
            oauthService.setRequestMethod('POST');
            oauthService.addParam(name="oauth_token",value=session['twitterOAuth']['oauth_token']);
            oauthService.addParam(name="oauth_verifier",value=session['twitterOAuth']['oauth_verifier']);

            var results = oauthService.send();

            var results = oauthService.send();
            if( results['status_code'] == 200 ){
                var myFields = listToArray(results['fileContent'],'&');

                for(var i=1;i<=arrayLen(myFields);i++){
                    session['twitterOAuth'][listFirst(myFields[i],'=')] = listLast(myFields[i],'=');
                }
                setNextEvent('twitter/oauth/activateUser')
            }else{
                throw('Unknown OAuth Error');
            }

        }else{

            oauthService.init();
            oauthService.setConsumerKey(data['key']);
            oauthService.setConsumerSecret(data['secret']);
            oauthService.setRequestURL('https://api.twitter.com/oauth/request_token');
            oauthService.setRequestMethod('POST');

            oauthService.addParam(name="oauth_callback",value="#( cgi.server_port == 443 ? 'https' : 'http' )#://#cgi.http_host#/#event.getCurrentModule()#/oauth/");

            var results = oauthService.send();

            if( results['status_code'] == 200 ){
                var myFields = listToArray(results['fileContent'],'&');

                for(var i=1;i<=arrayLen(myFields);i++){
                    session['twitterOAuth'][listFirst(myFields[i],'=')] = listLast(myFields[i],'=');
                }

                location(url="https://api.twitter.com/oauth/authorize?oauth_token=#session['twitterOAuth']['oauth_token']#",addToken=false);
            }else{
                throw('Unknown OAuth Error');
            }
        }
    }

}

$ box install nsg-module-oauth

No collaborators yet.
 
  • {{ getFullDate("2015-02-17T16:25:10Z") }}
  • {{ getFullDate("2016-06-09T06:41:38Z") }}
  • 3,692
  • 4,201