Sto usando l'API del grafico.
Ho un utente che ha effettuato l'accesso e desidero recuperare un elenco di ID pagina di tutte le pagine di cui l'utente è un amministratore.
C'è un modo per farlo? I documenti sono piuttosto scadenti e circolari.
Sto usando l'API del grafico.
Ho un utente che ha effettuato l'accesso e desidero recuperare un elenco di ID pagina di tutte le pagine di cui l'utente è un amministratore.
C'è un modo per farlo? I documenti sono piuttosto scadenti e circolari.
Risposte:
È semplice con Graph API. Passaggi:
manage_pages
autorizzazione dall'utente (autorizzazioni estese).Puoi testare questa procedura in Esplora grafico -> Fai clic sul pulsante "Ottieni token di accesso" - > sotto "Autorizzazioni estese" seleziona "Manage_pages" e invialo. Ti fornirà i dettagli della pagina di amministrazione JSON.
L'ho risolto con un po 'di 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;
}}
Puoi chiamare FB.api(/me/accounts)
se non vuoi usare FQL.
"account" è una connessione dell'oggetto Utente. Consulta la documentazione per questo @ http://developers.facebook.com/docs/reference/api/user
Certo, con Facebook c'è sempre un problema. In questo momento questo metodo restituirà non solo le pagine di cui l'utente è amministratore, ma anche le applicazioni che ha installato. Sono quasi sicuro che questo NON sia il comportamento previsto - mi sembra di ricordare di averlo usato alcuni mesi fa e di aver ottenuto solo un elenco di pagine. La documentazione non fa nemmeno menzione delle applicazioni in questo elenco.
Questo è un problema facile da risolvere: Facebook restituisce il nome, la categoria e l'ID per ogni elemento nell'elenco e ogni applicazione ha una categoria di "Applicazione". Mi sto semplicemente assicurando di elencare solo gli elementi la cui categoria non è "Applicazione".
vai a questo indirizzo
Basta fare clic su Ottieni token di accesso e vai a estesa
Controlla il file manage_pages casella di controllo
e fai clic su Ottieni token di accesso
Quindi sotto FQL scrivi questo
io / account? tipo = pagina
Fare clic su Invia. e otterrai tutti gli elenchi di pagine che hanno effettuato l'accesso come amministratore
me/accounts
supporta il type
parametro di query?
Richiedi l'autorizzazione con JavaScript SDK all'accesso
FB.login(function(){}, {perms:'manage_pages'});
e quindi una volta effettuato l'accesso puoi recuperare le pagine (e le app) come segue:
FB.api('/me/accounts', function(response){
console.log(response);
})
{perms: 'manage_pages'}
e {scope: 'manage_pages'}
?
Tieni presente che la tua soluzione restituisce sia Pages che Applicazioni . Se vuoi strettamente Pages, puoi usare FQL Multiquery con una clausola "Type not equals" come questa:
{
"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)"
}
Autorizzazione
$facebook->getLoginUrl( array( "scope" => "manage_pages" ) );
azione
$accounts = $facebook->api('/me/accounts');
return $accounts;
<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>
Con la nuova API GRAPH v3 con Javascript utilizza il campo "task" invece del campo "perms".
//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"
]
}
Invece di cercare "AMMINISTRATORE" all'interno dell'array, cerca "GESTISCI".
Informazioni complete qui: https://developers.facebook.com/docs/pages/access-tokens