Monday, November 10, 2014

FacebookSDK how to request permissions

General:
https://developers.facebook.com/docs/facebook-login/permissions/v2.2

List of all permissions:
https://developers.facebook.com/docs/facebook-login/permissions/v2.2#reference

How to request permissions:
https://developers.facebook.com/docs/facebook-login/permissions/v2.2#adding [Generic description]
https://developers.facebook.com/docs/android/login-with-facebook/v2.2 [For Android]

Friend list interface in Facebook SDK after API Version v2.0

[GET /v2.2/me HTTP/1.1]
A user represents a person on Facebook. The /{user-id} node returns a single user.
1. Go to https://developers.facebook.com/docs/graph-api/reference/v2.2/user
2. Click "Graph Explorer" -> "Get Access Token" -> "User Data Permissions" -> Select "user_about_me" -> Click "Get Access Token", you will see a access token look like "CAACEdEose ... ccKEs" show in the field, then click Submit.
3. You will see a JSON string which is an array of Friendlist objects, Ex:
{
    "id": "1234123412341234",
    "bio": "I love music!",
    "first_name": "bear",
    "gender": "male",
    "last_name": "lin",
    "link": "https://www.facebook.com/app_scoped_user_id/1234123412341234/",
    "locale": "zh_TW",
    "name": "bear lin",
    "timezone": 8,
    "updated_time": "2013-11-17T09:22:13+0000",
    "verified": true
}
4. The more Access token you select, the more information will return.


[GET /v2.2/me/friendlists HTTP/1.1]
A person's 'friend lists' - these are groupings of friends such as "Acquaintances" or "Close Friends", or any others that may have been created
1. Go to https://developers.facebook.com/docs/graph-api/reference/v2.2/user/friendlists
2. Click "Graph Explorer" -> "Get Access Token" -> "Extended Permissions" -> Select "read_friendlists" -> Click "Get Access Token", you will see a access token look like "CAACEdEose ... ccKEs" show in the field, then click Submit.
3. You will see a JSON string which is an array of Friendlist objects, Ex:
{
    "data": [
        {
            "id": "4777092484211",
            "name": "Artists",
            "list_type": "user_created"
        },
        {
            "id": "4777064723517",
            "name": "Musicians",
            "list_type": "user_created"
        }
    ],
    "paging": {
        "next": "https://graph.facebook.com/v2.2/1234123412341234/friendlists?limit=5000&offset=5000&__after_id=enc_AeyE7DuzMXSU9JFIGYuR1XfRcZT-U6YI205muBRRkOIAIAk_UhLZ3kMtWkS67_mgwuE"
    }
}

[GET /v2.2/{friendlist-id} HTTP/1.1]
A friend list - an object which refers to a grouping of friends created by someone or generated automatically for someone (such as the "Close Friends" or "Acquaintances" lists)
1. Go to https://developers.facebook.com/docs/graph-api/reference/v2.2/friendlist
2. In the "Graph Explorer" you should replace "{friendlist-id}" with a valid Id(ex: 4777092484211, you can get it from /v2.2/me/friendlists).
3. After submit, Ex:
{
    "id": "4777092484211",
    "name": "Artists",
    "list_type": "user_created"
}
NameDescriptionType
idThe friend list IDstring
nameThe name of the friend liststring
list_typeThe type of the friend listenum{close_friends, acquaintances, restricted, user_created, education, work, current_city, family}

[GET /v2.2/me/friends HTTP/1.1]
A person's friends.
"Friend list now only returns friends who also use your app".
Read below articles fist:
http://stackoverflow.com/questions/23417356/facebook-graph-api-v2-0-me-friends-returns-empty-or-only-friends-who-also-u
https://developers.facebook.com/docs/apps/changelog [Read API Version v2.0 changelog]

1. Go to https://developers.facebook.com/docs/graph-api/reference/v2.2/user/friends
2. In the "Graph Explorer":
Permissions
  • A user access token with user_friends permission is required to view the current person's friends.
  • This will only return any friends who have used (via Facebook Login) the app making the request.
  • If a friend of the person declines the user_friends permission, that friend will not show up in the friend list for this person.
