org.cocos2dx.plugin.UserFacebook.java Source code

Java tutorial

Introduction

Here is the source code for org.cocos2dx.plugin.UserFacebook.java

Source

/****************************************************************************
 Copyright (c) 2014 Chukong Technologies Inc.
    
 http://www.cocos2d-x.org
    
 Permission is hereby granted, free of charge, to any person obtaining a copy
 of this software and associated documentation files (the "Software"), to deal
 in the Software without restriction, including without limitation the rights
 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 copies of the Software, and to permit persons to whom the Software is
 furnished to do so, subject to the following conditions:
    
 The above copyright notice and this permission notice shall be included in
 all copies or substantial portions of the Software.
    
 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 THE SOFTWARE.
 ****************************************************************************/

package org.cocos2dx.plugin;

import java.math.BigDecimal;
import java.util.Arrays;
import java.util.Currency;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.List;
import java.util.Locale;

import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.util.Log;

import com.facebook.AppEventsLogger;
import com.facebook.FacebookRequestError;
import com.facebook.HttpMethod;
import com.facebook.LoggingBehavior;
import com.facebook.Request;
import com.facebook.Response;
import com.facebook.Session;
import com.facebook.Session.NewPermissionsRequest;
import com.facebook.Session.OpenRequest;
import com.facebook.SessionState;
import com.facebook.Settings;
import com.facebook.model.GraphUser;

public class UserFacebook implements InterfaceUser {

    private Session.StatusCallback statusCallback = new SessionStatusCallback();
    private static Activity mContext = null;
    private static InterfaceUser mAdapter = null;
    private static Session session = null;
    private static boolean bDebug = true;
    private static boolean isLoggedIn = false;
    private final static String LOG_TAG = "UserFacebook";
    private static final List<String> allPublishPermissions = Arrays.asList("publish_actions", "ads_management",
            "create_event", "rsvp_event", "manage_friendlists", "manage_notifications", "manage_pages");
    private static String userIdStr = "";

    protected static void LogE(String msg, Exception e) {
        Log.e(LOG_TAG, msg, e);
        e.printStackTrace();
    }

    protected static void LogD(String msg) {
        if (bDebug) {
            Log.d(LOG_TAG, msg);
        }
    }

    public String getUserID() {
        return userIdStr;
    }

    public UserFacebook(Context context) {

        mContext = (Activity) context;
        mAdapter = this;
        Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);

