iOS SDK Usage
Using Variable Values
To get values from your Features, the variableValue()
method is used to fetch variable values using
the variable's identifier key
coupled with a default value. The default value can be of type
String
, Boolean
, Number
, or JSONObject
:
Swift
let boolValue = devcycleClient.variableValue(key: "bool_key", defaultValue: false)
let strValue = devcycleClient.variableValue(key: "string_key", defaultValue: "default")
let numValue = devcycleClient.variableValue(key: "num_key", defaultValue: 4)
let jsonValue = devcycleClient.variableValue(key: "json_key", defaultValue: [:])
Objective-C
Bool boolValue = [self.devcycleClient boolVariableValueWithKey:@"bool_key" defaultValue:false];
NSString *strValue = [self.devcycleClient stringVariableValueWithKey:@"string_key" defaultValue:@"default"];
NSNumber *numValue = [self.devcycleClient numberVariableValueWithKey:@"num_key" defaultValue:@4];
NSObject *jsonValue = [self.devcycleClient jsonVariableValueWithKey:@"json_key" defaultValue:@{}];
If you would like to get the full Variable
object using the variable()
method it also contains the following params:
key
: the key identifier for the Variabletype
: the type of the Variable, one of:String
/Boolean
/Number
/JSON
value
: the Variable's valuedefaultValue
: the Variable's default valueisDefaulted
: if the Variable is using thedefaultValue
evalReason
: evaluation reason for why the variable was bucketed into its value
If the value is not ready, it will return the default value passed in the creation of the variable.
Variable Updates
Variable values update whenever identifyUser()
or resetUser()
are called, or when the
project configuration changes (to learn more, visit our Realtime Updates page).
To listen for variable updates, the onUpdate()
method can be used. Please note, a strong reference to the
variable is needed for onUpdate
to be triggered.
Swift
let boolVariable = devcycleClient.variable(key: "bool_key", defaultValue: false)
.onUpdate { value in
// Variable value updated
}
Objective-C
DVCVariable *boolVar = [[self.devcycleClient boolVariableWithKey:@"bool_key" defaultValue:true]
onUpdateWithHandler:^(id _Nonnull value) {
// Variable value updated
}];
Grabbing All Features / Variables
Get All Features
To get all the Features returned in the config:
Swift
let features: [String: Feature] = devcycleClient.allFeatures()
Objective C
NSDictionary *allFeatures = [self.devcycleClient allFeatures];
If the SDK has not finished initializing, these methods will return an empty object.
Get All Variables
To get all the variables returned in the config:
Swift
let variables: [String: Variable] = devcycleClient.allVariables()
Objective-C
NSDictionary *allVariables = [self.devcycleClient allVariables];
If the SDK has not finished initializing, these methods will return an empty object.
Identifying User
To identify a different user, or the same user passed into the initialize method with more attributes,
build a DevCycleUser object and pass it into identifyUser
:
Swift
do {
let user = try DevCycleUser.builder()
.userId("my-user1")
.email("my-email@email.com")
.country("CA")
.name("My Name")
.language("EN")
.customData([ "customkey": "customValue" ])
.privateCustomData([ "customkey2": "customValue2" ])
.build()
try devcycleClient.identifyUser(user: user)
} catch {
print("Error building new DevCycleUser: \(error)")
}
Objective-C
DevCycleUser *user = [DevCycleUser initializeWithUserId:@"my-user1"];
user.email = @"my-email@email.com";
user.appBuild = @1005;
user.appVersion = @"1.1.1";
user.country = @"CA";
user.name = @"My Name";
user.language = @"EN";
user.customData = @{@"customKey": @"customValue"};
user.privateCustomData = @{@"customkey2": @"customValue2"};
[self.devcycleClient identifyUser:user callback:^(NSError *error, NSDictionary<NSString *,id> *variables) {
if (error) {
return NSLog(@"Error calling DevCycleClient identifyUser:callback: %@", error);
}
}];
To wait on Variables that will be returned from the identify call, you can pass in a DevCycleCallback:
Swift
try devcycleClient.identifyUser(user: user) { error, variables in
if (error != nil) {
// error identifying user
} else {
// use variables
}
}
Objective-C
[self.devcycleClient identifyUser:user callback:^(NSError *error, NSDictionary<NSString *,id> *variables) {
if (error) {
// error identifying user
} else {
// use variables
}
}];
If error
exists the called the user's configuration will not be updated and previous user's data will persist.