@codeleap/cli 1.0.1 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitattributes +1 -0
- package/dist/commands/init.js +68 -26
- package/dist/commands/keystoresAndroid.js +128 -0
- package/dist/commands/rename.js +154 -0
- package/dist/index.js +7 -4
- package/dist/lib/android/index.js +18 -0
- package/dist/lib/android/keystore.js +27 -0
- package/dist/lib/android/rename.js +266 -0
- package/dist/lib/android/utils.js +67 -0
- package/dist/lib/firebase.js +19 -0
- package/dist/lib/index.js +22 -1
- package/dist/lib/ios/index.js +18 -0
- package/dist/lib/ios/rename.js +160 -0
- package/dist/lib/ios/utils.js +28 -0
- package/dist/lib/spinner.js +11 -2
- package/dist/lib/utils.js +69 -0
- package/dist/lib/walk.js +130 -0
- package/package.json +43 -32
- package/yarn-error.log +25945 -0
- package/dist/index.d.ts +0 -1
- package/src/commands/init.ts +0 -31
- package/src/index.ts +0 -12
- package/src/lib/Command.ts +0 -10
- package/src/lib/index.ts +0 -3
- package/src/lib/spinner.ts +0 -21
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
14
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
15
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
16
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
17
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
18
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
19
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
23
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
24
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
25
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
26
|
+
function step(op) {
|
|
27
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
28
|
+
while (_) try {
|
|
29
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
30
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
31
|
+
switch (op[0]) {
|
|
32
|
+
case 0: case 1: t = op; break;
|
|
33
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
34
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
35
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
36
|
+
default:
|
|
37
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
38
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
39
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
40
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
41
|
+
if (t[2]) _.ops.pop();
|
|
42
|
+
_.trys.pop(); continue;
|
|
43
|
+
}
|
|
44
|
+
op = body.call(thisArg, _);
|
|
45
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
46
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
var __read = (this && this.__read) || function (o, n) {
|
|
50
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
51
|
+
if (!m) return o;
|
|
52
|
+
var i = m.call(o), r, ar = [], e;
|
|
53
|
+
try {
|
|
54
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
55
|
+
}
|
|
56
|
+
catch (error) { e = { error: error }; }
|
|
57
|
+
finally {
|
|
58
|
+
try {
|
|
59
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
60
|
+
}
|
|
61
|
+
finally { if (e) throw e.error; }
|
|
62
|
+
}
|
|
63
|
+
return ar;
|
|
64
|
+
};
|
|
65
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
66
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
67
|
+
if (ar || !(i in from)) {
|
|
68
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
69
|
+
ar[i] = from[i];
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
73
|
+
};
|
|
74
|
+
var __values = (this && this.__values) || function(o) {
|
|
75
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
76
|
+
if (m) return m.call(o);
|
|
77
|
+
if (o && typeof o.length === "number") return {
|
|
78
|
+
next: function () {
|
|
79
|
+
if (o && i >= o.length) o = void 0;
|
|
80
|
+
return { value: o && o[i++], done: !o };
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
84
|
+
};
|
|
85
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
86
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
87
|
+
};
|
|
88
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
89
|
+
exports.renameAndroid = void 0;
|
|
90
|
+
/* eslint-disable handle-callback-err */
|
|
91
|
+
var utils_1 = require("../utils");
|
|
92
|
+
var utils_2 = require("./utils");
|
|
93
|
+
var path_1 = __importDefault(require("path"));
|
|
94
|
+
var fs_1 = __importDefault(require("fs"));
|
|
95
|
+
var walk_1 = require("../walk");
|
|
96
|
+
var firebase_admin_1 = __importDefault(require("firebase-admin"));
|
|
97
|
+
var node_keytool_1 = __importDefault(require("node-keytool"));
|
|
98
|
+
var common_1 = require("@codeleap/common");
|
|
99
|
+
function renameAndroid(androidFolder, newName, options) {
|
|
100
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
101
|
+
var newBundleName, androidManifest, stringsXml, bundleId, currentName, pm, androidAppReqs, androidApps, googleServiceFile, newApp_1, newGoogleServicesFile, keystoresFolder, keystores, keystores_1, keystores_1_1, keystore, keyPathData, valid, storeTypeMap, gradleProperties, key;
|
|
102
|
+
var e_1, _a;
|
|
103
|
+
var _this = this;
|
|
104
|
+
return __generator(this, function (_b) {
|
|
105
|
+
switch (_b.label) {
|
|
106
|
+
case 0:
|
|
107
|
+
newBundleName = (0, utils_1.getNewBundleName)(newName);
|
|
108
|
+
androidManifest = fs_1.default.readFileSync(path_1.default.join(androidFolder, 'app', 'src', 'main', 'AndroidManifest.xml')).toString();
|
|
109
|
+
stringsXml = fs_1.default.readFileSync(path_1.default.join(androidFolder, 'app', 'src', 'main', 'res', 'values', 'strings.xml')).toString();
|
|
110
|
+
bundleId = (0, utils_2.getAndroidBundleId)(androidManifest);
|
|
111
|
+
currentName = (0, utils_2.getAndroidAppName)(stringsXml);
|
|
112
|
+
return [4 /*yield*/, (0, walk_1.walkDir)({
|
|
113
|
+
action: function (info) {
|
|
114
|
+
if (!info.isDir) {
|
|
115
|
+
var content = info.file.content;
|
|
116
|
+
if (options === null || options === void 0 ? void 0 : options.changeBundle) {
|
|
117
|
+
content = content.replace(new RegExp("".concat(bundleId), 'g'), newBundleName);
|
|
118
|
+
}
|
|
119
|
+
var nameExp = new RegExp("(?<!\\.)".concat(currentName), 'g');
|
|
120
|
+
return content.replace(nameExp, newName.trim());
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
path: androidFolder,
|
|
124
|
+
options: {
|
|
125
|
+
scanFileContent: true,
|
|
126
|
+
ignore: [
|
|
127
|
+
{
|
|
128
|
+
name: 'google-services',
|
|
129
|
+
ext: ['json'],
|
|
130
|
+
file: true,
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
ext: ['png', 'jpg', 'jpeg'],
|
|
134
|
+
file: true,
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
name: 'gradle-wrapper',
|
|
138
|
+
file: true,
|
|
139
|
+
},
|
|
140
|
+
{
|
|
141
|
+
ext: ['keystore'],
|
|
142
|
+
file: true,
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
name: 'app/build',
|
|
146
|
+
dir: true,
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
},
|
|
150
|
+
}).then(function () {
|
|
151
|
+
var e_2, _a, e_3, _b;
|
|
152
|
+
if (options.changeBundle && newBundleName !== bundleId) {
|
|
153
|
+
var javaFolder = path_1.default.join(androidFolder, 'app', 'src', 'main', 'java');
|
|
154
|
+
var mainActivityFolder = path_1.default.join.apply(path_1.default, __spreadArray([javaFolder], __read(bundleId.split('.')), false));
|
|
155
|
+
var scan = javaFolder;
|
|
156
|
+
try {
|
|
157
|
+
for (var _c = __values(newBundleName.split('.')), _d = _c.next(); !_d.done; _d = _c.next()) {
|
|
158
|
+
var part = _d.value;
|
|
159
|
+
var folder = path_1.default.join(scan, part);
|
|
160
|
+
if (!fs_1.default.existsSync(folder)) {
|
|
161
|
+
fs_1.default.mkdirSync(folder);
|
|
162
|
+
}
|
|
163
|
+
scan = folder;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
167
|
+
finally {
|
|
168
|
+
try {
|
|
169
|
+
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
|
|
170
|
+
}
|
|
171
|
+
finally { if (e_2) throw e_2.error; }
|
|
172
|
+
}
|
|
173
|
+
try {
|
|
174
|
+
for (var _e = __values(fs_1.default.readdirSync(mainActivityFolder)), _f = _e.next(); !_f.done; _f = _e.next()) {
|
|
175
|
+
var file = _f.value;
|
|
176
|
+
fs_1.default.copyFileSync(path_1.default.join(mainActivityFolder, file), path_1.default.join(scan, file));
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
180
|
+
finally {
|
|
181
|
+
try {
|
|
182
|
+
if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
|
|
183
|
+
}
|
|
184
|
+
finally { if (e_3) throw e_3.error; }
|
|
185
|
+
}
|
|
186
|
+
fs_1.default.rmSync(mainActivityFolder, {
|
|
187
|
+
recursive: true,
|
|
188
|
+
force: true,
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
})];
|
|
192
|
+
case 1:
|
|
193
|
+
_b.sent();
|
|
194
|
+
pm = firebase_admin_1.default.projectManagement();
|
|
195
|
+
return [4 /*yield*/, pm.listAndroidApps()];
|
|
196
|
+
case 2:
|
|
197
|
+
androidAppReqs = (_b.sent()).map(function (a) { return __awaiter(_this, void 0, void 0, function () {
|
|
198
|
+
var _a;
|
|
199
|
+
var _b;
|
|
200
|
+
return __generator(this, function (_c) {
|
|
201
|
+
switch (_c.label) {
|
|
202
|
+
case 0:
|
|
203
|
+
_a = [__assign({}, a)];
|
|
204
|
+
_b = {};
|
|
205
|
+
return [4 /*yield*/, a.getMetadata()];
|
|
206
|
+
case 1: return [2 /*return*/, __assign.apply(void 0, _a.concat([(_b.meta = (_c.sent()), _b)]))];
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}); });
|
|
210
|
+
return [4 /*yield*/, Promise.all(androidAppReqs)];
|
|
211
|
+
case 3:
|
|
212
|
+
androidApps = _b.sent();
|
|
213
|
+
googleServiceFile = path_1.default.join(androidFolder, 'app', 'google-services.json');
|
|
214
|
+
if (!!androidApps.some(function (a) { return a.meta.packageName === newBundleName; })) return [3 /*break*/, 6];
|
|
215
|
+
console.log("Creating new android app on firebase and updating google-services.json");
|
|
216
|
+
return [4 /*yield*/, pm.createAndroidApp(newBundleName, newName.trim())];
|
|
217
|
+
case 4:
|
|
218
|
+
newApp_1 = _b.sent();
|
|
219
|
+
return [4 /*yield*/, newApp_1.getConfig()];
|
|
220
|
+
case 5:
|
|
221
|
+
newGoogleServicesFile = _b.sent();
|
|
222
|
+
fs_1.default.writeFileSync(googleServiceFile, newGoogleServicesFile, {
|
|
223
|
+
encoding: 'utf-8',
|
|
224
|
+
});
|
|
225
|
+
keystoresFolder = path_1.default.join(androidFolder, 'app', 'keystores');
|
|
226
|
+
keystores = fs_1.default.readdirSync(keystoresFolder, {
|
|
227
|
+
withFileTypes: true,
|
|
228
|
+
});
|
|
229
|
+
try {
|
|
230
|
+
for (keystores_1 = __values(keystores), keystores_1_1 = keystores_1.next(); !keystores_1_1.done; keystores_1_1 = keystores_1.next()) {
|
|
231
|
+
keystore = keystores_1_1.value;
|
|
232
|
+
keyPathData = (0, common_1.parseFilePathData)(keystore.name);
|
|
233
|
+
valid = ['jks', 'keystore'].includes(keyPathData.extension) && keystore.isFile();
|
|
234
|
+
if (!valid) {
|
|
235
|
+
continue;
|
|
236
|
+
}
|
|
237
|
+
storeTypeMap = {
|
|
238
|
+
'keystore': 'PKCS12',
|
|
239
|
+
'jks': 'JKS',
|
|
240
|
+
};
|
|
241
|
+
gradleProperties = (0, utils_2.readGradleProperties)(androidFolder);
|
|
242
|
+
key = (0, node_keytool_1.default)(path_1.default.join(keystoresFolder, keystore.name), gradleProperties["".concat(keyPathData.name.toUpperCase(), "_KEY_PASSWORD")], { debug: false, storeType: storeTypeMap[keyPathData.extension] });
|
|
243
|
+
key.list(function (err, vals) {
|
|
244
|
+
vals.certs.forEach(function (c) {
|
|
245
|
+
newApp_1.addShaCertificate({
|
|
246
|
+
certType: c.algorithm.toLowerCase().replace('-', ''),
|
|
247
|
+
shaHash: c.fingerprint,
|
|
248
|
+
});
|
|
249
|
+
});
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
254
|
+
finally {
|
|
255
|
+
try {
|
|
256
|
+
if (keystores_1_1 && !keystores_1_1.done && (_a = keystores_1.return)) _a.call(keystores_1);
|
|
257
|
+
}
|
|
258
|
+
finally { if (e_1) throw e_1.error; }
|
|
259
|
+
}
|
|
260
|
+
_b.label = 6;
|
|
261
|
+
case 6: return [2 /*return*/];
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
}
|
|
266
|
+
exports.renameAndroid = renameAndroid;
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.readGradleProperties = exports.getAndroidAppName = exports.getAndroidBundleId = void 0;
|
|
18
|
+
var fs_1 = __importDefault(require("fs"));
|
|
19
|
+
var path_1 = __importDefault(require("path"));
|
|
20
|
+
var __1 = require("..");
|
|
21
|
+
var getAndroidBundleId = function (androidManifestContent) {
|
|
22
|
+
var pkgStr = 'package="';
|
|
23
|
+
var packageIdx = androidManifestContent.indexOf(pkgStr) + pkgStr.length;
|
|
24
|
+
var packageName = androidManifestContent.substring(packageIdx);
|
|
25
|
+
var packageEndIdx = packageName.indexOf('"');
|
|
26
|
+
packageName = packageName.substring(0, packageEndIdx);
|
|
27
|
+
return packageName.trim();
|
|
28
|
+
};
|
|
29
|
+
exports.getAndroidBundleId = getAndroidBundleId;
|
|
30
|
+
var getAndroidAppName = function (stringsXmlContent) {
|
|
31
|
+
// const pkgStr = 'name="app_name">'
|
|
32
|
+
// const packageIdx = stringsXmlContent.indexOf(pkgStr) + pkgStr.length
|
|
33
|
+
// let packageName = stringsXmlContent.substring(packageIdx)
|
|
34
|
+
// const packageEndIdx = packageName.indexOf('<')
|
|
35
|
+
// packageName = packageName.substring(0, packageEndIdx)
|
|
36
|
+
// return packageName.trim()
|
|
37
|
+
return JSON.parse(fs_1.default.readFileSync(path_1.default.join(__1.cwd, 'app.json')).toString()).name;
|
|
38
|
+
};
|
|
39
|
+
exports.getAndroidAppName = getAndroidAppName;
|
|
40
|
+
var readGradleProperties = function (androidFolder) {
|
|
41
|
+
var paths = [
|
|
42
|
+
path_1.default.join(androidFolder, 'gradle.properties'),
|
|
43
|
+
];
|
|
44
|
+
var appProperties = path_1.default.join(androidFolder, 'app', 'gradle.properties');
|
|
45
|
+
if (fs_1.default.existsSync(appProperties)) {
|
|
46
|
+
paths.push(appProperties);
|
|
47
|
+
}
|
|
48
|
+
var mergedProps = {};
|
|
49
|
+
paths.forEach(function (path) {
|
|
50
|
+
var data = fs_1.default.readFileSync(path).toString();
|
|
51
|
+
var lines = data.split('\n').map(function (x) { return x.replace(/\n/g, '').replace(/\r/g, ''); }).filter(function (x) { return !!x.trim(); });
|
|
52
|
+
var props = {};
|
|
53
|
+
lines.forEach(function (l) {
|
|
54
|
+
if (l.startsWith('#'))
|
|
55
|
+
return;
|
|
56
|
+
var lineParts = l.split('=');
|
|
57
|
+
if (lineParts.length < 2)
|
|
58
|
+
return;
|
|
59
|
+
var value = lineParts[1].trim().split(' ')[0];
|
|
60
|
+
var property = lineParts[0].trim();
|
|
61
|
+
props[property] = value;
|
|
62
|
+
});
|
|
63
|
+
mergedProps = __assign(__assign({}, mergedProps), props);
|
|
64
|
+
});
|
|
65
|
+
return mergedProps;
|
|
66
|
+
};
|
|
67
|
+
exports.readGradleProperties = readGradleProperties;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.firebaseApp = void 0;
|
|
7
|
+
var firebase_admin_1 = __importDefault(require("firebase-admin"));
|
|
8
|
+
var path_1 = __importDefault(require("path"));
|
|
9
|
+
var _1 = require(".");
|
|
10
|
+
exports.firebaseApp = null;
|
|
11
|
+
if (!exports.firebaseApp) {
|
|
12
|
+
try {
|
|
13
|
+
exports.firebaseApp = firebase_admin_1.default.initializeApp({
|
|
14
|
+
credential: firebase_admin_1.default.credential.cert(path_1.default.join(_1.cwd, 'firebase_admin.json')),
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
catch (e) {
|
|
18
|
+
}
|
|
19
|
+
}
|
package/dist/lib/index.js
CHANGED
|
@@ -1,12 +1,33 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
2
16
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
17
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
18
|
};
|
|
5
19
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.inquirer = exports.chalk = exports.figlet = void 0;
|
|
20
|
+
exports.cwd = exports.isDev = exports.inquirer = exports.chalk = exports.figlet = void 0;
|
|
7
21
|
var figlet_1 = require("figlet");
|
|
8
22
|
Object.defineProperty(exports, "figlet", { enumerable: true, get: function () { return __importDefault(figlet_1).default; } });
|
|
9
23
|
var chalk_1 = require("chalk");
|
|
10
24
|
Object.defineProperty(exports, "chalk", { enumerable: true, get: function () { return __importDefault(chalk_1).default; } });
|
|
11
25
|
var inquirer_1 = require("inquirer");
|
|
12
26
|
Object.defineProperty(exports, "inquirer", { enumerable: true, get: function () { return __importDefault(inquirer_1).default; } });
|
|
27
|
+
var path_1 = __importDefault(require("path"));
|
|
28
|
+
var _cwd = process.cwd();
|
|
29
|
+
exports.isDev = process.argv[1] == 'src/index.ts';
|
|
30
|
+
exports.cwd = path_1.default.join(_cwd, exports.isDev ? 'tests' : '');
|
|
31
|
+
__exportStar(require("./utils"), exports);
|
|
32
|
+
__exportStar(require("./walk"), exports);
|
|
33
|
+
__exportStar(require("./android"), exports);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./rename"), exports);
|
|
18
|
+
__exportStar(require("./utils"), exports);
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
14
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
15
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
16
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
17
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
18
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
19
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
23
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
24
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
25
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
26
|
+
function step(op) {
|
|
27
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
28
|
+
while (_) try {
|
|
29
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
30
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
31
|
+
switch (op[0]) {
|
|
32
|
+
case 0: case 1: t = op; break;
|
|
33
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
34
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
35
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
36
|
+
default:
|
|
37
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
38
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
39
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
40
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
41
|
+
if (t[2]) _.ops.pop();
|
|
42
|
+
_.trys.pop(); continue;
|
|
43
|
+
}
|
|
44
|
+
op = body.call(thisArg, _);
|
|
45
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
46
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
50
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
51
|
+
};
|
|
52
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
53
|
+
exports.renameIos = void 0;
|
|
54
|
+
var utils_1 = require("../utils");
|
|
55
|
+
var utils_2 = require("./utils");
|
|
56
|
+
var path_1 = __importDefault(require("path"));
|
|
57
|
+
var fs_1 = __importDefault(require("fs"));
|
|
58
|
+
var walk_1 = require("../walk");
|
|
59
|
+
var firebase_admin_1 = __importDefault(require("firebase-admin"));
|
|
60
|
+
function renameIos(iosFolder, newName, options) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
62
|
+
var newBundleName, pbxProjPath, pbxProj, bundleId, currentName, renameQueue, pm, iosAppReqs, iosApps, googleServiceFile, newApp, newPlistFile;
|
|
63
|
+
var _this = this;
|
|
64
|
+
return __generator(this, function (_a) {
|
|
65
|
+
switch (_a.label) {
|
|
66
|
+
case 0:
|
|
67
|
+
newBundleName = (0, utils_1.getNewBundleName)(newName);
|
|
68
|
+
pbxProjPath = path_1.default.join(iosFolder, fs_1.default.readdirSync(iosFolder).find(function (x) { return x.endsWith('.xcodeproj'); }), 'project.pbxproj');
|
|
69
|
+
pbxProj = fs_1.default.readFileSync(pbxProjPath).toString();
|
|
70
|
+
bundleId = (0, utils_2.getIosBundleId)(pbxProj);
|
|
71
|
+
currentName = (0, utils_2.getIosAppName)(pbxProj);
|
|
72
|
+
renameQueue = [];
|
|
73
|
+
newName = newName.trim();
|
|
74
|
+
return [4 /*yield*/, (0, walk_1.walkDir)({
|
|
75
|
+
action: function (info) {
|
|
76
|
+
// console.log({ a: info.name })
|
|
77
|
+
if (info.name.includes(currentName)) {
|
|
78
|
+
var renameRegex = new RegExp(currentName, 'g');
|
|
79
|
+
var lastMatch_1 = info.path.lastIndexOf(currentName);
|
|
80
|
+
var idx_1 = 0;
|
|
81
|
+
renameQueue.push({
|
|
82
|
+
from: info.path.replace(renameRegex, function (str, i) {
|
|
83
|
+
if (i == lastMatch_1) {
|
|
84
|
+
return str;
|
|
85
|
+
}
|
|
86
|
+
idx_1++;
|
|
87
|
+
return newName;
|
|
88
|
+
}),
|
|
89
|
+
to: info.path.replace(renameRegex, newName),
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
if (!info.isDir) {
|
|
93
|
+
var content = info.file.content;
|
|
94
|
+
if (options === null || options === void 0 ? void 0 : options.changeBundle) {
|
|
95
|
+
content = content.replace(new RegExp("".concat(bundleId), 'g'), newBundleName);
|
|
96
|
+
}
|
|
97
|
+
var nameExp = new RegExp("(?<!\\.)".concat(currentName), 'g');
|
|
98
|
+
return content.replace(nameExp, newName);
|
|
99
|
+
}
|
|
100
|
+
},
|
|
101
|
+
path: iosFolder,
|
|
102
|
+
options: {
|
|
103
|
+
scanFileContent: true,
|
|
104
|
+
ignore: [
|
|
105
|
+
{
|
|
106
|
+
name: 'GoogleService-Info',
|
|
107
|
+
ext: ['plist'],
|
|
108
|
+
file: true,
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
ext: ['png', 'jpg', 'jpeg'],
|
|
112
|
+
file: true,
|
|
113
|
+
},
|
|
114
|
+
],
|
|
115
|
+
},
|
|
116
|
+
})];
|
|
117
|
+
case 1:
|
|
118
|
+
_a.sent();
|
|
119
|
+
renameQueue.sort(function (a, b) { return a.to.length - b.to.length; });
|
|
120
|
+
renameQueue.forEach(function (i) {
|
|
121
|
+
fs_1.default.renameSync(i.from, i.to);
|
|
122
|
+
});
|
|
123
|
+
pm = firebase_admin_1.default.projectManagement();
|
|
124
|
+
return [4 /*yield*/, pm.listIosApps()];
|
|
125
|
+
case 2:
|
|
126
|
+
iosAppReqs = (_a.sent()).map(function (a) { return __awaiter(_this, void 0, void 0, function () {
|
|
127
|
+
var _a;
|
|
128
|
+
var _b;
|
|
129
|
+
return __generator(this, function (_c) {
|
|
130
|
+
switch (_c.label) {
|
|
131
|
+
case 0:
|
|
132
|
+
_a = [__assign({}, a)];
|
|
133
|
+
_b = {};
|
|
134
|
+
return [4 /*yield*/, a.getMetadata()];
|
|
135
|
+
case 1: return [2 /*return*/, __assign.apply(void 0, _a.concat([(_b.meta = (_c.sent()), _b)]))];
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
}); });
|
|
139
|
+
return [4 /*yield*/, Promise.all(iosAppReqs)];
|
|
140
|
+
case 3:
|
|
141
|
+
iosApps = _a.sent();
|
|
142
|
+
googleServiceFile = path_1.default.join(iosFolder, newName, 'GoogleService-Info.plist');
|
|
143
|
+
if (!!iosApps.some(function (a) { return a.meta.bundleId === newBundleName; })) return [3 /*break*/, 6];
|
|
144
|
+
console.log("Creating new ios app on firebase and updating GoogleService-Info.plist...");
|
|
145
|
+
return [4 /*yield*/, pm.createIosApp(newBundleName, newName.trim())];
|
|
146
|
+
case 4:
|
|
147
|
+
newApp = _a.sent();
|
|
148
|
+
return [4 /*yield*/, newApp.getConfig()];
|
|
149
|
+
case 5:
|
|
150
|
+
newPlistFile = _a.sent();
|
|
151
|
+
fs_1.default.writeFileSync(googleServiceFile, newPlistFile, {
|
|
152
|
+
encoding: 'utf-8',
|
|
153
|
+
});
|
|
154
|
+
_a.label = 6;
|
|
155
|
+
case 6: return [2 /*return*/];
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
exports.renameIos = renameIos;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.getIosAppName = exports.getIosBundleId = void 0;
|
|
7
|
+
var fs_1 = __importDefault(require("fs"));
|
|
8
|
+
var path_1 = __importDefault(require("path"));
|
|
9
|
+
var __1 = require("..");
|
|
10
|
+
var getIosBundleId = function (pbxProjectContent) {
|
|
11
|
+
var pkgStr = 'PRODUCT_BUNDLE_IDENTIFIER =';
|
|
12
|
+
var packageIdx = pbxProjectContent.indexOf(pkgStr) + pkgStr.length;
|
|
13
|
+
var packageName = pbxProjectContent.substring(packageIdx);
|
|
14
|
+
var packageEndIdx = packageName.indexOf(';');
|
|
15
|
+
packageName = packageName.substring(0, packageEndIdx);
|
|
16
|
+
return packageName.trim();
|
|
17
|
+
};
|
|
18
|
+
exports.getIosBundleId = getIosBundleId;
|
|
19
|
+
var getIosAppName = function (pbxProjectContent) {
|
|
20
|
+
// const pkgStr = 'PRODUCT_NAME ='
|
|
21
|
+
// const packageIdx = pbxProjectContent.indexOf(pkgStr) + pkgStr.length
|
|
22
|
+
// let packageName = pbxProjectContent.substring(packageIdx)
|
|
23
|
+
// const packageEndIdx = packageName.indexOf(';')
|
|
24
|
+
// packageName = packageName.substring(0, packageEndIdx)
|
|
25
|
+
// return packageName.trim()
|
|
26
|
+
return JSON.parse(fs_1.default.readFileSync(path_1.default.join(__1.cwd, 'app.json')).toString()).name;
|
|
27
|
+
};
|
|
28
|
+
exports.getIosAppName = getIosAppName;
|
package/dist/lib/spinner.js
CHANGED
|
@@ -51,18 +51,27 @@ exports.spinWhileNotCompleted = void 0;
|
|
|
51
51
|
var nanospinner_1 = require("nanospinner");
|
|
52
52
|
function spinWhileNotCompleted(operation, opts) {
|
|
53
53
|
return __awaiter(this, void 0, void 0, function () {
|
|
54
|
-
var name, others, spinner, result;
|
|
54
|
+
var name, others, spinner, result, e_1;
|
|
55
55
|
return __generator(this, function (_a) {
|
|
56
56
|
switch (_a.label) {
|
|
57
57
|
case 0:
|
|
58
58
|
name = opts.name, others = __rest(opts, ["name"]);
|
|
59
59
|
spinner = (0, nanospinner_1.createSpinner)("".concat(name, "\n"), others);
|
|
60
60
|
spinner.start();
|
|
61
|
-
|
|
61
|
+
_a.label = 1;
|
|
62
62
|
case 1:
|
|
63
|
+
_a.trys.push([1, 3, , 4]);
|
|
64
|
+
return [4 /*yield*/, operation()];
|
|
65
|
+
case 2:
|
|
63
66
|
result = _a.sent();
|
|
64
67
|
spinner.success();
|
|
65
68
|
return [2 /*return*/, result];
|
|
69
|
+
case 3:
|
|
70
|
+
e_1 = _a.sent();
|
|
71
|
+
spinner.error();
|
|
72
|
+
console.error(e_1);
|
|
73
|
+
return [3 /*break*/, 4];
|
|
74
|
+
case 4: return [2 /*return*/];
|
|
66
75
|
}
|
|
67
76
|
});
|
|
68
77
|
});
|