89

I'm using the graph api.

I have a logged in user, and want to get back a list of page ids of all the pages that the user is an admin of.

Is there a way of doing this? The docs are pretty bad - and circular.

2
  • 8
    10 years later, and the documentation is still bad.
    – Darkwonder
    Commented Aug 26, 2020 at 6:04
  • bad is a SEVERE understatement. Gack. Commented Nov 1, 2021 at 18:37

10 Answers 10

151

Its simple with Graph API. Steps:

  1. Get the manage_pages permission from the user (extended permissions).
  2. Call the Graph API - https://graph.facebook.com/me/accounts

You can test this procedure in the graph explorer -> Just click on 'Get Access Token' button-> under 'Extended permission' check 'manage_pages' & submit it. It will give you the admin-page-details JSON.

9
  • 11
    Switching answers as this sounds like the more standard/stable way of doing it. Although I would warn against any use of the word 'simple': everything is simple once you know how :)
    – EoghanM
    Commented Mar 2, 2012 at 9:33
  • 1
    ya. u r right. But there can be several solutions to a problem. We need to choose the simplest among them. Commented Mar 2, 2012 at 12:08
  • 1
    If you're using FB PHP SDK it's easier: just $user_admin_pages = $facebok->api('/me/accounts'); Commented May 3, 2012 at 18:24
  • 2
    The advantage of querying with FQL vs. using a graph request is that graph always forces the returned data to be 'paged' (it only returns the first few results, and a link to the next few) - while in FQL it always returns the entire result-set in one time.
    – Yuval A.
    Commented Apr 28, 2013 at 12:33
  • 6
    Thanks. It lists pages only if the current user administrates app. Is there any way to list pages of another person? Commented Jan 2, 2015 at 13:51
14

I solved it with some FQL:

FB.api({method: 'fql.multiquery',
        access_token: <access_token>,
        queries: {
            query1: 'select page_id from page_admin where uid = ' + <uid>,
            query2: 'select page_id, name, page_url from page where page_id in (select page_id from #query1)'
        }
       }, function(queries){
           var pages = queries[1].fql_result_set;
       }}
1
  • 6
    As of August 2014: "The FQL and REST APIs are no longer available in v2.1: Previously announced with v2.0, apps must migrate to versioned Graph API calls starting with v2.1.". In other words, the FQL can no longer be used. Commented Aug 26, 2015 at 7:31
12

go to this address

https://developers.facebook.com/tools/explorer/431294226918345/?method=GET&path=me%2Faccounts%3Ftype%3Dpage`

Just click on get Access token and go to extended Permission

Check the manage_pages checkbox

and click Get Access Token

Then under FQL write this

me/accounts?type=page

Click on Submit . and you will get all page lists that logged in user admin

1
  • 5
    Where have you found that me/accounts supports type query parameter?
    – Serge S.
    Commented Jul 21, 2015 at 8:55
11

You can call FB.api(/me/accounts) if you don't want to use FQL.

'accounts' is a connection of the User object. See the documentation for this @ http://developers.facebook.com/docs/reference/api/user

Of course, with Facebook, there's always a catch. Right now this method will return not only the pages the user is an admin of, but also what applications they have installed. I'm almost positive this is NOT the intended behavior - I seem to remember using this a few months ago and only getting a list of pages. The documentation makes no mention of applications in this list either.

This is an easy problem to solve though - Facebook returns the name, category, and id for each item on the list, and each application has a category of 'Application'. I'm simply making sure I only list items whose category is not 'Application'.

3
  • 1
    As of December 2012, the documentation for 'accounts' states that it will return pages and apps the user owns. Commented Dec 7, 2012 at 3:08
  • Is thr any way to list pages of another person Commented Jan 2, 2015 at 14:02
  • @SoorajlalKG no, you won't have the permission to do so.
    – Raptor
    Commented Jul 30, 2015 at 10:46
7

You ask for the permission with the JavaScript SDK on login

FB.login(function(){}, {perms:'manage_pages'});

and then once they log in you can retrieve the pages (and apps) as follow :

FB.api('/me/accounts', function(response){
    console.log(response);
})
1
  • 5
    What is the difference between {perms: 'manage_pages'} and {scope: 'manage_pages'}? Commented Dec 19, 2013 at 9:19
7

You can also use "pages_show_list" permission, if you want only the list of facebook pages the user is admin of.

The "manage_pages" permission will ask the user permission to manage his pages, which can be too intrusive depending on what you need it for.

5

Note that your solution returns Pages as well as Applications. If you strictly want Pages, you can use FQL Multiquery with a "Type not equals" clause like this:

{
"query1":"select page_id from page_admin where uid = me()",
"query2":"select page_id, name, page_url, type from page where type!='APPLICATION' AND page_id in (select page_id from #query1)"
}
5

Permission

$facebook->getLoginUrl( array( "scope" => "manage_pages" ) );

action

$accounts = $facebook->api('/me/accounts');  
return $accounts;
1
<head>
 <link rel="stylesheet" href="@Url.Content("~/Content/jquery.remodal.css")">
</head>

