Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6176585
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T00:07:39+00:00 2026-05-24T00:07:39+00:00

I’m using https://github.com/abraham/twitteroauth library. I already created my app on Twitter, the callbacks are

  • 0

I’m using https://github.com/abraham/twitteroauth library. I already created my app on Twitter, the callbacks are working fine (even on localhost), but one thing that is bugging me is HOW the auto-login happens? I know there’s “user_id” that is stored in the MYSQL database, along with oauth_token and oauth_token_secret, but how do I obtain user_id as soon as the user enters the site, so I can query the database to see if it already exists and what not, without having to popup the authorize twitter popup then reaching the callback, over and over again?

I’ve seen a lot of questions like this one, but no one ever answered it in a satisfying way.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T00:07:39+00:00Added an answer on May 24, 2026 at 12:07 am

    actually, it needs to be a mix of PHP own $_SESSION with OAuth callbacks. After the callback, set the current user ID you inserted on the database or query for “user_id” from Twitter OAuth response (that you should ALSO store on the database, along with the username), then use that for future reference, and using $_SESSION containing the registered user data on your own database.

    So, for a quick example

    function action_login()
    {
        if ( ! $this->user->is_logged())
        {
            // Create TwitterOAuth object with our Twitter provided keys
            $tOAuth = new TwitterOAuth($this->config->get('consumer_key'), $this->config->get('consumer_secret'));
            // Generate request tokens
            $requestToken = $tOAuth->getRequestToken(url::site('auth/twitter','http'));
            $_SESSION["oauth_token"] = $requestToken["oauth_token"];
            $_SESSION["oauth_token_secret"] = $requestToken["oauth_token_secret"];
            // Display Twitter log in button with encoded link
            $this->view->set('url', $tOAuth->getAuthorizeURL($requestToken["oauth_token"]));
            $_SESSION['current_url'] = Request::detect_uri();
        }
    
        echo $this->view->render();
    }
    
    public function action_twitter()
    {
        if ( empty($_GET["denied"]) && isset($_GET["oauth_token"])) 
        {
            if ($_GET["oauth_token"] == @$_SESSION["oauth_token"]) 
            {
                // Use generated request tokens (from session) to construct object
                $tOAuth = new TwitterOAuth($this->config->get('consumer_key'), $this->config->get('consumer_secret'), $_SESSION["oauth_token"], $_SESSION["oauth_token_secret"]);
                // Retrieve access token from Twitter
                $accessToken = $tOAuth->getAccessToken();
                // Check we have valid response
                if(is_numeric($accessToken["user_id"]))  {
                    // Remove request token session variables
                    if ($this->user->loaded() || $this->user->where('user_id', '=', $accessToken['user_id'])->find()->loaded())
                    {
                        $this->user->values(array(
                            'oauth_token' => $accessToken['oauth_token'],
                            'oauth_token_secret' => $accessToken['oauth_token_secret'],
                            'screen_name' => $accessToken['screen_name'],
                        ))->update();
                    }
                    else
                    {
                        $this->user->values(array(
                            'user_id' => $accessToken['user_id'],
                            'oauth_token' => $accessToken['oauth_token'],
                            'oauth_token_secret' => $accessToken['oauth_token_secret'],
                            'screen_name' => $accessToken['screen_name'],
                        ))->create();
                    }
    
                    unset($_SESSION["oauth_token"]);
                    unset($_SESSION["oauth_token_secret"]);
                    echo $this->view->render();
                    // Redirect to main page
                } 
            }
        }
    
        $this->request->redirect($_SESSION['current_url']);
    }
    

    so basically, the AUTO LOGIN (like the user is already logged to twitter, and already registered to your website) can’t be done without him clicking the LOGIN WITH TWITTER button, unless you set the lifetime of your $_SESSION pretty high (like it happens with twitpic for example).

    $this->user->is_logged() is checking for $_SESSION['id'] (auto increment on MYSQL) and $_SESSION['twitter']['user_id'] from twitter info

    EDIT: Also, the quickest and cleanest way to do it, is to make an AJAX call on the page load with the Twitter credentials using the Javascript SDK, then set the $_SESSION variables with the info the SDK provided.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

We're building an app, our first using Rails 3, and we're having to build
I am using Paperclip to handle profile photo uploads in my app. They upload
I'm new to using the Perl treebuilder module for HTML parsing and can't figure
That's pretty much it. I'm using Nokogiri to scrape a web page what has
link Im having trouble converting the html entites into html characters, (&# 8217;) i
I'm using v2.0 of ClassTextile.php, with the following call: $testimonial_text = $textile->TextileRestricted($_POST['testimonial']); ... and
I'm making a simple page using Google Maps API 3. My first. One marker
I'm parsing an RSS feed that has an ’ in it. SimpleXML turns this
We are using XSLT to translate a RIXML file to XML. Our RIXML contains
I'm trying to decode HTML entries from here NYTimes.com and I cannot figure out

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.