BrainCloudCpp 5.4.1

BrainCloudCpp 5.4.1

TestsTested
LangLanguage C++C++
License Apache-2.0
ReleasedLast Release Oct 2024

Maintained by Paul Winterhalder, brainCloud Client Team.



 
Depends on:
SSKeychain>= 0
BrainCloudJsonCpp~> 1.2.1
SocketRocket~> 0.5
 

  • By
  • brainCloud Team

brainCloud C++ Library

Thanks for downloading the brainCloud C++ client library! Here are a few notes to get you started. Further information about the brainCloud API, including example Tutorials can be found here:

http://getbraincloud.com/apidocs/

If you haven't signed up or you want to log into the brainCloud portal, you can do that here:

https://portal.braincloudservers.com/

Build in Visual Studio

Prerequisis:

  • git or downloaded zip archive of brainCloud
  • Visual Studio 17 2022. But everything after 2013 should work.
  • CMake https://cmake.org/

Steps (Command lines are done in PowerShell):

  1. Clone the repository somewhere on your PC, then cd to it.

    git clone https://github.com/getbraincloud/braincloud-cpp.git
    cd braincloud-cpp
  2. Update submodules so thirdparty libraries are present when building.

    git submodule update --init --recursive
  3. Create an out of source build folder, then cd to it.

    mkdir build
    cd build
  4. Generate the solution using cmake.

    cmake ..

    You may specify a Visual Studio version with the generator command:

    cmake -G"Visual Studio 16 2019" ..
    cmake -G"Visual Studio 17 2022" ..

    Or if you are building for UWP, do the following instead:

     cmake -DCMAKE_SYSTEM_NAME=WindowsStore -DCMAKE_SYSTEM_VERSION="10.0" -DCMAKE_GENERATOR_PLATFORM=x64 -DBUILD_TESTS=ON ..
  5. From file explorer, "explorer .", open brainCloud.sln in Visual Studio and build the brainCloud project with desired configuration. Release/Debug/static or shared libraries, etc..

  6. You may build brainCloud.lib at the shell commandline:

    cmake ..
    cmake --build . --target brainCloud

Build for Linux or Mac

Prerequisis:

  • git or downloaded zip archive of brainCloud
  • A C++ compiler
  • Ninja optional for faster build
  • CMake https://cmake.org/
  • libcurl-dev with openssl
  • pthread

Steps (Command lines are done in PowerShell):

  1. Clone the repository somewhere on your PC, then cd to it.
    git clone https://github.com/getbraincloud/braincloud-cpp.git
    cd braincloud-cpp
  2. Update submodules so thirdparty libraries are present when building.
    git submodule update --init --recursive
  3. Create an out of source build folder, then cd to it.
    mkdir build
    cd build
  4. Generate the solution using cmake, and specify if you want Debug or Release.
    cmake -DCMAKE_BUILD_TYPE=Release ..
    Or if you are generating for XCode, do the following:
    cmake -DCMAKE_GENERATOR=Xcode ..
  5. Build brainCloud
    make

Or,

cmake --build . --config Release

Other IDE/Build System Support

Use cmake --help to see available generators. Then, use command eg.:

cmake -G"CodeBlocks" ..
cmake -G Ninja ..

CLion

  1. Open the folder braincloud-cpp in CLion.
  2. Set CMake options in Clion > Settings... For Windows, set
-DSSL_ALLOW_SELFSIGNED=ON -DCMAKE_GENERATOR_PLATFORM=x64
  1. Select Build > Build 'brainCloud' Or, add brainCloud directly to your cmake project (see below).

Build for Android

Do the following step by adding brainCloud directly to your NDK Application's CMake project.

Add brainCloud to your application's cmake project.

Find the directory where the CMakeLists.txt resides. For example, if this is an Android project do these steps inside your YourAppDir/app/src/main/cpp/.

  1. Clone the repository to your submodules, in ./thirdparty/ path for example.

    mkdir thirdparty
    cd thirdparty
    git submodule add https://github.com/getbraincloud/braincloud-cpp.git
  2. Update submodules so required libraries are present when building.

    cd braincloud-cpp
    git submodule update --init --recursive
  3. Add the subirectory to your CMakeLists.txt, example:

    add_subdirectory(./thirdparty/braincloud-cpp)
    target_link_libraries(${PROJECT_NAME} brainCloud) # Note the capital 'C'

    Or:

     add_subdirectory(/path/to/braincloud-cpp ./builddir/braincloud-cpp)
     list(APPEND includes PUBLIC /path/to/braincloud-cpp/include/)
     list(APPEND includes PUBLIC /path/to/braincloud-cpp/libs/jsoncpp-1.0.0)
     list(APPEND libs brainCloud)
     target_include_directories(${PROJECT_NAME} ${includes})
     target_link_libraries(${PROJECT_NAME} ${libs})
  4. For Android apps only, don't forget to add INTERNET permission to your AndroidManifest.xml or else brainCloud won't work.

    <uses-permission android:name="android.permission.INTERNET" />

Cocoapod Installation

The library is distributed through CocoaPods. In order to install the library, simply add the following to your Podfile.