<body>
<script type="text/javascript" src="@Url.Content("~/Scripts/Home/jquery.remodal.js")"></script>
<div class="remodal" id="page-selector-remodal" data-remodal-id="pageselector">
        <p>Please select a facebook page Share </p>
        <div id="page-name-container">
            <select id="page-name" class="form-control">
            </select>
        </div>
        <a class="remodal-confirm" id="facebookPageSelectSubmit" href="#">OK</a>
        <a class="remodal-cancel" id="remodal-cancel" href="#">CANCEL</a>
    </div>

    <div data-remodal-id="modal-status">
        <p id="modal-status-content">
            The Account you have selected does not have Email.
        </p>
        <br>
        <a class="remodal-confirm" href="#">OK</a>
    </div>
<script type="text/javascript>
 (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 = "//connect.facebook.net/en_US/sdk.js";
            fjs.parentNode.insertBefore(js, fjs);
        }(document, 'script', 'facebook-jssdk'));

        window.fbAsyncInit = function () {
            FB.init({
                appId: 'YOUR APP ID',
                cookie: true,  // enable cookies to allow the server to access 
                // the session
                xfbml: true,  // parse social plugins on this page
                version: 'v2.2' // use version 2.1
            });
        };

        var pageSelector = $('[data-remodal-id=pageselector]').remodal();
        var modalstatus = $('[data-remodal-id=modal-status]').remodal();

        function statusChangeCallback(response) {

            if (response.status === 'connected') {
                // Logged into your app and Facebook.
                //testAPI();
            } else if (response.status === 'not_authorized') {
                // The person is logged into Facebook, but not your app.
                $("#modal-status-content").empty().html(response.status);
                modalstatus.open();
            }

            else {
                $("#modal-status-content").empty().html(response.status);
                modalstatus.open();
                // The person is not logged into Facebook, so we're not sure if
                // they are logged into this app or not.
                document.getElementById('status').innerHTML = 'Please log ' +
                    'into Facebook.';
            }
        }


        function FacebookHandler() {
            FB.login(function (result) {
                if (result != null && result.authResponse != null && result.authResponse != undefined) {
                    facebookPageData = result;
                    FB.api('/me/accounts', function (accountsResult) {
                        if (accountsResult != null && accountsResult.data.length != 0) {
                            //open the remodal here
                            pageSelector.open();
                            facebookAccountsData = accountsResult;
                            var data = accountsResult['data'];
                            if (data != null) {
                                for (var i = 0; i < data.length; i++) {
                                    $("#page-name").append('<option value="' + data[i].id + '">' + data[i].name + '</option>');
                                }
                            }
                            unblockUI('body');
                            $("#flip-container, #feature-container, #branding-container, #intro-arrow-container, #share-container, #copyright-text-container").hide();
                            $("body").css("padding-right", "0");
                        }
                        else {
                            $("#modal-status-content").empty().html("The Account you have selected does not have any facebook page,<br />Post to Wall.");
                            modalstatus.open();
                            pageSelector.open();
                            unblockUI('body');
                        }
                    });
                }
                else {
                    $("#modal-status-content").empty().html("Unable to retrieve your details from facebook, try again after sometime.");
                    modalstatus.open();
                    unblockUI('body');
                }
            }, { scope: 'manage_pages, publish_stream' });
        }

        $("#facebookPageSelectSubmit").on("click", function () {
            var facebookpageId = $("#page-name option:selected").val();
            if (facebookpageId != null) {
                FB.api('/' + facebookpageId, function (identity) {

                    if (identity != null) {
                        FB.api('/' + facebookpageId, { fields: 'access_token' }, function (resp) {
                            if (resp.access_token != null) {
                                //Get the "resp"(Data) here
                        }
                        else {

                        }

                    });
                }

                else {

                }
            });
        }
        else {

        }
    });
</script>

//Finally call the "FacebookHandler()" function on click


</body>
2
  • You seem to use some frameworks in your codes, would you mind to explain it?
    – Raptor
    Commented Jul 30, 2015 at 10:43
  • Just posting a code is not a good answer, from my point of view.
    – Igorzovisk
    Commented Oct 16, 2018 at 17:08
0

With the new GRAPH API v3 with Javascript use the 'tasks' field instead of 'perms' field.

//Example JS Call
FB.api('/me/accounts?fields=name,picture.type(square),access_token,tasks', function(response) {console.log(response)});

//Example Response
{
      "name": "Engage",
      "picture": {
        "data": {
          "height": 50,
          "is_silhouette": false,
          "url": "https://scontent.xx.fbcdn.net/v/t1.0-1/c1.0.50.50a/p50x50/430597_259746387431503_2144341304_n.jpg?_nc_cat=103&_nc_eui2=AeGVrU8Wxe7k5BMvRXOEAcUo9dMIxyeMP9POPkYDwfgdRl8QquAtz1GcwXpJaK4z_0o&_nc_ht=scontent.xx&oh=e5b952a4adbbcd1b1af6b71b688f7284&oe=5CF9A64C",
          "width": 50
        }
      },
      "access_token": "XXXXXXXXXX",
      "id": "253263371413138",
      "tasks": [
        "ANALYZE",
        "ADVERTISE",
        "MODERATE",
        "CREATE_CONTENT",
        "MANAGE"
      ]
    }

Instead of looking of 'ADMINISTER' within the array, look for 'MANAGE'.

Full info here: https://developers.facebook.com/docs/pages/access-tokens

Not the answer you're looking for? Browse other questions tagged or ask your own question.