/unity3d-profile

Unity3D plugin for Facebook, Twitter and Google Plus. The social module of SOOMLA - free2play mobile game framework for iOS and Android.

Primary LanguageC#Apache License 2.0Apache-2.0

This project is a part of The SOOMLA Framework, which is a series of open source initiatives with a joint goal to help mobile game developers do more together. SOOMLA encourages better game design, economy modeling, social engagement, and faster development.

Haven't you ever wanted a status sharing one liner that looks like this ?!

SoomlaProfile.UpdateStatus(Provider.FACEBOOK, "I love this game !", new VirtualItemReward( ... ));

unity3d-profile

March 9th: v2.0.8 Unity 5 compatibility patch.

If you are upgrading an already imported profile module, make sure to delete the <project>/Assets/Soomla/compilations folder, and the <project>/Assets/WebPlayerTemplates/SoomlaSdkResources folder.

If you get the “API Update Required” window, click the "I Made a Backup. Go Ahead!" button, Unity will automatically update some of our code.

November 17th: v2.0 unity3d-profile supports Facebook, Google+ and Twitter

SOOMLA's Profile Module for Unity3d

unity3d-profile is the Unity3D flavour of SOOMLA's Profile Module. This project uses android-profile and ios-profile in order to provide game developers with social network connectivity for their Unity3D projects.

unity3d-profile easily connects to SOOMLA's virtual economy model (unity3d-store), thus you can reward players for performing social interactions with virtual rewards (VirtualItemReward, etc). That said this integration is completely optional.

SOOMLA's Profile Module

Download

Pre baked unitypackage:

unity3d-profile v2.2.1

From sources:

  • Clone this repository recursively: git clone --recursive https://github.com/soomla/unity3d-profile.git
  • Run ./build_all from project directory
  • Take created binaries from build directory and use it!

Debugging

If you want to see full debug messages from android-profile and ios-profile you just need to check the box that says "Debug Messages" in the SOOMLA Settings. Unity debug messages will only be printed out if you build the project with Development Build checked.

Cloning

There are some necessary files in submodules linked with symbolic links. If you're cloning the project make sure you clone it with the --recursive flag.

$ git clone --recursive git@github.com:soomla/unity3d-profile.git

Getting Started

  1. Download and import soomla-unity3d-core.unitypackage and unity3d-profile.unitypackage. If you also want to use Store related rewards you'll need to go over the instructions of unity3d-store

  2. Drag the CoreEvents and ProfileEvents Prefabs from Assets/Soomla/Prefabs into your scene. You should see it listed in the "Hierarchy" panel. [This step MUST be done for unity3d-profile to work properly!]

  3. On the menu bar click "Window -> Soomla -> Edit Settings" and change the value for "Soomla Secret".

    • Soomla Secret - is an encryption secret you provide that will be used to secure your data. (If you used versions before v1.5.2 this secret MUST be the same as Custom Secret)
      Choose the secret wisely. You can't change them after you launch your game!
    • Social Platforms - select the social platform which you want to integrate with
  4. Initialize SoomlaProfile:

    SoomlaProfile.Initialize();

    Initialize SoomlaProfile ONLY ONCE when your application loads.

    Initialize SoomlaProfile in the Start() function of a "MonoBehaviour" and NOT in the Awake() function. SOOMLA has its own "MonoBehaviour" and it needs to be "Awakened" before you initialize.

    SoomlaProfile will initialize the social providers. Don't initialize them on your own (for example, don't call FB.Init() !).

  5. Call all the social functions you can from SoomlaProfile class. Otherwise, you won't be able to work with SOOMLA correctly. You can still call functions from the FB class but only those that are not provided by SoomlaProfile.

  6. Register event handlers in order to be notified about in-app purchasing related events. refer to the Event Handling section for more information.

And that's it ! You have social capabilities for your game.

What's next? Selecting Social Providers

unity3d-profile is structured to support multiple social networks, and currently supports Facebook, Twitter and Google+. Note that currently only Facebook is supported for work in Editor.

IMPORTANT: When upgrading this module it is important that you uncheck and then re-check your social networks, to make the new libraries copy over to your project

Facebook

  1. Go over the guidelines for downloading and importing the official Facebook SDK: https://developers.facebook.com/docs/unity/getting-started/canvas - You don't need to initialize FB. SoomlaProfile will initialize it for you.

    NOTE: for unity 4.6, use FB Unity SDK v6.1.

  2. Create an empty folder named Facebook under Assets/Plugins

  3. Move the folder Scripts from Assets/Facebook to Assets/Plugins/Facebook - SOOMLA works from the Plugins folder so it'll be available to UnityScript devs. So you'll have to move Facebook in there as well.

    When working under Unity version > 4.5.0 (targeting iOS) please follow these extra steps:

    1. Edit the file Assets/Facebook/Editor/iOS/fixup.projmods
    1. Under headerpaths change Facebook/Scripts to Plugins/Facebook/Scripts

