I have the following activity connecting facebook
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_facebook);
mFacebook = SavvyActivityDelegate.get().getFacebook(this);
if (mFacebook.isSessionValid()) {
// TODO GET FB ACCESS TOKEN
} else {
mFacebook.authorize(this, FacebookConstants.PERMISSIONS, new AppFacebookDialogListener(FacebookActivity.this,mFacebook));
}
public void onActivityResult(int request, int result, Intent data) {
super.onActivityResult(request, result, data);
mFacebook.authorizeCallback(request, result, data);
}
Here goes the dialog listener used
public class AppFacebookDialogListener implements Facebook.DialogListener {
private final Activity activity;
private final Facebook facebook;
public SavvyFacebookDialogListener(Activity activity, Facebook facebook) {
this.activity = activity;
this.facebook = facebook;
Log.d(LogTag.app, "Facebook constructor"); // activity.finish(); }
@Override public void onComplete(Bundle values) {
Log.d(LogTag.app, "Facebook authorization complete!");
SharedPreferences.Editor editor = PreferenceManager.getDefaultSharedPreferences(activity).edit();
editor.putLong("fb_access_expires", facebook.getAccessExpires());
editor.putString("fb_access_token", facebook.getAccessToken());
editor.commit(); }
@Override public void onFacebookError(FacebookError e) {
Log.e(LogTag.app, e.getErrorType() + ": " + e.getMessage() + " (code: " + e.getErrorCode() + ")", e); }
@Override public void onError(DialogError e) {
Log.e(LogTag.app, e.getMessage(), e); }
@Override public void onCancel() {
Log.d(LogTag.app, "Facebook authorization was cancelled"); } }
The log statement on start of the activity
06-06 15:09:19.314: I/ActivityManager(404): START u0 {cmp=com.biggu.shopsavvy/.FacebookActivity} from pid 17947 06-06 15:09:19.392: D/ShopSavvy(17947): Facebook constructor 06-06 15:09:19.400: I/ActivityManager(404): START u0 {cmp=com.facebook.katana/.ProxyAuth (has extras)} from pid 17947 06-06 15:09:19.415: I/ActivityManager(404): START u0 {cmp=com.facebook.katana/.ProxyAuthDialog (has extras)} from pid 15214
So as per the logs the dialog constructor gets called but none of the callback methods get called .
If the facebook app is not installed then the code works fine and i get the callback authorization complete but the code behaves weirdly on devices with facebook app and user is logged in . Thanks in advance .