Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Phone number & SMS Subscription APIs #40

Merged
merged 5 commits into from
Nov 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,16 @@ Batch Cordova Plugin

## UPCOMING

**Plugin**
* Updated Batch to 2.1
* Batch requires to compile with SDK 35 (Android 15) (cordova-android@14).

**iOS**
* `BatchBridgeNotificationCenterDelegate` now defaults to showing foreground notifications.

**Profile**
- Added `setPhoneNumber` API to the `BatchProfileAttributeEditor` class. This requires to have a user identifier registered or to call the `identify` method beforehand.
- Added `setSMSMarketingSubscription` API to the `BatchProfileAttributeEditor` class.

## 6.0.0

Expand Down
4 changes: 2 additions & 2 deletions dist/plugin.xml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

<platform name="android">

<preference name="BATCHSDK_ANDROID_VERSION" default="2.0.+"/>
<preference name="BATCHSDK_ANDROID_VERSION" default="2.1.+"/>

<!-- This should be 1.0.0 forever, we leave it configurable just in case another version needs to be used in an app -->
<preference name="BATCHSDK_ANDROID_LOCALBROADCAST_VERSION" default="1.0.0"/>
Expand Down Expand Up @@ -79,7 +79,7 @@

<platform name="ios">

<preference name="BATCHSDK_IOS_VERSION" default="~> 2.0"/>
<preference name="BATCHSDK_IOS_VERSION" default="~> 2.1"/>

