npm package diff
Package: @forge/cli-shared
Versions: 6.7.1-next.2-experimental-611b366 - 6.8.0-next.3
Modified: package/out/apps/create-an-app.js
Index: package/out/apps/create-an-app.js
===================================================================
--- package/out/apps/create-an-app.js
+++ package/out/apps/create-an-app.js
@@ -11,17 +11,20 @@
class CreateAppCommand {
templater;
registerAppCommand;
packageInstaller;
- constructor(templater, registerAppCommand, packageInstaller) {
+ statsig;
+ constructor(templater, registerAppCommand, packageInstaller, statsig) {
this.templater = templater;
this.registerAppCommand = registerAppCommand;
this.packageInstaller = packageInstaller;
+ this.statsig = statsig;
}
- async execute({ name, description, template, directory }) {
+ async execute({ name, description, template, directory, requiredProduct }) {
await this.templater.downloadAndExtract(template, directory);
const result = await this.registerAppCommand.registerApp({ name, description }, directory, {
- shouldPrependAppName: true
+ shouldPrependAppName: true,
+ requiredProduct
});
await this.packageInstaller.install(directory);
return {
analytics: { template, appId: result.id, appName: name },
@@ -34,6 +37,20 @@
throw new NoTemplatesError();
}
return availableTemplates;
}
+ async filterAvailableProducts(products, teamworkGraph, crossContext) {
+ const useTeamworkGraph = await this.statsig.isTeamworkGraphProductSupported();
+ const useCrossProduct = await this.statsig.enableCrossProductAppInstallation();
+ return products.filter((product) => {
+ switch (product) {
+ case teamworkGraph:
+ return useTeamworkGraph;
+ case crossContext:
+ return useCrossProduct;
+ default:
+ return true;
+ }
+ });
+ }
}
exports.CreateAppCommand = CreateAppCommand;
Modified: package/out/graphql/graphql-types.js
Large diffs are not rendered by default.
Modified: package/out/apps/register-app.js
Index: package/out/apps/register-app.js
===================================================================
--- package/out/apps/register-app.js
+++ package/out/apps/register-app.js
@@ -23,9 +23,9 @@
analytics: { appId: result.id, appName: input.name },
environments: result.environments.map((env) => env.key)
};
}
- async registerApp(input, directory, { shouldPrependAppName }) {
+ async registerApp(input, directory, { shouldPrependAppName, requiredProduct }) {
this.logger.info(ui_1.Text.create.taskRegister);
const result = await this.appClient.createApp(input);
await (0, file_system_1.inDirectory)(directory, async () => {
const { modules } = await this.configFile.readConfig();
@@ -36,9 +36,10 @@
}
}
const section = await this.appConfigReader.readConfigSection();
let newAppDetails = {
- id: result.id
+ id: result.id,
+ ...(requiredProduct && { requiredProduct })
};
if (section !== 'invalid' && section !== 'missing') {
newAppDetails = {
...section,
Modified: package/out/ui/text.js
Index: package/out/ui/text.js
===================================================================
--- package/out/ui/text.js
+++ package/out/ui/text.js
@@ -250,9 +250,9 @@
waitTemplates: 'Getting template list...',
promptName: 'Enter a name for your app:',
promptCategory: 'Select a category:',
promptTemplate: 'Select a template:',
- promptProduct: 'Select a product:',
+ promptProduct: 'Select a context:',
taskTemplate: {
title: 'Downloading template',
downloading: (template) => `Downloading ${template} template project...`,
extracting: 'Extracting template'
Modified: package/package.json
Index: package/package.json
===================================================================
--- package/package.json
+++ package/package.json
@@ -1,7 +1,7 @@
{
"name": "@forge/cli-shared",
- "version": "6.7.1-next.2-experimental-611b366",
+ "version": "6.8.0-next.3",
"description": "Common functionality for Forge CLI",
"author": "Atlassian",
"license": "SEE LICENSE IN LICENSE.txt",
"main": "out/index.js",
@@ -11,9 +11,9 @@
"compile": "tsc -b -v",
"generate-graphql-types": "graphql-codegen --config src/graphql/codegen.yml"
},
"dependencies": {
- "@forge/manifest": "8.9.0-next.0-experimental-611b366",
+ "@forge/manifest": "8.9.0-next.0",
"@forge/util": "1.4.8",
"@forge/i18n": "0.0.4",
"@sentry/node": "7.106.0",
"adm-zip": "^0.5.10",
Modified: package/out/apps/create-an-app.d.ts.map
Index: package/out/apps/create-an-app.d.ts.map
===================================================================
--- package/out/apps/create-an-app.d.ts.map
+++ package/out/apps/create-an-app.d.ts.map
@@ -1,1 +1,1 @@
-{"version":3,"file":"create-an-app.d.ts","sourceRoot":"","sources":["../../src/apps/create-an-app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAC7F,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,MAAM,WAAW,qBAAsB,SAAQ,oBAAoB;IACjE,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,gBAAiB,SAAQ,KAAK;;CAI1C;AAED,oBAAY,sBAAsB,GAAG,iBAAiB,GAAG;IACvD,SAAS,EAAE;QACT,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH,CAAC;AAEF,qBAAa,gBAAgB;IAEzB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB;gBAFhB,SAAS,EAAE,SAAS,EACpB,kBAAkB,EAAE,kBAAkB,EACtC,gBAAgB,EAAE,gBAAgB;IAGxC,OAAO,CAAC,EACnB,IAAI,EACJ,WAAW,EACX,QAAQ,EACR,SAAS,EACV,EAAE,qBAAqB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAY7C,qBAAqB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;CAQxD"}
\ No newline at end of file
+{"version":3,"file":"create-an-app.d.ts","sourceRoot":"","sources":["../../src/apps/create-an-app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAC7F,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE5C,MAAM,WAAW,qBAAsB,SAAQ,oBAAoB;IACjE,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,qBAAa,gBAAiB,SAAQ,KAAK;;CAI1C;AAED,oBAAY,sBAAsB,GAAG,iBAAiB,GAAG;IACvD,SAAS,EAAE;QACT,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH,CAAC;AAEF,qBAAa,gBAAgB;IAEzB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IACjC,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAHP,SAAS,EAAE,SAAS,EACpB,kBAAkB,EAAE,kBAAkB,EACtC,gBAAgB,EAAE,gBAAgB,EAClC,OAAO,EAAE,cAAc;IAG7B,OAAO,CAAC,EACnB,IAAI,EACJ,WAAW,EACX,QAAQ,EACR,SAAS,EACT,eAAe,EAChB,EAAE,qBAAqB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAa7C,qBAAqB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAS1C,uBAAuB,CAAC,CAAC,SAAS,MAAM,EACnD,QAAQ,EAAE,CAAC,EAAE,EACb,aAAa,EAAE,CAAC,EAChB,YAAY,EAAE,CAAC,GACd,OAAO,CAAC,CAAC,EAAE,CAAC;CAehB"}
\ No newline at end of file
Modified: package/out/graphql/graphql-types.d.ts.map
Large diffs are not rendered by default.
Modified: package/out/apps/register-app.d.ts.map
Index: package/out/apps/register-app.d.ts.map
===================================================================
--- package/out/apps/register-app.d.ts.map
+++ package/out/apps/register-app.d.ts.map
@@ -1,1 +1,1 @@
-{"version":3,"file":"register-app.d.ts","sourceRoot":"","sources":["../../src/apps/register-app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,mBAAmB,EAAqB,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAExH,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,EAAE,CAAC;CACL;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,KAAK,EAAE,oBAAoB,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;CAClE;AAED,oBAAY,iBAAiB,GAAG;IAC9B,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,EAAE;QACT,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,CAAC;AAEF,qBAAa,kBAAkB;IAE3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAJV,SAAS,EAAE,eAAe,EAC1B,eAAe,EAAE,mBAAmB,CAAC,kBAAkB,CAAC,EACxD,eAAe,EAAE,mBAAmB,CAAC,UAAU,CAAC,EAChD,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,UAAU;IAG5B,OAAO,CAAC,KAAK,EAAE,oBAAoB,EAAE,EAAE,oBAA4B,EAAE;;KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAQvG,WAAW,CACtB,KAAK,EAAE,oBAAoB,EAC3B,SAAS,EAAE,MAAM,EACjB,EAAE,oBAAoB,EAAE,EAAE;QAAE,oBAAoB,EAAE,OAAO,CAAA;KAAE,GAC1D,OAAO,CAAC,eAAe,CAAC;CAgC5B"}
\ No newline at end of file
+{"version":3,"file":"register-app.d.ts","sourceRoot":"","sources":["../../src/apps/register-app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,mBAAmB,EAAqB,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAExH,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,EAAE,CAAC;CACL;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,KAAK,EAAE,oBAAoB,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;CAClE;AAED,oBAAY,iBAAiB,GAAG;IAC9B,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,EAAE;QACT,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,CAAC;AAEF,qBAAa,kBAAkB;IAE3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAJV,SAAS,EAAE,eAAe,EAC1B,eAAe,EAAE,mBAAmB,CAAC,kBAAkB,CAAC,EACxD,eAAe,EAAE,mBAAmB,CAAC,UAAU,CAAC,EAChD,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,UAAU;IAG5B,OAAO,CAAC,KAAK,EAAE,oBAAoB,EAAE,EAAE,oBAA4B,EAAE;;KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAQvG,WAAW,CACtB,KAAK,EAAE,oBAAoB,EAC3B,SAAS,EAAE,MAAM,EACjB,EAAE,oBAAoB,EAAE,eAAe,EAAE,EAAE;QAAE,oBAAoB,EAAE,OAAO,CAAC;QAAC,eAAe,CAAC,EAAE,MAAM,CAAA;KAAE,GACrG,OAAO,CAAC,eAAe,CAAC;CAiC5B"}
\ No newline at end of file
Modified: package/CHANGELOG.md
Large diffs are not rendered by default.
Modified: package/out/apps/create-an-app.d.ts
Index: package/out/apps/create-an-app.d.ts
===================================================================
--- package/out/apps/create-an-app.d.ts
+++ package/out/apps/create-an-app.d.ts
@@ -1,10 +1,12 @@
import { CreateAppClientInput, RegisterAppCommand, RegisterAppResult } from './register-app';
import { Templater } from './template';
import { PackageInstaller } from './package-installer';
+import { StatsigService } from '../service';
export interface CreateAppCommandInput extends CreateAppClientInput {
template: string;
directory: string;
+ requiredProduct?: string;
}
export declare class NoTemplatesError extends Error {
constructor();
}
@@ -16,9 +18,11 @@
export declare class CreateAppCommand {
private readonly templater;
private readonly registerAppCommand;
private readonly packageInstaller;
- constructor(templater: Templater, registerAppCommand: RegisterAppCommand, packageInstaller: PackageInstaller);
- execute({ name, description, template, directory }: CreateAppCommandInput): Promise<CreateAppCommandResult>;
+ private readonly statsig;
+ constructor(templater: Templater, registerAppCommand: RegisterAppCommand, packageInstaller: PackageInstaller, statsig: StatsigService);
+ execute({ name, description, template, directory, requiredProduct }: CreateAppCommandInput): Promise<CreateAppCommandResult>;
getAvailableTemplates(): Promise<string[]>;
+ filterAvailableProducts<T extends string>(products: T[], teamworkGraph: T, crossContext: T): Promise<T[]>;
}
//# sourceMappingURL=create-an-app.d.ts.map
\ No newline at end of file
Modified: package/out/graphql/graphql-types.d.ts
Large diffs are not rendered by default.
Modified: package/out/apps/register-app.d.ts
Index: package/out/apps/register-app.d.ts
===================================================================
--- package/out/apps/register-app.d.ts
+++ package/out/apps/register-app.d.ts
@@ -30,9 +30,10 @@
constructor(appClient: CreateAppClient, appConfigReader: ConfigSectionReader<NO_VALIDATION_TYPE>, appConfigWriter: ConfigSectionWriter<AppDetails>, logger: Logger, configFile: ConfigFile);
execute(input: CreateAppClientInput, { shouldPrependAppName }?: {
shouldPrependAppName?: boolean | undefined;
}): Promise<RegisterAppResult>;
- registerApp(input: CreateAppClientInput, directory: string, { shouldPrependAppName }: {
+ registerApp(input: CreateAppClientInput, directory: string, { shouldPrependAppName, requiredProduct }: {
shouldPrependAppName: boolean;
+ requiredProduct?: string;
}): Promise<CreateAppResult>;
}
//# sourceMappingURL=register-app.d.ts.map
\ No newline at end of file