pod 'BrainCloudCpp'

Or,

pod 'BrainCloudCpp', '4.xx.y'

If you're a newcomer to the CocoaPods world, you can find documentation on how to set up your Xcode project here:

https://guides.cocoapods.org/

After adding to your Podfile, run the command:

pod update

Troubleshooting

Here are a few common errors that you may see on your first attempt to connect to brainCloud.

  • App id not set: Verify you've set up the app id and app secret correctly in the initialize() method.
  • Platform not enabled: Verify you've enabled your platform on the portal.

If you're still having issues, log into the portal and give us a shout through the help system (bottom right icon with the question mark and chat bubble).

brainCloud Summary

brainCloud is a ready-made back-end platform for the development of feature-rich games, apps and things. brainCloud provides the features you need – along with comprehensive tools to support your team during development, testing and user support.

brainCloud consists of:

  • Cloud Service – an advanced, Software-as-a-Service (SaaS) back-end
  • Client Libraries – local client libraries (SDKs)
  • Design Portal – a portal that allows you to design and debug your apps
  • brainCloud Architecture

architecture

What's the difference between the brainCloud Wrapper and the brainCloud Client?

The wrapper contains quality of life improvement around the brainCloud Client. It may contain device specific code, such as serializing the user's login id on an Android or iOS device. It is recommended to use the wrapper by default.

wrapper

How do I initialize brainCloud?

If using the wrapper use the following code.

_bc = new BrainCloudWrapper(); // optionally pass in a _wrapperName
_bc->initialize("https://api.braincloudservers.com/dispatcherv2", _appId, _secret, _appVersion, _companyName, _appName);

Your _appId, _secret, is set on the brainCloud dashboard. Under Design | Core App Info > Application IDs

wrapper

_wrapperName prefixes saved operations that the wrapper will make. Use a _wrapperName if you plan on having multiple instances of brainCloud running.


Newly upgraded?

If your app is already live, you should NOT specify the _wrapperName - otherwise the library will look in the wrong location for your user's stored anonymousID and profileID information. Only add a name if you intend to alter the save data.


_companyName and _appName are also used in determining the fileName. ex. bitHeads.exampleApp, or mainWrapper.bitHeads.exampleApp

_appVersion is the current version of our app. Having an _appVersion less than your minimum app version on brainCloud will prevent the user from accessing the service until they update their app to the lastest version you have provided them.

wrapper

How do I keep the brainCloud SDK updating?

In your project's update loop, you're going to want to update brainCloud client so it can check for responses.

To do this, you need to call runCallbacks();

_bc->runCallbacks();

How do I authenticate a user with brainCloud?

The simplest form of authenticating with brainCloud Wrapper is an Anonymous Authentication.

_bc->authenticateAnonymous(_callback);

This method will create an account, and continue to use a locally saved anonymous id.

Your _callback will inherit from IServerCallback and contain the functions needed to react to the brainCloud Server response.

To login with a specfic anonymous id, use the brainCloud client.

_bc->getBCClient()->getAuthenticationService()->setAnonymousId(_anonymousId); // re-use an Anon id
_bc->getBCClient()->getAuthenticationService()->setAnonymousId(_bc->getBCClient()->getAuthenticationService()->generateAnonymousId().c_str()); // or use brainCloud to generate one
_bc->getBCClient()->getAuthenticationService()->authenticateAnonymous(_forceCreate, _callback);

Setting _forceCreate to false will ensure the user will only login to an existing account. Setting it to true, will allow the user to register a new account

How do I attach an email to a user's brainCloud profile?

After having the user create an anonymous with brainCloud, they are probably going to want to attach an email or username, so their account can be accessed via another platform, or when their local data is discarded. Attaching email authenticate would look like this.

_bc->getBCClient()->getIdentityService()->attachEmailIdentity(_email, _password, _callback);

There are many authentication types. You can also merge profiles and detach idenities. See the brainCloud documentation for more information: http://getbraincloud.com/apidocs/apiref/?java#capi-auth

Building and Running Tests

Refer to Jenkinsfile for platform builds and unit test pipeline. See also tests/README.md.

To run unit tests locally, you can use the autobuild script runtests.sh or runtest.bat. The process is:

  1. Run cmake with BUILD_TESTS set to ON in debug configuration.
  2. Run cmake to build target bctests in debug configuration.
  3. Create/copy file ids.txt to the folder where tests will run. Input your server url, app ids and secret keys.
  4. Execute with desired test filter.

Attributions

The brainCloud C++ windows library uses libwebsockets v3.0.1. Linux and Mac uses libwebsockets v4.3-stable. Also depends on MBedTLS v2.8. And redistributes public domain library JsonCpp.

Cocoapod Depenencies

The brainCloud library ships with SSKeychain and requires SocketRocket and JsonCpp cocoapods.

Important Submodule Note

These are included as submodules so can be retrieved using

git submodule update --init --recursive

However should not be updated or pulled to another version since the initialized version is known to build and run stable.

JsonCpp has recently been made a submodule (as of brainCloud 4.15) so if pulling or changing branches the existing folder lib/jsoncpp-1.0.0/ should be deleted or there will be git errors.