3. After submit: Ex:
{
    "data": [
        {
            "name": "Eric",
            "id": "33333333333333"
        },
        {
            "name": "Lee",
            "id": "111111111111"
        }
    ],
    "paging": {
        "next": "https://graph.facebook.com/v2.2/1234123412341234/friends?limit=25&offset=25&__after_id=enc_AexidG6KKymgeEvLC38u6ERUDQud__sm2tYQkoPMs2ba6l8E17X73s-pSYx5y5hnuDdwFpyt23dt_Gi3GWiZ1raR"
    },
    "summary": {
        "total_count": 307
    }
}
4. You can also using Postman:
GET /v2.2/1234123412341234/friends?access_token=CAACEdEose0cBAIBIg6ZA9P9YNQQxLpmzT4VSBj2dYClv7vIM7aeXNoHpRTq27yGPh14szRVC2VVU6727V66BItbgUuco1tHVo6ZAwr2LhLlZCu3KxuHSuW6ZASBWm9T44RWWnHCbvFELTSJkveqArEAVEdPwkjHIyDFiAQJX6na9uESefCVfX0e4fUNvKjAkvK7b7BSKkhkCEKulWhPO HTTP/1.1
Host: graph.facebook.com


After API Version v2.0, "/me/friends" no longer return full friends list, it only returns the user's friends who are also using your app, please read: http://stackoverflow.com/questions/23417356/facebook-graph-api-v2-0-me-friends-returns-empty-or-only-friends-who-also-u
------------------------------------------------------------------------------------------------------------------------------
In v2.0 of the Graph API, calling /me/friends returns the person's friends who also use the app.
In addition, in v2.0, you must request the user_friends permission from each user. user_friendsis no longer included by default in every login. Each user must grant the user_friends permission in order to appear in the response to /me/friends. See the Facebook upgrade guide  for more detailed information, or review the summary below.
If you want to access a list of non-app-using friends, there are two options:
  1. If you want to let your people tag their friends  in stories that they publish to Facebook using your App, you can use the /me/taggable_friends API. Use of this endpoint requires review by Facebook  and should only be used for the case where you're rendering a list of friends in order to let the user tag them in a post.
  2. If your App is a Game AND your Game supports Facebook Canvas , you can use the /me/invitable_friends endpoint in order to render a custom invite dialog , then pass the tokens returned by this API to the standard Requests Dialog. 
In other cases, apps are no longer able to retrieve the full list of a user's friends (only those friends who have specifically authorized your app using the user_friends permission). This has been confirmed by Facebook as 'by design'. 
For apps wanting allow people to invite friends to use an app, you can still use the Send Dialog on Web or the new Message Dialog on iOS  and Android .
UPDATE: Facebook have published an FAQ on these changes here:https://developers.facebook.com/docs/apps/faq  which explain all the options available to developers in order to invite friends etc.
------------------------------------------------------------------------------------------------------------------------------
References:
https://developers.facebook.com/docs/apps/faq
https://developers.facebook.com/docs/apps/changelog [Read API Version v2.0 changelog]
https://developers.facebook.com/docs/apps/upgrading#upgrading_v2_0_user_ids

[TODO]
https://developers.facebook.com/docs/graph-api/reference/v2.2/user/taggable_friends
https://developers.facebook.com/docs/graph-api/reference/v2.2/user/invitable_friends

Thursday, November 6, 2014

Change Tomcat HeapSize(JVM Heap) in Eclipse

Recently I've deployed same WAR to Tomcat server on two machines A and B. On machine A everything works well, but on machine B there are error messages: "java.lang.OutOfMemoryError: Java heap space"

I try to reduce Java heap size on machine A to see if same symptom can be reproduce. After change InitialHeapSize and MaxHeapSize to 128MB, I finally can reproduce same issue on machine A.

I am using Tomcat 7 + Eclipse on machine A, here are some references about how to change the heap size using Eclipse:
http://www.mkyong.com/eclipse/eclipse-tomcat-java-lang-outofmemoryerror-java-heap-space/
http://crunchify.com/how-to-increase-tomcat-heapsize-jvm-heap-in-eclipse-ede/

Important parameters:
-Xms<size> - Set initial Java heap size
-Xmx<size> - Set maximum Java heap size
-Xss<size> - Set java thread stack size


Add new Tomcat server arguments in Eclipse on Machine A:
[-XX:+PrintFlagsFinal]
    uintx InitialHeapSize                          := 262228096       {product}           [250MB]
    uintx MaxHeapSize                              := 4196401152      {product}           [4002MB]
     intx ThreadStackSize                           = 1024            {pd product}      
(means the original MaxHeapSize is about 4002MB)

