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

[question]: Automated OneSignalServiceExtension needs adaption for version 3.3.2 or 5.0.x, help possible? #990

Closed
1 task done
anh1979 opened this issue Apr 30, 2024 · 5 comments

Comments

@anh1979
Copy link

anh1979 commented Apr 30, 2024

How can we help?

The brilliant script of @ludufre (see #537 (comment)) is broken, since we try to use a newer version of OneSignal.

The commandline xcode-build fails with fatal error: 'OneSignal/OneSignal.h' file not found, due to the fact that paths within the OneSignal SDK Framework have changed, I suppose.

Did anyone also encounter this and has a solution?

We are using the script for Jenkins automation of our app build process to add a OneSignalServiceExtension to each app and it worked perfectly since we found it.

We have to change the OneSignal Version for being able to generate Privacy Manifest Data.

Code of Conduct

  • I agree to follow this project's Code of Conduct
@anh1979
Copy link
Author

anh1979 commented May 2, 2024

I got it working, finally.

I opened the .xcworkspace manually in Xcode and added the missing framework dependency. Then I did a file comparison on the .pbxproj File inside .xcproject with an older one.

A lot of fiddling around, because at first the local build was successful, but delivering the .ipa failed with
Exception in lane process_build - Error uploading ipa file: [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90685) CFBundleIdentifier Collision. There is more than one bundle with the CFBundleIdentifier value 'com.onesignal.OneSignalCore' under the iOS application 'appdinx.app'. (ID: b51775a2-7e77-4875-ac55-f9651f1a9bfc) [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90685) CFBundleIdentifier Collision. There is more than one bundle with the CFBundleIdentifier value 'com.onesignal.OneSignalOutcomes' under the iOS application 'appdinx.app'. (ID: 7fee6c54-16c8-4480-80b9-fde06698a486) [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90685) CFBundleIdentifier Collision. There is more than one bundle with the CFBundleIdentifier value 'com.onesignal.OneSignal-Dynamic' under the iOS application 'appdinx.app'. (ID: dff5e9ba-8f58-4b53-af1e-90f2239520b8) [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90685) CFBundleIdentifier Collision. There is more than one bundle with the CFBundleIdentifier value 'com.onesignal.OneSignalExtension' under the iOS application 'appdinx.app'. (ID: 8ea7ecfa-5dfa-485d-9f9e-6315d642c080) [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90205) Invalid Bundle. The bundle at 'appdinx.app/PlugIns/OneSignalNotificationServiceExtension.appex' contains disallowed nested bundles. (ID: 098627a6-9de8-4a7a-a340-bec33caf368b) [Application Loader Error Output]: ERROR: [ContentDelivery.Uploader] Asset validation failed (90206) Invalid Bundle. The bundle at 'appdinx.app/PlugIns/OneSignalNotificationServiceExtension.appex' contains disallowed file 'Frameworks'. (ID: 21f5bfc8-9d11-494d-9408-1feea892803a) [Application Loader Error Output]: Error uploading '/var/folders/1k/vvqw2jx12_jgnkmrq5kxyxm80000gn/T/35baf30e-48d4-4bc2-956a-c989b2329460.ipa'.

I tried back and forth...

@anh1979
Copy link
Author

anh1979 commented May 2, 2024

Final script version

`#!/usr/bin/env node

var fs = require('fs');
var path = require('path');
var xml2js = require('xml2js');

var parser = new xml2js.Parser();

module.exports = function (context) {
console.log('\n[OneSignal - Notification Service Extension] - Installation start');

const log = '\t';
var rootdir = context.opts.projectRoot;
var project = path.join(rootdir, 'platforms/ios');

try {
fs.accessSync(rootdir, fs.F_OK);

} catch (e) {
console.error(log + e);
return;
}

let config_xml = path.join(rootdir, 'config.xml');
let configAsString = fs.readFileSync(config_xml).toString();

let bundleId;
let appName;
let teamId = "XXXXXXXX";
parser.parseString(configAsString, function (err, data) {
bundleId = data.widget.$.id;
appName = data.widget.name[0];
console.log(log + "Identified BUNDLE_IDENTIFIER: ", bundleId);
console.log(log + "Using fixed APP_NAME: ", appName);
console.log(log + "Using fixed TEAM_ID: ", teamId);
});

var info = fs.readFileSync(path.join(project, appName, appName + '-Info.plist'), 'utf8');

var config = [];
for (var key of ['CFBundleShortVersionString', 'CFBundleVersion']) {
var matchs = info.match(new RegExp('' + key + '</key>(?:(?:.|\n)+?)(.+?)</string>'));
if (!!!matchs) {
console.error(log + 'Can't get ' + key + ' from ./' + appName + '-Info.plist');
process.exit(1);
}
config[key] = matchs[1];
}

var appVersion = config['CFBundleShortVersionString'];
var appBuild = config['CFBundleVersion'];
var appTarget = '12.0';

var cnt = fs.readFileSync(path.join(project, appName + '.xcodeproj/project.pbxproj'), 'utf8');

if (cnt.indexOf('NotificationService.m') > -1) {
console.log(log + 'Source files and Frameworks already installed. [Skip]');
} else {

// Get Project Object ID
var projId = cnt.match(/rootObject = (.+?)(?:| \/\* Project object \*\/);/);
if (!!!projId) {
  console.error(log + 'Can\'t get Project object from project.pbxproj');
  process.exit(1);
}
projId = projId[1];

// Append PBXBuildFile section
console.log(log + 'Append PBXBuildFile section');
cnt = cnt.replace('/* End PBXBuildFile section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF5C15 /* NotificationService.m in Sources */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFF6A7C /* NotificationService.m */; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF9238 /* OneSignalNotificationServiceExtension.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFF0CC6 /* OneSignalNotificationServiceExtension.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF9AC8 /* CoreGraphics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFF8FC2 /* CoreGraphics.framework */; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFA186 /* WebKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFF16D6 /* WebKit.framework */; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFAED6 /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFFA60A /* UIKit.framework */; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFA397 /* SystemConfiguration.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FFFFFFFFFFFFFFFFFFFF15DB /* SystemConfiguration.framework */; };\n' +
  '\t\tDAAE46682BDFDFB30064CE94 /* OneSignal.xcframework in Frameworks */ = { isa = PBXBuildFile; fileRef = DAAE46672BDFDFB30064CE94 /* OneSignal.xcframework */; }; \n' +
  '\t\tDAAE466D2BDFDFB60064CE94 /* OneSignalCore.xcframework in Frameworks */ = { isa = PBXBuildFile; fileRef = DAAE466C2BDFDFB60064CE94 /* OneSignalCore.xcframework */; }; \n' +
  '\t\tDAAE46712BDFDFB90064CE94 /* OneSignalExtension.xcframework in Frameworks */ = { isa = PBXBuildFile; fileRef = DAAE46702BDFDFB90064CE94 /* OneSignalExtension.xcframework */; }; \n' +
  '\t\tDAAE46752BDFDFBD0064CE94 /* OneSignalOutcomes.xcframework in Frameworks */ = { isa = PBXBuildFile; fileRef = DAAE46742BDFDFBD0064CE94 /* OneSignalOutcomes.xcframework */; }; \n' +
  "/* End PBXBuildFile section */");

// Append PBXContainerItemProxy section
console.log(log + 'Append PBXContainerItemProxy section');
cnt = cnt.replace('/* End PBXContainerItemProxy section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF0E7E /* PBXContainerItemProxy */ = {\n' +
  '\t\t\tisa = PBXContainerItemProxy;\n' +
  '\t\t\tcontainerPortal = ' + projId + ' /* Project object */;\n' +
  '\t\t\tproxyType = 1;\n' +
  '\t\t\tremoteGlobalIDString = FFFFFFFFFFFFFFFFFFFF5D00;\n' +
  '\t\t\tremoteInfo = OneSignalNotificationServiceExtension;\n' +
  '\t\t};\n' +
  "/* End PBXContainerItemProxy section */");

// Add or append PBXCopyFilesBuildPhase section
console.log(log + 'Append PBXCopyFilesBuildPhase section');
if (cnt.indexOf('/* End PBXCopyFilesBuildPhase section */') === -1) {
  cnt = cnt.replace('/* End PBXContainerItemProxy section */', '/* End PBXContainerItemProxy section */\n\n/* Begin PBXCopyFilesBuildPhase section */\n/* End PBXCopyFilesBuildPhase section */');
}
cnt = cnt.replace('/* End PBXCopyFilesBuildPhase section */',
  '\t\tDAAE466A2BDFDFB30064CE94 /* Embed Frameworks */ = {\n' +
  '\t\tisa = PBXCopyFilesBuildPhase; \n' +
  '\t\tbuildActionMask = 2147483647; \n' +
  '\t\tdstPath = ""; \n' +
  '\t\tdstSubfolderSpec = 10; \n' +
  '\t\tfiles = (\n' +
  '\t\tDAAE46692BDFDFB30064CE94 /* OneSignal.xcframework in Embed Frameworks */, \n' +
  '\t\tDAAE46722BDFDFB90064CE94 /* OneSignalExtension.xcframework in Embed Frameworks */, \n' +
  '\t\tDAAE466E2BDFDFB60064CE94 /* OneSignalCore.xcframework in Embed Frameworks */, \n' +
  '\t\tDAAE46762BDFDFBD0064CE94 /* OneSignalOutcomes.xcframework in Embed Frameworks */, \n' +
  '\t\t); \n' +
  '\t\tname = "Embed Frameworks"; \n' +
  '\t\trunOnlyForDeploymentPostprocessing = 0; \n' +
  '\t\t}; \n\n' +

  '\t\tFFFFFFFFFFFFFFFFFFFF2C80 /* Embed App Extensions */ = {\n' +
  '\t\t\tisa = PBXCopyFilesBuildPhase;\n' +
  '\t\t\tbuildActionMask = 2147483647;\n' +
  '\t\t\tdstPath = \"\";\n' +
  '\t\t\tdstSubfolderSpec = 13;\n' +
  '\t\t\tfiles = (\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF9238 /* OneSignalNotificationServiceExtension.appex in Embed App Extensions */,\n' +
  '\t\t\t);\n' +
  '\t\t\tname = \"Embed App Extensions\";\n' +
  '\t\t\trunOnlyForDeploymentPostprocessing = 0;\n' +
  '\t\t};\n' +
  "/* End PBXCopyFilesBuildPhase section */");

// Append PBXFileReference section
console.log(log + 'Append PBXFileReference section');
cnt = cnt.replace('/* End PBXFileReference section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF0CC6 /* OneSignalNotificationServiceExtension.appex */ = {isa = PBXFileReference; explicitFileType = "wrapper.app-extension"; includeInIndex = 0; path = OneSignalNotificationServiceExtension.appex; sourceTree = BUILT_PRODUCTS_DIR; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFCDA5 /* NotificationService.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = NotificationService.h; sourceTree = "<group>"; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF6A7C /* NotificationService.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = NotificationService.m; sourceTree = "<group>"; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFCB44 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF8FC2 /* CoreGraphics.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreGraphics.framework; path = System/Library/Frameworks/CoreGraphics.framework; sourceTree = SDKROOT; };\n' +
  '\t\tDAAE46672BDFDFB30064CE94 /* OneSignal.xcframework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.xcframework; name = OneSignal.xcframework; path = Pods/OneSignalXCFramework/iOS_SDK/OneSignalSDK/OneSignal_XCFramework/OneSignal.xcframework; sourceTree = "<group>"; };\n' +
  '\t\tDAAE466C2BDFDFB60064CE94 /* OneSignalCore.xcframework */ = { isa = PBXFileReference; lastKnownFileType = wrapper.xcframework; name = OneSignalCore.xcframework; path = Pods/OneSignalXCFramework/iOS_SDK/OneSignalSDK/OneSignal_Core/OneSignalCore.xcframework; sourceTree = "<group>"; }; \n' +
  '\t\tDAAE46702BDFDFB90064CE94 /* OneSignalExtension.xcframework */ = { isa = PBXFileReference; lastKnownFileType = wrapper.xcframework; name = OneSignalExtension.xcframework; path = Pods/OneSignalXCFramework/iOS_SDK/OneSignalSDK/OneSignal_Extension/OneSignalExtension.xcframework; sourceTree = "<group>"; }; \n' +
  '\t\tDAAE46742BDFDFBD0064CE94 /* OneSignalOutcomes.xcframework */ = { isa = PBXFileReference; lastKnownFileType = wrapper.xcframework; name = OneSignalOutcomes.xcframework; path = Pods/OneSignalXCFramework/iOS_SDK/OneSignalSDK/OneSignal_Outcomes/OneSignalOutcomes.xcframework; sourceTree = "<group>"; }; \n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF16D6 /* WebKit.framework */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = wrapper.framework; name = WebKit.framework; path = System/Library/Frameworks/WebKit.framework; sourceTree = SDKROOT; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFA60A /* UIKit.framework */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = undefined; includeInIndex = 0; lastKnownFileType = wrapper.framework; name = UIKit.framework; path = System/Library/Frameworks/UIKit.framework; sourceTree = SDKROOT; };\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFF15DB /* SystemConfiguration.framework */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = undefined; includeInIndex = 0; lastKnownFileType = wrapper.framework; name = SystemConfiguration.framework; path = System/Library/Frameworks/SystemConfiguration.framework; sourceTree = SDKROOT; };\n' +
  '/* End PBXFileReference section */');

// Append PBXFrameworksBuildPhase section ???
console.log(log + 'Append PBXFrameworksBuildPhase section');
cnt = cnt.replace('/* End PBXFrameworksBuildPhase section */',
  '\t\tFFFFFFFFFFFFFFFFFFFFFAB3 /* Frameworks */ = {\n' +
  '\t\t\tisa = PBXFrameworksBuildPhase;\n' +
  '\t\t\tbuildActionMask = 2147483647;\n' +
  '\t\t\tfiles = (\n' +
  '\t\t\t\tDAAE46682BDFDFB30064CE94 /* OneSignal.xcframework in Frameworks */,\n' +
  '\t\t\t\tDAAE466D2BDFDFB60064CE94 /* OneSignalCore.xcframework in Frameworks */, \n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFA397 /* SystemConfiguration.framework in Frameworks */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFAED6 /* UIKit.framework in Frameworks */,\n' +
  '\t\t\t\tDAAE46712BDFDFB90064CE94 /* OneSignalExtension.xcframework in Frameworks */,\n' +
  '\t\t\t\tDAAE46752BDFDFBD0064CE94 /* OneSignalOutcomes.xcframework in Frameworks */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFA186 /* WebKit.framework in Frameworks */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF9AC8 /* CoreGraphics.framework in Frameworks */,\n' +
  '\t\t\t);\n' +
  '\t\t\trunOnlyForDeploymentPostprocessing = 0;\n' +
  '\t\t};\n' +
  '/* End PBXFrameworksBuildPhase section */');

// Append PBXGroup section > Products > children
console.log(log + 'Append PBXGroup section > Products > children');
var id = cnt.match(/productRefGroup = (.+?) \/\* Products \*\/;/); // Search for ID
if (!!!id) {
  console.error(log + 'Can\'t get Products ID from project.pbxproj');
  process.exit(1);
}
id = id[1]; // Get matched value
var matchs = cnt.match(new RegExp('\\t\\t' + id + ' \/\\* Products \\*\/ = {(?:(?:.|\n)+?)children = \\(\n((.|\n)+?)\\t\\t\\t\\);(?:(?:.|\n)+?)};')); // Search section
if (!!!matchs) {
  console.error(log + 'Can\'t get Products content from project.pbxproj');
  process.exit(1);
}
var section = matchs[0]; // Store old section
var appended = section.replace(matchs[1], matchs[1] + '\t\t\t\tFFFFFFFFFFFFFFFFFFFF0CC6 /* OneSignalNotificationServiceExtension.appex */,\n'); // Store new section
cnt = cnt.replace(section, appended); // Replaces it

// Append PBXGroup section > CustomTemplate > children
console.log(log + 'Append PBXGroup section > CustomTemplate > children');
var id = cnt.match(/mainGroup = (.+?)(?:| \/\* CustomTemplate \*\/);/); // Search for ID
if (!!!id) {
  console.error(log + 'Can\'t get CustomTemplate ID from project.pbxproj');
  process.exit(1);
}
id = id[1]; // Get matched value
var matchs = cnt.match(new RegExp('\\t\\t' + id + '(?:| \/\\* CustomTemplate \\*\/) = {(?:(?:.|\n)+?)children = \\(\n((.|\n)+?)\\t\\t\\t\\);(?:(?:.|\n)+?)};')); // Search section
if (!!!matchs) {
  console.error(log + 'Can\'t get CustomTemplate content from project.pbxproj');
  process.exit(1);
}
var section = matchs[0]; // Store old section
var appended = section.replace(matchs[1], matchs[1] + '\t\t\t\tFFFFFFFFFFFFFFFFFFFF1F29 /* OneSignalNotificationServiceExtension */,\n'); // Store new section
cnt = cnt.replace(section, appended); // Replaces it

// Append PBXGroup section > Frameworks > children
console.log(log + 'Append PBXGroup section > Frameworks > children');
var id = appended.match(/\t\t\t\t(.+?) \/\* Frameworks \*\/,/);
if (!!!id) {
  console.error(log + 'Can\'t get Frameworks ID from project.pbxproj');
  process.exit(1);
}
id = id[1];
var matchs = cnt.match(new RegExp('\\t\\t' + id + ' \/\\* Frameworks \\*\/ = {(?:(?:.|\n)+?)children = \\(\n((.|\n)+?)\\t\\t\\t\\);(?:(?:.|\n)+?)};')); // Search section
if (!!!matchs) {
  console.error(log + 'Can\'t get Frameworks content from project.pbxproj');
  process.exit(1);
}
var section = matchs[0]; // Store old section
var appended = section.replace(matchs[1], matchs[1] +
  '\t\t\t\tDAAE46672BDFDFB30064CE94 /* OneSignal.xcframework */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF8FC2 /* CoreGraphics.framework */,\n' +  // Store new section
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF16D6 /* WebKit.framework */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFA60A /* UIKit.framework */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF15DB /* SystemConfiguration.framework */,\n')
cnt = cnt.replace(section, appended); // Replaces it

// Append PBXGroup section ???
console.log(log + 'Append PBXGroup section');
cnt = cnt.replace('/* End PBXGroup section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF1F29 /* OneSignalNotificationServiceExtension */ = {\n' +
  '\t\t\tisa = PBXGroup;\n' +
  '\t\t\tchildren = (\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFCDA5 /* NotificationService.h */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF6A7C /* NotificationService.m */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFCB44 /* Info.plist */,\n' +
  '\t\t\t);\n' +
  '\t\t\tpath = OneSignalNotificationServiceExtension;\n' +
  '\t\t\tsourceTree = "<group>";\n' +
  '\t\t};\n' +
  '/* End PBXGroup section */');

// Append PBXNativeTarget section > AppName > buildPhases & dependencies
console.log(log + 'Append PBXNativeTarget section > AppName > buildPhases & dependencies');
var matchs = cnt.match(new RegExp('\/\\* Begin PBXNativeTarget section \\*\/(?:(?:.|\n)+?)buildPhases = \\(\n((.|\n)+?)\\t\\t\\t\\);(?:(?:.|\n)+?)dependencies = \\(\n((.|\n)+?)\\t\\t\\t\\);((.|\n)+?)\/\\* End PBXNativeTarget section \\*\/')); // Search section
if (!!!matchs) {
  console.error(log + 'Can\'t get target content from project.pbxproj');
  process.exit(1);
}
var section = matchs[0]; // Store old section
var appended = section.replace(matchs[1], matchs[1] + '\t\t\t\tFFFFFFFFFFFFFFFFFFFF2C80 /* Embed App Extensions */,\n'); // Store new section
appended = appended.replace(matchs[3], matchs[3] + '\t\t\t\tFFFFFFFFFFFFFFFFFFFF9CCD /* PBXTargetDependency */,\n'); // Store new section
cnt = cnt.replace(section, appended); // Replaces it

// Append PBXNativeTarget section
console.log(log + 'Append PBXNativeTarget section');
cnt = cnt.replace('/* End PBXNativeTarget section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF5D00 /* OneSignalNotificationServiceExtension */ = {\n' +
  '\t\t\tisa = PBXNativeTarget;\n' +
  '\t\t\tbuildConfigurationList = FFFFFFFFFFFFFFFFFFFFB33D /* Build configuration list for PBXNativeTarget "OneSignalNotificationServiceExtension" */;\n' +
  '\t\t\tbuildPhases = (\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF7943 /* Sources */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFFAB3 /* Frameworks */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFBAB7 /* Resources */,\n' +
  '\t\t\t\tDAAE466A2BDFDFB30064CE94 /* Embed Frameworks */,\n' +
  '\t\t\t);\n' +
  '\t\t\tbuildRules = (\n' +
  '\t\t\t);\n' +
  '\t\t\tdependencies = (\n' +
  '\t\t\t);\n' +
  '\t\t\tname = OneSignalNotificationServiceExtension;\n' +
  '\t\t\tproductName = OneSignalNotificationServiceExtension;\n' +
  '\t\t\tproductReference = FFFFFFFFFFFFFFFFFFFF0CC6 /* OneSignalNotificationServiceExtension.appex */;\n' +
  '\t\t\tproductType = "com.apple.product-type.app-extension";\n' +
  '\t\t};\n' +
  '/* End PBXNativeTarget section */');

// Append PBXProject section > AppName > attributes & targets
console.log(log + 'Append PBXProject section > AppName > attributes & targets');
var matchs = cnt.match(new RegExp('\/\\* Begin PBXProject section \\*\/(?:(?:.|\n)+?)attributes = \\{\n((.|\n)+?)\\t\\t\\t\\};(?:(?:.?|\n)+?)targets = \\(\n((.|\n)+?)\\t\\t\\t\\);((.|\n)+?)\/\\* End PBXProject section \\*\/')); // Search section
if (!!!matchs) {
  console.error(log + 'Can\'t get PBXProject content from project.pbxproj');
  process.exit(1);
}
var section = matchs[0]; // Store old section
var appended = section.replace(matchs[1], matchs[1] + '\t\t\t\tTargetAttributes = {\n\t\t\t\t\tFFFFFFFFFFFFFFFFFFFF5D00 = {\n\t\t\t\t\t\tCreatedOnToolsVersion = 12.4;\n\t\t\t\t\t};\n\t\t\t\t};\n'); // Store new section
appended = appended.replace(matchs[3], matchs[3] + '\t\t\t\tFFFFFFFFFFFFFFFFFFFF5D00 /* OneSignalNotificationServiceExtension */,\n'); // Store new section
cnt = cnt.replace(section, appended); // Replaces it

// Append PBXNativeTarget section
console.log(log + 'Append PBXNativeTarget section');
cnt = cnt.replace('/* End PBXResourcesBuildPhase section */',
  '\t\tFFFFFFFFFFFFFFFFFFFFBAB7 /* Resources */ = {\n' +
  '\t\t\tisa = PBXResourcesBuildPhase;\n' +
  '\t\t\tbuildActionMask = 2147483647;\n' +
  '\t\t\tfiles = (\n' +
  '\t\t\t);\n' +
  '\t\t\trunOnlyForDeploymentPostprocessing = 0;\n' +
  '\t\t};\n' +
  '/* End PBXResourcesBuildPhase section */');

// Append PBXSourcesBuildPhase section
console.log(log + 'Append PBXSourcesBuildPhase section');
cnt = cnt.replace('/* End PBXSourcesBuildPhase section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF7943 /* Sources */ = {\n' +
  '\t\t\tisa = PBXSourcesBuildPhase;\n' +
  '\t\t\tbuildActionMask = 2147483647;\n' +
  '\t\t\tfiles = (\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF5C15 /* NotificationService.m in Sources */,\n' +
  '\t\t\t);\n' +
  '\t\t\trunOnlyForDeploymentPostprocessing = 0;\n' +
  '\t\t};\n' +
  '/* End PBXSourcesBuildPhase section */');

// Append PBXTargetDependency section
console.log(log + 'Append PBXTargetDependency section');
cnt = cnt.replace('/* End PBXTargetDependency section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF9CCD /* PBXTargetDependency */ = {\n' +
  '\t\t\tisa = PBXTargetDependency;\n' +
  '\t\t\ttarget = FFFFFFFFFFFFFFFFFFFF5D00 /* OneSignalNotificationServiceExtension */;\n' +
  '\t\t\ttargetProxy = FFFFFFFFFFFFFFFFFFFF0E7E /* PBXContainerItemProxy */;\n' +
  '\t\t};\n' +
  '/* End PBXTargetDependency section */');

// Append XCBuildConfiguration section
console.log(log + 'Append XCBuildConfiguration section');
cnt = cnt.replace('/* End XCBuildConfiguration section */',
  '\t\tFFFFFFFFFFFFFFFFFFFF0074 /* Debug */ = {\n' +
  '\t\t\tisa = XCBuildConfiguration;\n' +
  '\t\t\tbuildSettings = {\n' +
  '\t\t\t\tALWAYS_SEARCH_USER_PATHS = NO;\n' +
  '\t\t\t\tCLANG_ANALYZER_NONNULL = YES;\n' +
  '\t\t\t\tCLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;\n' +
  '\t\t\t\tCLANG_CXX_LANGUAGE_STANDARD = "gnu++14";\n' +
  '\t\t\t\tCLANG_CXX_LIBRARY = "libc++";\n' +
  '\t\t\t\tCLANG_ENABLE_OBJC_WEAK = YES;\n' +
  '\t\t\t\tCLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n' +
  '\t\t\t\tCLANG_WARN_DOCUMENTATION_COMMENTS = YES;\n' +
  '\t\t\t\tCLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n' +
  '\t\t\t\tCLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;\n' +
  '\t\t\t\tCLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;\n' +
  '\t\t\t\tCODE_SIGN_IDENTITY = "Apple Development";\n' +
  '\t\t\t\tCODE_SIGN_STYLE = Manual;\n' +
  '\t\t\t\tCOPY_PHASE_STRIP = NO;\n' +
  '\t\t\t\tCURRENT_PROJECT_VERSION = ' + appBuild + ';\n' +
  '\t\t\t\tDEBUG_INFORMATION_FORMAT = dwarf;\n' +
  '\t\t\t\tDEVELOPMENT_TEAM = ' + teamId + ';\n' +
  '\t\t\t\tFRAMEWORK_SEARCH_PATHS = (\n' +
  '\t\t\t\t\t"$(inherited)",\n' +
  '\t\t\t\t\t"$(PROJECT_DIR)/Pods/OneSignal/iOS_SDK/OneSignalSDK/Framework",\n' +
  '\t\t\t\t);\n' +
  '\t\t\t\tGCC_C_LANGUAGE_STANDARD = gnu11;\n' +
  '\t\t\t\tGCC_DYNAMIC_NO_PIC = NO;\n' +
  '\t\t\t\tGCC_OPTIMIZATION_LEVEL = 0;\n' +
  '\t\t\t\tGCC_PREPROCESSOR_DEFINITIONS = (\n' +
  '\t\t\t\t\t"DEBUG=1",\n' +
  '\t\t\t\t\t"$(inherited)",\n' +
  '\t\t\t\t);\n' +
  '\t\t\t\tGCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n' +
  '\t\t\t\tGCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;\n' +
  '\t\t\t\tINFOPLIST_FILE = OneSignalNotificationServiceExtension/Info.plist;\n' +
  '\t\t\t\tIPHONEOS_DEPLOYMENT_TARGET = ' + appTarget + ';\n' +
  '\t\t\t\tLD_RUNPATH_SEARCH_PATHS = (\n' +
  '\t\t\t\t\t"$(inherited)",\n' +
  '\t\t\t\t\t"@executable_path/Frameworks",\n' +
  '\t\t\t\t\t"@executable_path/../../Frameworks",\n' +
  '\t\t\t\t);\n' +
  '\t\t\t\tMARKETING_VERSION = ' + appVersion + ';\n' +
  '\t\t\t\tMTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;\n' +
  '\t\t\t\tMTL_FAST_MATH = YES;\n' +
  '\t\t\t\tPRODUCT_BUNDLE_IDENTIFIER = ' + bundleId + '.OneSignalNotificationServiceExtension;\n' +
  '\t\t\t\tPRODUCT_NAME = "$(TARGET_NAME)";\n' +
  '\t\t\t\tSKIP_INSTALL = YES;\n' +
  '\t\t\t\tTARGETED_DEVICE_FAMILY = 1;\n' +
  '\t\t\t};\n' +
  '\t\t\tname = Debug;\n' +
  '\t\t};\n' +
  '\t\tFFFFFFFFFFFFFFFFFFFFE808 /* Release */ = {\n' +
  '\t\t\tisa = XCBuildConfiguration;\n' +
  '\t\t\tbuildSettings = {\n' +
  '\t\t\t\tALWAYS_SEARCH_USER_PATHS = NO;\n' +
  '\t\t\t\tCLANG_ANALYZER_NONNULL = YES;\n' +
  '\t\t\t\tCLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;\n' +
  '\t\t\t\tCLANG_CXX_LANGUAGE_STANDARD = "gnu++14";\n' +
  '\t\t\t\tCLANG_CXX_LIBRARY = "libc++";\n' +
  '\t\t\t\tCLANG_ENABLE_OBJC_WEAK = YES;\n' +
  '\t\t\t\tCLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;\n' +
  '\t\t\t\tCLANG_WARN_DOCUMENTATION_COMMENTS = YES;\n' +
  '\t\t\t\tCLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;\n' +
  '\t\t\t\tCLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;\n' +
  '\t\t\t\tCLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;\n' +
  '\t\t\t\tCODE_SIGN_IDENTITY = "Apple Development";\n' +
  '\t\t\t\tCODE_SIGN_STYLE = Manual;\n' +
  '\t\t\t\tCOPY_PHASE_STRIP = NO;\n' +
  '\t\t\t\tCURRENT_PROJECT_VERSION = ' + appBuild + ';\n' +
  '\t\t\t\tDEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";\n' +
  '\t\t\t\tDEVELOPMENT_TEAM = ' + teamId + ';\n' +
  '\t\t\t\tENABLE_NS_ASSERTIONS = NO;\n' +
  '\t\t\t\tFRAMEWORK_SEARCH_PATHS = (\n' +
  '\t\t\t\t\t"$(inherited)",\n' +
  '\t\t\t\t\t"$(PROJECT_DIR)/Pods/OneSignal/iOS_SDK/OneSignalSDK/Framework",\n' +
  '\t\t\t\t);\n' +
  '\t\t\t\tGCC_C_LANGUAGE_STANDARD = gnu11;\n' +
  '\t\t\t\tGCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;\n' +
  '\t\t\t\tGCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;\n' +
  '\t\t\t\tINFOPLIST_FILE = OneSignalNotificationServiceExtension/Info.plist;\n' +
  '\t\t\t\tIPHONEOS_DEPLOYMENT_TARGET = ' + appTarget + ';\n' +
  '\t\t\t\tLD_RUNPATH_SEARCH_PATHS = (\n' +
  '\t\t\t\t\t"$(inherited)",\n' +
  '\t\t\t\t\t"@executable_path/Frameworks",\n' +
  '\t\t\t\t\t"@executable_path/../../Frameworks",\n' +
  '\t\t\t\t);\n' +
  '\t\t\t\tMARKETING_VERSION = ' + appVersion + ';\n' +
  '\t\t\t\tMTL_ENABLE_DEBUG_INFO = NO;\n' +
  '\t\t\t\tMTL_FAST_MATH = YES;\n' +
  '\t\t\t\tPRODUCT_BUNDLE_IDENTIFIER = ' + bundleId + '.OneSignalNotificationServiceExtension;\n' +
  //'\t\t\t\tPROVISIONING_PROFILE_SPECIFIER = "";\n' +
  '\t\t\t\tPRODUCT_NAME = "$(TARGET_NAME)";\n' +
  '\t\t\t\tSKIP_INSTALL = YES;\n' +
  '\t\t\t\tTARGETED_DEVICE_FAMILY = 1;\n' +
  '\t\t\t\tVALIDATE_PRODUCT = YES;\n' +
  '\t\t\t};\n' +
  '\t\t\tname = Release;\n' +
  '\t\t};\n' +
  '/* End XCBuildConfiguration section */');


// Append XCConfigurationList section
console.log(log + 'Append XCConfigurationList section');
cnt = cnt.replace('/* End XCConfigurationList section */',
  '\t\tFFFFFFFFFFFFFFFFFFFFB33D /* Build configuration list for PBXNativeTarget "OneSignalNotificationServiceExtension" */ = {\n' +
  '\t\t\tisa = XCConfigurationList;\n' +
  '\t\t\tbuildConfigurations = (\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFF0074 /* Debug */,\n' +
  '\t\t\t\tFFFFFFFFFFFFFFFFFFFFE808 /* Release */,\n' +
  '\t\t\t);\n' +
  '\t\t\tdefaultConfigurationIsVisible = 0;\n' +
  '\t\t\tdefaultConfigurationName = Release;\n' +
  '\t\t};\n' +
  '/* End XCConfigurationList section */');

fs.writeFileSync(path.join(project, appName + '.xcodeproj/project.pbxproj'), cnt);

console.log(log + 'Source files and Frameworks installed');

}

// Entitlements
['Entitlements-Release.plist', 'Entitlements-Debug.plist'].forEach((target) => {
var cnt = fs.readFileSync(path.join(project, appName, target), 'utf8');

if (cnt.indexOf('<string>group.' + bundleId + '.onesignal</string>') > -1) {
  console.log(log + 'App Group already created for ' + target + ' [Skip]');
} else {

  if (cnt.indexOf('<key>com.apple.security.application-groups</key>') > -1) {
    cnt = cnt.replace('<key>com.apple.security.application-groups</key>\n\t<array>', '<key>com.apple.security.application-groups</key>\n\t<array>\n\t\t<string>group.' + bundleId + '.onesignal</string>\t\t\t');
  } else {
    cnt = cnt.replace('</dict>\n</plist>', '\t<key>com.apple.security.application-groups</key>\n\t<array>\n\t\t<string>group.' + bundleId + '.onesignal</string>\n\t</array>\n</dict>\n</plist>');
  }
  fs.writeFileSync(path.join(project, appName, target), cnt);

  console.log(log + 'App Group created for ' + target);
}

});

// Dir
var onesignalDir = path.join(project, 'OneSignalNotificationServiceExtension');
if (!fs.existsSync(onesignalDir)) {
fs.mkdirSync(onesignalDir);
console.log(log + 'Folder OneSignalNotificationServiceExtension created');
} else {
console.log(log + 'Folder OneSignalNotificationServiceExtension already exists [Skip]');
}

// Files
fs.writeFileSync(path.join(onesignalDir, 'Info.plist'),
`

CFBundleDevelopmentRegion $(DEVELOPMENT_LANGUAGE) CFBundleDisplayName OneSignalNotificationServiceExtension CFBundleExecutable $(EXECUTABLE_NAME) CFBundleIdentifier $(PRODUCT_BUNDLE_IDENTIFIER) CFBundleInfoDictionaryVersion 6.0 CFBundleName $(PRODUCT_NAME) CFBundlePackageType $(PRODUCT_BUNDLE_PACKAGE_TYPE) CFBundleShortVersionString $(MARKETING_VERSION) CFBundleVersion $(CURRENT_PROJECT_VERSION) NSExtension NSExtensionPointIdentifier com.apple.usernotifications.service NSExtensionPrincipalClass NotificationService `); console.log(log + 'File Info.plist created');

fs.writeFileSync(path.join(onesignalDir, 'NotificationService.h'),
`#import <UserNotifications/UserNotifications.h>

@interface NotificationService : UNNotificationServiceExtension

@end`);
console.log(log + 'File NotificationService.h created');

fs.writeFileSync(path.join(onesignalDir, 'NotificationService.m'),
`#import <OneSignal/OneSignal.h>

#import "NotificationService.h"

@interface NotificationService ()

@Property (nonatomic, strong) void (^contentHandler)(UNNotificationContent *contentToDeliver);
@Property (nonatomic, strong) UNNotificationRequest *receivedRequest;
@Property (nonatomic, strong) UNMutableNotificationContent *bestAttemptContent;

@EnD

@implementation NotificationService

  • (void)didReceiveNotificationRequest:(UNNotificationRequest *)request withContentHandler:(void (^)(UNNotificationContent * _Nonnull))contentHandler {
    self.receivedRequest = request;
    self.contentHandler = contentHandler;
    self.bestAttemptContent = [request.content mutableCopy];

    [OneSignal didReceiveNotificationExtensionRequest:self.receivedRequest withMutableNotificationContent:self.bestAttemptContent];

    // DEBUGGING: Uncomment the 2 lines below and comment out the one above to ensure this extension is excuting
    // Note, this extension only runs when mutable-content is set
    // Setting an attachment or action buttons automatically adds this
    NSLog(@"Running NotificationServiceExtension");
    // self.bestAttemptContent.body = [@"[Modified] " stringByAppendingString:self.bestAttemptContent.body];

    self.contentHandler(self.bestAttemptContent);
    }

  • (void)serviceExtensionTimeWillExpire {
    // Called just before the extension will be terminated by the system.
    // Use this as an opportunity to deliver your "best attempt" at modified content, otherwise the original push payload will be used.

    [OneSignal serviceExtensionTimeWillExpireRequest:self.receivedRequest withMutableNotificationContent:self.bestAttemptContent];

    self.contentHandler(self.bestAttemptContent);
    }

@end`);
console.log(log + 'File NotificationService.m created');

console.log('[OneSignal - Notification Service Extension] - Installation finished\n');
};
`

@anh1979 anh1979 closed this as completed May 2, 2024
@anh1979
Copy link
Author

anh1979 commented May 2, 2024

Sorry for markdown not showing code correctly.

@brunoinds
Copy link

How to use it? I'm facing the same errors "CFBundleIdentifier Collision"... How and when should I run this script?

@brunoinds
Copy link

I've found a "partial" solution. If do not use rich notifications, you should not use OneSignalServiceExtension. As I only use text in the notifications, I've deleted the OneSignalServiceExtension, and the problem is gone!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants