Skip to main content

Android Client ID Swapping

The Feed.fm SDK generates and stores a single random token (called the 'client ID') on the local device that is used to track a user's playback history and enforce playback restrictions. This works well when a single user plays music on a single device, but has some drawbacks when multiple users use the same device. The latest iteration of the Feed.fm Android SDK has new methods to support multiple users on the same device. These new methods also support transferring a client ID between devices so a user's playback history and feedback can follow them wherever they log in.

The Client ID

The Feed.fm client ID is a simple ASCII string up to 32 characters long that is provided to an application the first time it contacts the Feed.fm servers via the Feed.fm SDK, and looks like this:

   fmcidv1:jmgmpzwr:1z6:i5o8vn8pvj

The value is stored in SharedPreferences on Android devices and in a UserDefaults iOS devices.

The current client ID may be be retrieved on Android devices via FeedAudioPlayer.clientId. Note that this value will be null until the first time the player successfully contacts the Feed.fm servers and transitions out of the UNINITIALIZED state..

Creating and Switching Between IDs

If your application can switch between users, then it should request a new client ID for each user beyond the first, it should persist those client IDs, and it should tell the Feed.fm SDK when to switch to a different client ID. There are multiple ways to create new client id's and to switch between them, depending on whether you use a singleton FeedAudioPlayer that is shared between all users or whether you create a new FeedAudioPlayer when changing users.

Switching Client IDs with Existing FeedAudioPlayer

If your application is creating and using a singleton FeedAudioPlayer (whether via the FeedPlayerService or not), then the way to generate new client IDs and switch between them are to use the FeedAudioPlayer.clientId, FeedAudioPlayer.setClientId() and FeedAudioPlayer.createNewClientId() methods.

FeedAudioPlayer.clientId returns the player's current ID, suitable for persisting. This value is guaranteed to not be null once the player has left the UNINITIALIZED state. This value can be persisted or transferred to another device.

FeedAudioPlayer.setClientId() stores a previously retrieved client ID (from FeedAudioPlayer.clientId on the device as the current and default client ID. This call stops any music playback and flushes all playback buffers. This call should be made when switching between users, after the player has transitioned out of the UNINITIALIZED state. Playback via the new client ID

FeedAudioPlayer.createNewClientId() asks the Feed.fm servers for a new client ID, then stores that on the device as the current client ID by calling FeedAudioPLayer.setClientId(), then returns the value to the caller via the provided listener. This method should be called when the application is switching to a new user that doesn't have a client ID associated with their account already. The client ID returned to the listener should be persisted with the new user.

Switching Client IDs with New FeedAudioPlayer

If your application creates a new FeedAudioPlayer when starting a music session and then destroys it when ending a sesssion, you can use the FeedAudioPlayer.Builder.setCreateNewClientId() and FeedAudioPlayer.Builder.setClientId() methods when creating a new FeedAudioPlayer to support multiple client ids.

If you are creating a new player for a user that doesn't have a persisted client ID yet, then call the FeedAudioPlayer.Builder.setCreateNewClientId() method while constructing your FeedAudioPlayer with a Builder, like so:

  FeedAudioPlayer player = new FeedAudioPlayer.Builder()
.setToken("demo")
.setSecret("demo")
.setContext(getContext())
.setCreateNewClientId(true) // <-- new client!
.setAvailabilityListener(new FeedAudioPlayer.availabilityListener() {
public void onPlayerAvailable(FeedAudioPlayer player) {
// here is your new client id
String clientId = player.getClientId();

// persist that ID somewhere
}
public void onPlayerUnavailable(Exception e) {
// no client id for this person
}
})
.build();

The example above will construct a new player that will immediately request a new client ID from the Feed.fm servers. The new client ID will be persisted to the local device and set as the default client ID for future players that don't request a new client ID or provide a client ID. The value can be retrieved via the FeedAudioPlayer.clientId method, and it should be stored

If your app has a previously generated client ID, then it can be provided to the player while constructing it, like so:

  FeedAudioPlayer player = new FeedAudioPlayer.Builder()
.setToken("demo")
.setSecret("demo")
.setContext(getContext())
.setClientId(previouslySaveClientId) // <-- saved client id
.setAvailabilityListener(new FeedAudioPlayer.availabilityListener() {
public void onPlayerAvailable(FeedAudioPlayer player) {
// player.getClientId() should match previouslySavedClientId
}
public void onPlayerUnavailable(Exception e) {
// no client id for this person
}
})
.build();