diff --git a/plugin/src/withAirship.ts b/plugin/src/withAirship.ts index 390b530..a062b86 100644 --- a/plugin/src/withAirship.ts +++ b/plugin/src/withAirship.ts @@ -31,6 +31,10 @@ export type AirshipIOSPluginProps = { * The local path to a Notification Service Extension Info.plist. */ notificationServiceInfo?: string; + /** + * Optional. Defaults to NotificationServiceExtension if not provided. + */ + notificationServiceTargetName?: string; /** * Optional. The Apple Development Team ID used to configure the Notification Service Extension target. */ diff --git a/plugin/src/withAirshipIOS.ts b/plugin/src/withAirshipIOS.ts index 2806ab8..907bf3f 100644 --- a/plugin/src/withAirshipIOS.ts +++ b/plugin/src/withAirshipIOS.ts @@ -16,7 +16,7 @@ import { ExpoConfig } from '@expo/config-types'; import { AirshipIOSPluginProps } from './withAirship'; import { mergeContents, MergeResults } from '@expo/config-plugins/build/utils/generateCode'; -const NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME = "AirshipNotificationServiceExtension"; +const DEFAULT_NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME = "NotificationServiceExtension"; const NOTIFICATION_SERVICE_FILE_NAME = "AirshipNotificationService.swift"; const NOTIFICATION_SERVICE_INFO_PLIST_FILE_NAME = "AirshipNotificationServiceExtension-Info.plist"; @@ -57,8 +57,8 @@ async function writeNotificationServiceFilesAsync(props: AirshipIOSPluginProps, const pluginDir = require.resolve("airship-expo-plugin/package.json"); const sourceDir = join(pluginDir, "../plugin/NotificationServiceExtension/"); - - const extensionPath = join(projectRoot, "ios", NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME); + const targetName = props.notificationServiceTargetName ?? DEFAULT_NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME + const extensionPath = join(projectRoot, "ios", targetName); if (!existsSync(extensionPath)) { mkdirSync(extensionPath, { recursive: true }); @@ -94,19 +94,20 @@ async function writeNotificationServiceFilesAsync(props: AirshipIOSPluginProps, }; const withExtensionTargetInXcodeProject: ConfigPlugin = (config, props) => { + const targetName = props.notificationServiceTargetName ?? DEFAULT_NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME + return withXcodeProject(config, newConfig => { const xcodeProject = newConfig.modResults; - - if (!!xcodeProject.pbxTargetByName(NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME)) { - console.log(NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME + " already exists in project. Skipping..."); + if (!!xcodeProject.pbxTargetByName(targetName)) { + console.log(targetName + " already exists in project. Skipping..."); return newConfig; } // Create new PBXGroup for the extension const extGroup = xcodeProject.addPbxGroup( [NOTIFICATION_SERVICE_FILE_NAME, NOTIFICATION_SERVICE_INFO_PLIST_FILE_NAME], - NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME, - NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME + targetName, + targetName ); // Add the new PBXGroup to the top level group. This makes the @@ -129,10 +130,10 @@ const withExtensionTargetInXcodeProject: ConfigPlugin = ( // Add the Notification Service Extension Target // This adds PBXTargetDependency and PBXContainerItemProxy const notificationServiceExtensionTarget = xcodeProject.addTarget( - NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME, + targetName, "app_extension", - NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME, - `${config.ios?.bundleIdentifier}.${NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME}` + targetName, + `${config.ios?.bundleIdentifier}.${targetName}` ); // Add build phases to the new Target @@ -159,7 +160,7 @@ const withExtensionTargetInXcodeProject: ConfigPlugin = ( const configurations = xcodeProject.pbxXCBuildConfigurationSection(); for (const key in configurations) { if (typeof configurations[key].buildSettings !== "undefined" - && configurations[key].buildSettings.PRODUCT_NAME == `"${NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME}"` + && configurations[key].buildSettings.PRODUCT_NAME == `"${targetName}"` ) { const buildSettingsObj = configurations[key].buildSettings; buildSettingsObj.IPHONEOS_DEPLOYMENT_TARGET = "14.0"; @@ -177,9 +178,11 @@ const withExtensionTargetInXcodeProject: ConfigPlugin = ( }; const withAirshipServiceExtensionPod: ConfigPlugin = (config, props) => { + const targetName = props.notificationServiceTargetName ?? DEFAULT_NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME + return withPodfile(config, async (config) => { const airshipServiceExtensionPodfileSnippet = ` - target '${NOTIFICATION_SERVICE_EXTENSION_TARGET_NAME}' do + target '${targetName}' do use_frameworks! :linkage => podfile_properties['ios.useFrameworks'].to_sym if podfile_properties['ios.useFrameworks'] use_frameworks! :linkage => ENV['USE_FRAMEWORKS'].to_sym if ENV['USE_FRAMEWORKS'] pod 'AirshipServiceExtension'