JavaScript SDK Core
This module handles the SDK initialization and registration. This module has the following classes:
imi.imiconnect
This class contains the methods to initialize the SDK and register a user. When integrating the SDK into your app it is mandatory to use this class to initialize the SDK before any other features are used. With the exception of the Authentication module, it is also necessary to register a user before other features are used.
Public Methods | |
---|---|
void | startup(config) |
void | shutdown() |
void | register(deviceProfile, regcallback) |
void | unregister() |
boolean | isRegistered() |
void | updateProfileData() |
boolean | removeProfileData() |
void | setSecurityToken |
void | registerListener |
void | unregisterListener |
startup
This method is used to initialize the SDK using the provided configuration options.
Syntax: void startup(config)
Parameters:
Parameter | Type | Description |
---|---|---|
config | ICConfig | Refer to ICConfig class. |
Click here to view ICConfig class.
Example:
try {
//Initialize an ICConfig instance with an appId, clientKey
var config = new imi.ICConfig(appId, clientKey);
// Initialize the imiconnect SDK with ICConfig instance
imi.imiconnect.startup(config);
}
catch (e) {
console.log(e)
}
shutdown
This method is used to clean up the SDK, freeing all internal object instances. Invoking this method will stop the SDK features from functioning as such RTM will no longer be received.
Syntax: void shutdown()
Example:
// Provides a means to shutdown the SDK and perform cleanup, after this method is called none of the SDK features will work
try {
imi.imiconnect.shutdown();
} catch (error) {
console.log(error)
}
register
This method is used to register the userId with imiconnect. This method reads the device details and sent to the imiconnect platform. Once a user is registered all further SDK calls take place in the context of that user.
Syntax: register(deviceProfile, regcallback)
Parameters:
Parameter | Type | Description |
---|---|---|
deviceProfile | [ICDeviceProfile] | Specifies the device profile registered with imiconnect. |
regcallback | Object | Refer to example below. |
Example:
//Verify whether the user is registered or not, if not registered, register the user.
if (!imi.imiconnect.isRegistered()) {
var callback = {
onSuccess: function() {
console.log("reg success");
//Write you code to connect to imiconnect.
},
onFailure: function(errormsg) {
console.log("reg failed");
}
};
var deviceProfile=new imi.ICDeviceProfile(deviceId, userId);
//here user id is optional (If user id not there user can call deviceID,
userId will be generated by imiConnect and passed to callback function)
//var deviceProfile = new imi.ICDeviceProfile(deviceId);
imi.imiconnect.register(deviceProfile, callback);
}
else{
//Write you code to connect to imiconnect.
}
unregister
This method is used to unregister the current user. The features that rely on a registered user will no longer function after this method has been called.
Syntax: imi.imiconnect.unregister(unregisterCallback);
Parameter | Type |
---|---|
unregisterCallback | Callback |
Example:
var unregisterCallback = {
onSuccess: function (msg) {
console.log("de register...");
},
onFailure: function (err) {
console.log("failed to un register");
}
};
imi.imiconnect.unregister(unregisterCallback );
isRegistered
This method is used to check whether the user is currently registered with imiconnect.
Syntax: boolean isRegistered()
Returns:
Returns true if the user is registered, else false is returned.
Example:
var isRegistered = imi.imiconnect.isRegistered();
updateProfileData
This method is used to update userID and customerID parameters of current device profile registered with imiconnect.
To update UserID
Syntax: imi.imiconnect.updateProfileData(imi.ICDeviceProfileParam.UserId, newuserid, userIdcallbck);
Parameters:
Parameter | Type | Description |
---|---|---|
DeviceProfileParam | imi.ICDeviceProfileParam.UserId | Specifies the user ID to register with imiconnect. |
newUserId | String | Specifies the new user ID to register with imiconnect. |
userIdcallback | Object | Refer to example below. |
To update CustomerID
Syntax: imi.imiconnect.updateProfileData(imi.ICDeviceProfileParam.CustomerId, newcustomerid, customerCallback);
Parameters:
Parameter | Type | Description |
---|---|---|
DeviceProfileParam | imi.ICDeviceProfileParam.CustomerId | Specifies the customer ID to register with imiconnect. |
newcustomerId | String | Specifies the new customer ID to register with imiconnect. |
customerCallback | Object | Refer to example below. |
Example:
var userIdcallbck = {
onSuccess: function (msg) {
console.log("usermodified...");
},
onFailure: function (err) {
console.log("failed to add user");
}
};
imi.imiconnect.updateProfileData(imi.ICDeviceProfileParam.UserId, "2130", userIdcallbck);
var customerCallback = {
onSuccess: function (msg) {
console.log("customer...");
$("#setCustomerModel").modal('hide');
},
onFailure: function (err) {
console.log("failed to add customer");
alert(err)
}
};
imi.imiconnect.updateProfileData(imi.ICDeviceProfileParam.CustomerId, "2130", customerCallback);
removeProfileData
This method is used to remove the profile data (user ID or customer ID).
To Remove UserID
This method is used to remove the userID.
Syntax: imi.imiconnect.removeProfileData(imi.ICDeviceProfileParam.UserId, removeUserCallback);
Parameters:
Parameter | Type | Description |
---|---|---|
DeviceProfileParam | imi.ICDeviceProfileParam.UserId | Specifies the user ID to register with imiconnect. |
removeUserCallback | Object | Refer to example below. |
8*To Remove customerID
This method is used to remove the userID.
Syntax:** imi.imiconnect.removeProfileData(imi.ICDeviceProfileParam.CustomerId, CustomerIdcallbck);
Returns:
Returns customerId.
Parameters:
Parameter | Type | Description |
---|---|---|
DeviceProfileParam | imi.ICDeviceProfileParam.CustomerId | Specifies the customer ID to register with imiconnect. |
customerIdcallback | Callback | Refer to example below. |
Example:
var removeUserCallback = {
onSuccess: function (resrmsg) {
console.log("remove userId...");
},
onFailure: function (err) {
console.log("failed to remove customerid..");
}
};
imi.imiconnect.removeProfileData(imi.ICDeviceProfileParam.UserId, userIdcallbck);
var CustomerIdcallbck = {
onSuccess: function (msg) {
console.log("usermodified...");
},
onFailure: function (err) {
console.log("failed to add user");
}
};
imi.imiconnect.removeProfileData(imi.ICDeviceProfileParam.CustomerId, customerCallback);
setSecurityToken
This method allows to specify the security token that the SDK will pass to the Connect platform.
Syntax: void setSecurityToken(token)
//generate token and call the below method using the token
imi.imiconnect.setSecurityToken(token);
registerListener
This method allows registering an object which implements the onFailure
method to listen for security token related exceptions which occur from internal (indirect) connect platform API calls.
Syntax: void registerListener(callbackListener)
Parameters:
Parameter | Description |
---|---|
callbackListener | Security Token Exception listener object. |
var callback= {
onFailure: function () {
console.log("token got expired...");
alert("token got expired...");
//need to generate token your (for more information, refer to docs) }
};
//this method should be called after startup()
imi.imiconnect.registerListener(callback);
unregisterListener
This method allows unregistering a previously registered object in order to stop listening for security token exceptions.
Syntax: void unregisterListener(callbackListener)
Parameters:
Parameter | Description |
---|---|
callbackListener | Security Token Exception listener object. |
var callbackListener={
onFailure:function(error){
//This method will be called when security token issues comes
}
}
imi.imiconnect.unregisterListener(callback);
imi.ICConfig
This class holds the configuration information that is used to initialize the SDK.
Public Constructors |
---|
ICConfig(appId, appSecret) |
Public Methods | |
---|---|
String | getAppID() |
String | getClientKey() |
ICConfig
This method is used to initialize an ICConfig
instance with an appId and clientKey.
Syntax: ICConfig(appId, appSecret)
Parameters:
Parameter | Type | Description |
---|---|---|
appId | String | Specifies the appId that is created in imiconnect. |
appSecret | String | Specifies the appSecret that is created in imiconnect. |
Example:
try {
//Initialize an ICConfig instance with an appId, clientKey
var config = new imi.ICConfig(appId, appSecret);
// Initialize the imiconnect SDK with ICConfig instance
imi.imiconnect.startup(config);
} catch ( e) {
console.log(e)
}
getAppId
This method is used to get the app id.
Syntax: String getAppId()
Return Value:
Returns the appid.
getClientKey
This method is used to get the client key.
Syntax: String getClientKey()
Return Value:
Returns the client key.
imi.ICDeviceProfile
An ICDeviceProfile instance should be instantiated to register a device profile.
The developer can choose to register the device profile with a deviceId
only or with a deviceId
and an appUserId
. Users' can generate their own device ID or can choose the default deviceId
provided by the SDK.
If the user chooses to register a device profile with the deviceId
only, then the backend will automatically generate an appUserId
.
The current device profile is accessible via the imiconnect class.
Public Methods | |
---|---|
String | getDefaultDeviceId() |
String | isAppUserSystemGenerated() |
String | getUserId() |
String | getDeviceId() |
ICDeviceProfile()
The current device profile, which is accessible via the imiconnect class.
Syntax: ICDeviceProfile(deviceId, userId)
Syntax: ICDeviceProfile(deviceId, userId, customerId, isSystemGenerated)
Parameters:
Parameter | Type | Description |
---|---|---|
deviceId | Property | Specifies the device ID that is created in imiconnect. |
userId | Property | Specifies the user ID that is created in imiconnect. |
customerId | Property | Specifies the customer ID that is created in imiconnect. |
isSystemGenerated | Property | Indicates if the device ID is system generated. |
getDefaultDeviceId()
This method is used to get the value of default deviceId.
var deviceId=imi.ICDeviceProfile.getDefaultDeviceId();
var deviceProfile =new imi.ICDeviceProfile(deviceId, userId);
var deviceProfile =new imi.ICDeviceProfile(deviceId, userId, customerId, isSystemGenerated);
isAppUserSystemGenerated()
This method is used to know whether the appuserId is generated by the end-system or the user.
Syntax: String isAppUserSystemGenerated()
Return Value:
Returns the appuserid.
Example:
var deviceProfile =new imi.ICDeviceProfile(deviceId, userId);
var isAppUserSystemGenerated=deviceProfile.isAppUserSystemGenerated(); if(isAppUserSystemGenerated)
{
console.log("system generated appuser");
}
getUserId()
This method is used to get the user ID.
Syntax: String getUserId()
Return Value:
Returns the userId.
getDeviceId()
This method is used to get the user ID.
Syntax: String getDeviceId()
Return Value:
Returns the deviceId.
imi.ICMediaFileManager
uploadFile
This method is used to check the status of the file upload.
Syntax: uploadFile(file, file.type, callback)
Return Value:
Returns the file upload status.
onFileUploadComplete: function
This method is used to execute the callback method after the file upload is complete.
Syntax: onFileUploadComplete: function(file, mediaId, error)
onFileUploadComplete: function(file, mediaId, error){
if(error){
console.log(error);
} else{
$("#mediaid").val(mediaId);
}
}
setMediaId
This method is used to set the media id in the attachment section.
function pubMessage(threadtitle, threadid, msg, mediaId, callback){
----------------
----------------
if(mediaId && mediaId !==""){
var mediaArr = [];
var icAttach = new imi.ICAttachment();
icAttach.setMediaId(mediaId);
mediaArray.push(icAttach);
message.setAttachment(mediaArray);
}
Updated 9 months ago