Twitter

Twitter is supported out-of-the-box, authentication is done either through the signed in Twitter account (iOS 5+) or through web browser (fallback). Follow the next steps to make it work:

  1. Create your Twitter app at https://apps.twitter.com/

  2. On the menu bar click "Window -> Soomla -> Edit Settings" and toggle the "twitter" check box. Then fill in "Consumer Key" and "Consumer Secret".

    Consumer Key and Consumer Secret are located under "Keys and Access Tokens" of your twitter app.

Google Plus

Targeting iOS:
  1. Follow Step 1. Creating the Google Developers Console project and create a Google+ app for iOS.
> Set the BUNDLE ID of your Google+ app to the Bundle Identifier of your Unity3d app.
  1. On the menu bar click "Window -> Soomla -> Edit Settings", toggle "google" check box and fill the "Client Id" text box with "CLIENT ID" value of your Google+ app.
Targeting Android:
  1. Follow Step 1: Enable the Google+ API and create a Google+ app for Android.

Set the PACKAGE NAME of your Google+ app to the value of "Bundle Identifier" of your Unity3d app.

To create a custom keystore file with Unity3d, navigate to "Player Settings" -> "Publishing Settings" and click "Create New Keystore". In your Google+ app page, navigate to "API & Auth " -> "Credentials" and update the value of "CERTIFICATE FINGERPRINT (SHA1)" with the SHA-1 of your new keystore file.

  1. Navigate to "Window -> Soomla -> Edit Settings" and toggle "google" check box (ignore the Client Id text box).

  2. Navigate to "Publishing Settings" and browse for your keystore file (debug.keystore/custom keystore).

What's next? Social Actions.

The Profile module is young and only a few social actions are provided. We're always working on extending the social capabilities and hope the community will "jump" on the chance to create them and even connect them with SOOMLA's modules (Store and LevelUp).

Here is an example of sharing a story on the user's feed:

After you initialized SoomlaProfile and logged the user in:

  SoomlaProfile.UpdateStory(
                  Provider.FACEBOOK,
                  "Check out this great story by SOOMLA !",  
                  "SOOMLA is 2 years young!",
                  "SOOMLA is GROWing",
                  "soomla_2_years",
                  "http://blog.soom.la/2014/08/congratulations-soomla-is-2-years-young.html",
                  "http://blog.soom.la/wp-content/uploads/2014/07/Birthday-bot-300x300.png",
                  new BadgeReward("sherriff", "Sheriff"));

And that's it! unity3d-profile knows how to contact Facebook and share a story with the information you provided.
It will also give the user the BadgeReward we configured in the function call.

Storage

unity3d-profile is caching user information on the device. You can access it through:

UserProfile userProfile = SoomlaProfile.GetStoredUserProfile(Provider.FACEBOOK);

The on-device storage is encrypted and kept in a SQLite database. SOOMLA is preparing a cloud-based storage service that will allow this SQLite to be synced to a cloud-based repository that you'll define.

Event Handling

SOOMLA lets you subscribe to profile events, get notified and implement your own application specific behavior to those events.

Your behavior is an addition to the default behavior implemented by SOOMLA. You don't replace SOOMLA's behavior.

The ProfileEvents class is where all event go through. To handle various events, just add your specific behavior to the delegates in the Events class.

For example, if you want to 'listen' to a LoginFinished event:

ProfileEvents.OnLoginFinished += (UserProfile UserProfile) => {
			Soomla.SoomlaUtils.LogDebug("My Perfect Game", "login finished with profile: " + UserProfile.toJSONObject().print());
			SoomlaProfile.GetContacts(Provider.FACEBOOK);
};

Facebook Caveats

  1. See iOS Facebook Caveats
  2. See Android Facebook Caveats

Twitter Caveats

  1. Have you enabled twitter in "Widow -> Soomla -> Edit Settings" and supplied the correct Consumer Key and Secret?

Google Plus Caveats

  1. Have you enabled google in "Window -> Soomla -> Edit Settings"?
  2. Have you supplied the correct Client Id (when targeting iOS)?
  3. Did you sign your Unity3d app with keystore file with SHA-1 identical to "CERTIFICATE FINGERPRINT (SHA1)" of your Google+ app?

Contribution

SOOMLA appreciates code contributions! You are more than welcome to extend the capabilities of SOOMLA.

Fork -> Clone -> Implement -> Add documentation -> Test -> Pull-Request.

IMPORTANT: If you would like to contribute, please follow our Documentation Guidelines. Clear, consistent comments will make our code easy to understand.

SOOMLA, Elsewhere ...

License

Apache License. Copyright (c) 2012-2014 SOOMLA. http://www.soom.la