<config-file target="config.xml" parent="/*">
<feature name="Batch">
Expand Down
26 changes: 26 additions & 0 deletions dist/src/android/interop/Bridge.java
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
import com.batch.android.Batch;
import com.batch.android.BatchAttributesFetchListener;
import com.batch.android.BatchEmailSubscriptionState;
import com.batch.android.BatchSMSSubscriptionState;
import com.batch.android.BatchEventAttributes;
import com.batch.android.BatchMessage;
import com.batch.android.BatchMigration;
Expand Down Expand Up @@ -410,6 +411,31 @@ private static void editProfileAttributes(Map<String, Object> parameters) throws
Log.e(TAG, "Invalid SET_EMAIL_MARKETING_SUBSCRIPTION value: it can only be `subscribed` or `unsubscribed`.");
}
}
case "SET_PHONE_NUMBER" -> {
Object value = operationDescription.get("value");
if (value != null && !(value instanceof String)) {
Log.e(TAG, "Invalid SET_PHONE_NUMBER value: it can only be a string or null");
// Invalid value, continue. NULL is allowed though
continue;
}
editor.setPhoneNumber((String) value);
}
case "SET_SMS_MARKETING_SUB" -> {
Object value = operationDescription.get("value");
if (value == null || !(value instanceof String)) {
Log.e(TAG, "Invalid SET_SMS_MARKETING_SUB value: it can only be a string");
// Invalid value, continue.
continue;
}

if ("subscribed".equals(value)) {
editor.setSMSMarketingSubscription(BatchSMSSubscriptionState.SUBSCRIBED);
} else if ("unsubscribed".equals(value)) {
editor.setSMSMarketingSubscription(BatchSMSSubscriptionState.UNSUBSCRIBED);
} else {
Log.e(TAG, "Invalid SET_SMS_MARKETING_SUB value: it can only be `subscribed` or `unsubscribed`.");
}
}
case "SET_ATTRIBUTE" -> {
String key = getTypedParameter(operationDescription, "key", String.class);
String type = getTypedParameter(operationDescription, "type", String.class);
Expand Down
14 changes: 14 additions & 0 deletions dist/src/ios/interop/BatchProfileBridge.m
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,20 @@ + (void)editAttributes:(NSDictionary*)params
NSLog(@"Batch Bridge - Invalid value for email marketing subscription state. Must be `subscribed` or `unsubscribed`.");
}
}
else if([@"SET_PHONE_NUMBER" isEqualToString:operationName])
{
[editor setPhoneNumber:[BatchBridgeUtils nullableString:operationDescription forKey:@"value"] error:nil];
}
else if([@"SET_SMS_MARKETING_SUB" isEqualToString:operationName]) {
NSString* value = [operationDescription objectForKey:@"value"];
if([[value uppercaseString] isEqualToString:@"SUBSCRIBED"]) {
[editor setSMSMarketingSubscriptionState:BatchSMSSubscriptionStateSubscribed];
} else if ([[value uppercaseString] isEqualToString:@"UNSUBSCRIBED"]) {
[editor setSMSMarketingSubscriptionState: BatchSMSSubscriptionStateUnsubscribed];
} else {
NSLog(@"Batch Bridge - Invalid value for SMS marketing subscription state. Must be `subscribed` or `unsubscribed`.");
}
}
else if ([@"SET_ATTRIBUTE" isEqualToString:operationName])
{
NSString *type = operationDescription[@"type"];
Expand Down
2 changes: 2 additions & 0 deletions src/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,8 @@ export enum ProfileAttributeOperation {
SetRegion = "SET_REGION",
SetEmail = "SET_EMAIL_ADDRESS",
SetEmailMarketingSubscription = "SET_EMAIL_MARKETING_SUB",
SetPhoneNumber = "SET_PHONE_NUMBER",
SetSMSMarketingSubscription = "SET_SMS_MARKETING_SUB",
SetAttribute = "SET_ATTRIBUTE",
RemoveAttribute = "REMOVE_ATTRIBUTE",
AddToArray = "ADD_TO_ARRAY",
Expand Down
7 changes: 6 additions & 1 deletion src/batchStub.ts
Original file line number Diff line number Diff line change
Expand Up @@ -132,13 +132,18 @@ class BatchUserDataEditorStub implements BatchSDK.BatchProfileAttributeEditor {
public setRegion(_region: string | null) {
return this;
}

public setEmailAddress(_email: string | null) {
return this;
}
public setEmailMarketingSubscription(_state: "subscribed" | "unsubscribed") {
return this;
}
public setPhoneNumber(_phoneNumber: string | null) {
return this;
}
public setSMSMarketingSubscription(_state: "subscribed" | "unsubscribed") {
return this;
}
public setAttribute(
_key: string,
_value: string | number | boolean | Date | URL
Expand Down
36 changes: 36 additions & 0 deletions src/modules/profile/profileAttributeEditor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,42 @@ export class BatchProfileAttributeEditor
return this;
}

public setPhoneNumber(phoneNumber: string | null): this {
if (typeof phoneNumber !== "string" && phoneNumber !== null) {
writeBatchLog(
false,
"BatchProfileAttributeEditor - Phone number must be a string or null"
);
return this;
}
this._enqueueOperation(ProfileAttributeOperation.SetPhoneNumber, {
value: phoneNumber,
});
return this;
}

public setSMSMarketingSubscription(
state: "subscribed" | "unsubscribed"
): this {
if (
typeof state !== "string" ||
(state !== "subscribed" && state !== "unsubscribed")
) {
writeBatchLog(
false,
"BatchProfileAttributeEditor - SMS marketing subscription state must be `subscribed` or `unsubscribed`."
);
return this;
}
this._enqueueOperation(
ProfileAttributeOperation.SetSMSMarketingSubscription,
{
value: state,
}
);
return this;
}

public setAttribute(
key: string,
value: string | number | boolean | Date | URL | Array<string>
Expand Down
43 changes: 31 additions & 12 deletions types/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -146,9 +146,9 @@ export declare namespace BatchSDK {
* - Prevent batch.start()
* - Disable any network capability from the SDK
* - Disable all In-App campaigns
* - Make the Inbox module return an error immediatly when used
* - Make the Inbox module return an error immediately when used
* - Make the SDK reject any editor calls
* - Make the SDK reject calls to batch.user.trackEvent(), batch.user.trackTransaction(), batch.user.trackLocation() and any related methods
* - Make the SDK reject calls to batch.profile.trackEvent(), batch.profile.trackLocation() and any related methods
*
* Even if you opt in afterwards, data that has been generated while opted out WILL be lost.
*
Expand Down Expand Up @@ -282,8 +282,8 @@ export declare namespace BatchSDK {
identify(identifier: string | null): void;

/**
* Get the user data editor. Don't forget to call save when you're done.
* @return Batch user data editor
* Get the profile data editor. Don't forget to call save when you're done.
* @return Batch profile data editor
*/
getEditor(): BatchProfileAttributeEditor;

Expand Down Expand Up @@ -318,20 +318,20 @@ export declare namespace BatchSDK {
getInstallationID(): Promise<undefined | string>;

/**
* Get the application language override set using BatchUserDataEditor. Batch must be started to read it.
* Get the application language override set using BatchProfileAttributeEditor. Batch must be started to read it.
* The promise will return the language you have previously set, if any, or undefined. Might be null/undefined if Batch isn't started.
* Might throw if Batch isn't started.
*/
getLanguage(): Promise<undefined | string>;

/**
* Get the application region override set using BatchUserDataEditor. Batch must be started to read it.
* Get the application region override set using BatchProfileAttributeEditor. Batch must be started to read it.
* The promise will return the region you have previously set, if any, or undefined. Might be null/undefined if Batch isn't started.
*/
getRegion(): Promise<undefined | string>;

/**
* Get the user identifier set using BatchUserDataEditor. Batch must be started to read it.
* Get the user identifier set using BatchProfileAttributeEditor. Batch must be started to read it.
* The promise will return the user identifier you have previously set, if any, or undefined. Might be null/undefined if Batch isn't started.
*/
getIdentifier(): Promise<undefined | string>;
Expand Down Expand Up @@ -417,8 +417,8 @@ export declare namespace BatchSDK {
setiOSNotificationTypes(notifTypes: iOSNotificationTypes): void;

/**
* Set whether notifications should be show in the foreground on iOS.
* If true, notifications will be shown like if the user was outside of your application and
* Set whether notifications should be shown in the foreground on iOS.
* If true, notifications will be shown like if the user was outside your application and
* `batchPushReceived` will only be triggered when the notification is tapped.
* @param showForegroundNotifications Show foreground notifications?
*/
Expand Down Expand Up @@ -658,7 +658,7 @@ export declare namespace BatchSDK {
}

/**
* User data editor
* Profile attribute editor
*/
interface BatchProfileAttributeEditor {
/**
Expand All @@ -676,7 +676,7 @@ export declare namespace BatchSDK {
setRegion(region: string | null): BatchProfileAttributeEditor;

/**
* Set the user email address.
* Set the profile email address.
*
* This requires to have a custom user ID registered
* or to call the `setIdentifier` method on the editor instance beforehand.
Expand All @@ -685,14 +685,33 @@ export declare namespace BatchSDK {
setEmailAddress(email: string | null): BatchProfileAttributeEditor;

/**
* Set the user email marketing subscription state
* Set the profile email marketing subscription state
*
* @param state The state of the marketing email subscription. Must be "subscribed" or "unsubscribed".
*/
setEmailMarketingSubscription(
state: "subscribed" | "unsubscribed"
): BatchProfileAttributeEditor;

/**
* Set the profile phone number.
*
* This requires to have a custom profile ID registered or to call the `identify` method beforehand.
* @param phoneNumber A valid E.164 formatted string. Must start with a `+` and not be longer than 15 digits
* without special characters (eg: "+33123456789"). Null to reset.
*/
setPhoneNumber(phoneNumber: string | null): BatchProfileAttributeEditor;

/**
* Set the profile SMS marketing subscription state.
*
* Note that profile's subscription status is automatically set to unsubscribed when users send a STOP message.
* @param state The state of the SMS marketing subscription. Must be "subscribed" or "unsubscribed".
*/
setSMSMarketingSubscription(
state: "subscribed" | "unsubscribed"
): BatchProfileAttributeEditor;

/**
* Set an attribute for a key
* @param key Attribute key. Cannot be null, empty or undefined. It should be made of letters, numbers or underscores ([a-z0-9_]) and can't be longer than 30 characters.
Expand Down
Loading