        session = Session.getActiveSession();
        if (session == null) {
            session = new Session(context);

            Session.setActiveSession(session);
            if (session.getState().equals(SessionState.CREATED_TOKEN_LOADED)) {
                session.openForRead(new Session.OpenRequest((Activity) context).setCallback(statusCallback));
            }
        }
    }

    @Override
    public void configDeveloperInfo(Hashtable<String, String> cpInfo) {
        LogD("not supported in Facebook pluign");
    }

    @Override
    public void login() {
        PluginWrapper.runOnMainThread(new Runnable() {
            @Override
            public void run() {
                Session session = Session.getActiveSession();

                if (!session.isOpened() && !session.isClosed()) {
                    OpenRequest request = new Session.OpenRequest(mContext);
                    request.setCallback(statusCallback);
                    session.openForRead(request);
                } else {
                    Session.openActiveSession(mContext, true, statusCallback);
                }
            }
        });
    }

    public void login(final String permissions) {

        PluginWrapper.runOnMainThread(new Runnable() {
            @Override
            public void run() {
                String[] permissionArray = permissions.split(",");
                boolean publishPermission = false;
                for (int i = 0; i < permissionArray.length; i++) {
                    if (allPublishPermissions.contains(permissionArray[i])) {
                        publishPermission = true;
                        break;
                    }
                }

                Session session = Session.getActiveSession();
                if (session.isOpened()) {
                    if (session.getPermissions().containsAll(Arrays.asList(permissionArray))) {
                        LogD("login called when use is already connected");
                    } else {
                        NewPermissionsRequest newPermissionsRequest = new NewPermissionsRequest(mContext,
                                Arrays.asList(permissionArray));
                        newPermissionsRequest.setCallback(statusCallback);
                        if (publishPermission)
                            session.requestNewPublishPermissions(newPermissionsRequest);
                        else
                            session.requestNewReadPermissions(newPermissionsRequest);
                    }
                } else {
                    if (!session.isClosed()) {
                        OpenRequest request = new Session.OpenRequest(mContext);
                        request.setCallback(statusCallback);
                        request.setPermissions(Arrays.asList(permissionArray));
                        if (publishPermission)
                            session.openForPublish(request);
                        else
                            session.openForRead(request);
                    } else {
                        Session.openActiveSession(mContext, true, statusCallback);
                    }
                }

            }
        });
    }

    @Override
    public void logout() {
        Session session = Session.getActiveSession();
        if (!session.isClosed()) {
            session.closeAndClearTokenInformation();
            isLoggedIn = false;
        }

    }

    @Override
    public boolean isLogined() {
        return isLoggedIn;
    }

    public boolean isLoggedIn() {
        return isLoggedIn;
    }

    @Override
    public String getSessionID() {
        return null;
    }

    @Override
    public void setDebugMode(boolean debug) {
        bDebug = debug;
    }

    @Override
    public String getPluginVersion() {
        return "0.2.0";
    }

    @Override
    public String getSDKVersion() {
        return Settings.getSDKVersion();
    }

    public void setSDKVersion(String version) {
        Settings.setSDKVersion(version);
    }

    public String getAccessToken() {
        return Session.getActiveSession().getAccessToken();
    }

    public String getPermissionList() {
        StringBuffer buffer = new StringBuffer();
        buffer.append("{\"permissions\":[");
        List<String> list = Session.getActiveSession().getPermissions();
        for (int i = 0; i < list.size(); ++i) {
            buffer.append("\"").append(list.get(i)).append("\"");
            if (i != list.size() - 1)
                buffer.append(",");
        }
        //       .append(Session.getActiveSession().getPermissions().toString())
        buffer.append("]}");
        return buffer.toString();
    }

    public void request(final JSONObject info /*String path, int method, JSONObject params, int nativeCallback*/ ) {
        PluginWrapper.runOnMainThread(new Runnable() {

            @Override
            public void run() {
                try {
                    String path = info.getString("Param1");

                    int method = info.getInt("Param2");
                    HttpMethod httpmethod = HttpMethod.values()[method];

                    JSONObject jsonParameters = info.getJSONObject("Param3");
                    Bundle parameter = new Bundle();
                    Iterator<?> it = jsonParameters.keys();
                    while (it.hasNext()) {
                        String key = it.next().toString();
                        String value = jsonParameters.getString(key);
                        parameter.putString(key, value);
                    }

                    final int nativeCallback = info.getInt("Param4");

                    Request request = new Request(Session.getActiveSession(), path, parameter, httpmethod,
                            new Request.Callback() {

                                @Override
                                public void onCompleted(Response response) {
                                    LogD(response.toString());

                                    FacebookRequestError error = response.getError();

                                    if (error == null) {
                                        nativeRequestCallback(0,
                                                response.getGraphObject().getInnerJSONObject().toString(),
                                                nativeCallback);
                                    } else {
                                        nativeRequestCallback(error.getErrorCode(),
                                                "{\"error_message\":\"" + error.getErrorMessage() + "\"}",
                                                nativeCallback);
                                    }
                                }
                            });
                    request.executeAsync();
                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }

        });

    }

    public void activateApp() {
        AppEventsLogger.activateApp(mContext);
        // com.facebook.Settings.publishInstallAsync(mContext, Settings.getApplicationId());
    }

    public void logEvent(String eventName) {
        FacebookWrapper.getAppEventsLogger().logEvent(eventName);
    }

    public void logEvent(JSONObject info) {
        int length = info.length();
        if (3 == length) {
            try {
                String eventName = info.getString("Param1");
                Double valueToSum = info.getDouble("Param2");

                JSONObject params = info.getJSONObject("Param3");
                Iterator<?> keys = params.keys();
                Bundle bundle = new Bundle();
                while (keys.hasNext()) {
                    String key = keys.next().toString();
                    bundle.putString(key, params.getString(key));
                }

                FacebookWrapper.getAppEventsLogger().logEvent(eventName, valueToSum, bundle);
            } catch (JSONException e) {
                e.printStackTrace();
            }
        } else if (2 == length) {
            try {
                String eventName = info.getString("Param1");
                Double valueToSum = info.getDouble("Param2");
                FacebookWrapper.getAppEventsLogger().logEvent(eventName, valueToSum);
            } catch (JSONException e) {
                try {
                    String eventName = info.getString("Param1");
                    JSONObject params = info.getJSONObject("Param2");
                    Iterator<?> keys = params.keys();
                    Bundle bundle = new Bundle();
                    while (keys.hasNext()) {
                        String key = keys.next().toString();
                        bundle.putString(key, params.getString(key));
                    }
                    FacebookWrapper.getAppEventsLogger().logEvent(eventName, bundle);
                } catch (JSONException e1) {
                    e1.printStackTrace();
                }
            }
        }

    }

    public void logPurchase(JSONObject info) {
        int length = info.length();
        if (3 == length) {
            try {
                Double purchaseNum = info.getDouble("Param1");
                String currency = info.getString("Param2");

                JSONObject params = info.getJSONObject("Param3");
                Iterator<?> keys = params.keys();
                Bundle bundle = new Bundle();
                while (keys.hasNext()) {
                    String key = keys.next().toString();
                    bundle.putString(key, params.getString(key));
                }
                Currency currencyStr = null;
                try {
                    currencyStr = Currency.getInstance(currency);
                } catch (IllegalArgumentException e) {
                    currencyStr = Currency.getInstance(Locale.getDefault());
                    e.printStackTrace();
                }

                FacebookWrapper.getAppEventsLogger().logPurchase(new BigDecimal(purchaseNum), currencyStr, bundle);
            } catch (JSONException e) {
                e.printStackTrace();
            }
        } else if (2 == length) {
            try {
                Double purchaseNum = info.getDouble("Param1");
                String currency = info.getString("Param2");
                FacebookWrapper.getAppEventsLogger().logPurchase(new BigDecimal(purchaseNum),
                        Currency.getInstance(currency));
            } catch (JSONException e) {
                e.printStackTrace();
            }
        }
    }

    private class SessionStatusCallback implements Session.StatusCallback {
        @Override
        public void call(Session session, SessionState state, Exception exception) {
            onSessionStateChange(session, state, exception);
            if (false == isLoggedIn) {
                if (SessionState.OPENED == state) {
                    isLoggedIn = true;
                    UserWrapper.onActionResult(mAdapter, UserWrapper.ACTION_RET_LOGIN_SUCCEED,
                            getSessionMessage(session));
                } else if (SessionState.CLOSED_LOGIN_FAILED == state /*|| SessionState.CLOSED == state*/) {
                    UserWrapper.onActionResult(mAdapter, UserWrapper.ACTION_RET_LOGIN_FAILED,
                            getErrorMessage(exception, "login failed"));
                }

            } else {
                if (SessionState.OPENED_TOKEN_UPDATED == state) {
                    UserWrapper.onActionResult(mAdapter, UserWrapper.ACTION_RET_LOGIN_SUCCEED,
                            getSessionMessage(session));
                } else if (SessionState.CLOSED == state || SessionState.CLOSED_LOGIN_FAILED == state) {
                    isLoggedIn = false;
                    UserWrapper.onActionResult(mAdapter, UserWrapper.ACTION_RET_LOGIN_FAILED,
                            getErrorMessage(exception, "failed"));
                }
            }
        }
    }

    private void onSessionStateChange(Session session, SessionState state, Exception exception) {
        if (session != null && session.isOpened()) {
            // make request to the /me API
            Request.newMeRequest(session, new Request.GraphUserCallback() {
                @Override
                public void onCompleted(GraphUser user, Response response) {
                    if (user != null) {
                        userIdStr = user.getId();
                    }

                }
            }).executeAsync();
        }
    }

    private String getSessionMessage(Session session) {
        StringBuffer buffer = new StringBuffer();
        buffer.append("{\"accessToken\":\"").append(session.getAccessToken()).append("\",");
        buffer.append("\"permissions\":[");
        List<String> list = session.getPermissions();
        for (int i = 0; i < list.size(); ++i) {
            buffer.append("\"").append(list.get(i)).append("\"");
            if (i != list.size() - 1)
                buffer.append(",");
        }
        buffer.append("]}");
        System.out.println(buffer.toString());
        return buffer.toString();
    }

    private String getErrorMessage(Exception exception, String message) {
        StringBuffer errorMessage = new StringBuffer();
        errorMessage.append("{\"error_message\":\"").append(null == exception ? message : exception.getMessage())
                .append("\"}");

        return errorMessage.toString();
    }

    private native void nativeRequestCallback(int ret, String msg, int cbIndex);
}