[-Xms512m -Xmx1024m -XX:+PrintFlagsFinal]
    uintx InitialHeapSize                          := 536870912       {product}           [512MB]
    uintx MaxHeapSize                              := 1073741824      {product}           [1024MB]
     intx ThreadStackSize                           = 1024            {pd product}      

[-Xms128m -Xmx128m -XX:+PrintFlagsFinal]
    uintx InitialHeapSize                          := 134217728       {product}           [128MB]
    uintx MaxHeapSize                              := 134217728       {product}           [128MB]
     intx ThreadStackSize                           = 1024            {pd product}        

Wednesday, November 5, 2014

Facebook SDK for Android

[Install the Prerequisites]
1. Prepare your Android development environment
    * Get the Android SDK: http://developer.android.com/sdk/index.html
    * Development tools: JDK 6 (JRE alone is not sufficient), Apache Ant 1.8 or later
    * Create AVD: http://developer.android.com/tools/devices/managing-avds.html
    * Adding SDK Packages: http://developer.android.com/sdk/installing/adding-packages.html
    * Building Your First App: http://developer.android.com/training/basics/firstapp/index.html

2. You'll need to have the Android 2.2 (API 8) components installed in order to use the Facebook SDK.

[Download the Facebook SDK and install Facebook APK for AVD]
1. Download them:
    https://developers.facebook.com/resources/facebook-android-sdk-current.zip
    https://developers.facebook.com/resources/Facebook-11.zip

2. Export PATH:
    * set_env_android.sh:
       $ cat set_env_android.sh
       ANDROID_SDK_HOME="/home/linst/ws/android/ws/adt-bundle-linux-x86_64-20140702/sdk";

       export PATH="${PATH}:${ANDROID_SDK_HOME}/platform-tools";
       export PATH="${PATH}:${ANDROID_SDK_HOME}/tools";

    * source it:
       $ source set_env_android.sh
       $ which adb
       /home/linst/ws/android/ws/adt-bundle-linux-x86_64-20140702/sdk/platform-tools/adb
 
3. Install Facebook APK to emulator:
    * Reason:
"The Facebook SDK uses Facebook's native app to provide support for authentication when it's present. On a real device, you can test this by simply installing this app for free from Google Play. However, it's not possible to access Google Play on an emulator. If you want to test the flow there, you can download and extract the APK of the Facebook app. It should be named Facebook-11.apk or similar. To install it onto an Android emulator ... "
    * Start AVD
    * Install:
       $ unzip Facebook-11.zip
       Archive:  Facebook-11.zip
         inflating: Facebook-11.apk      

       $ adb devices
       List of devices attached
       emulator-5554 device

       $ adb install ./Facebook-11.apk
       2533 KB/s (40683138 bytes in 15.680s)
        pkg: /data/local/tmp/Facebook-11.apk
       Success

4. Import the SDK into Eclipse:
    * Unzip the Facebook SDK:
       $ unzip facebook-android-sdk-3.20.0.zip
    * Import the Facebook SDK library and the samples to Eclipse:
"The installation folder contains a directory called facebook, which is the SDK project itself. There is
also a selection of sample projects in the 
samples folder."

"To import the SDK library project and the samples, with the new SDK, go to Eclipse's 'File' > 'Import' menu, and select 'General' / 'Existing Projects into Workspace'"

"Browse to select the root of your SDK folder, facebook-android-sdk-3.16. The SDK should appear in the list as 'FacebookSDK' along with all of the samples."

"You must unselect the 'Copy projects into workspace' option so that each of the sample projects retains a correct reference to the neighboring SDK. However, this means that Eclipse creates a link to the project in the SDK installation, rather than making a copy of it."

    * Clean your projects to remove build errors: Project -> Clean... -> Clean all projects.
    * Some important paths:
       Facebook SDK root path: /home/linst/ws/android/ws/facebook-android-sdk-3.20.0
       Facebook SDK library: /home/linst/ws/android/ws/facebook-android-sdk-3.20.0/facebook
       Basic Samples: /home/linst/ws/android/ws/facebook-android-sdk-3.20.0/samples
       AudienceNetwork Samples: /home/linst/ws/android/ws/facebook-android-sdk-3.20.0/AudienceNetwork

References:
https://developers.facebook.com/docs/android
https://developers.facebook.com/docs/android/getting-started/
https://developers.facebook.com/docs/reference/android/current