sfdx-browserforce-plugin 4.2.0 → 4.4.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/bin/run +6 -5
- package/lib/browserforce-command.d.ts +8 -0
- package/lib/browserforce-command.js +32 -63
- package/lib/browserforce-command.js.map +1 -1
- package/lib/browserforce.d.ts +20 -0
- package/lib/browserforce.js +14 -19
- package/lib/browserforce.js.map +1 -1
- package/lib/commands/browserforce/apply.d.ts +10 -0
- package/lib/commands/browserforce/apply.js +15 -20
- package/lib/commands/browserforce/apply.js.map +1 -1
- package/lib/commands/browserforce/plan.d.ts +10 -0
- package/lib/commands/browserforce/plan.js +17 -47
- package/lib/commands/browserforce/plan.js.map +1 -1
- package/lib/config-parser.d.ts +16 -0
- package/lib/config-parser.js +1 -5
- package/lib/config-parser.js.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.js +1 -2
- package/lib/jsforce-utils.d.ts +5 -0
- package/lib/jsforce-utils.js +1 -5
- package/lib/jsforce-utils.js.map +1 -1
- package/lib/pages/login.d.ts +8 -0
- package/lib/pages/login.js +2 -5
- package/lib/pages/login.js.map +1 -1
- package/lib/plugin.d.ts +17 -0
- package/lib/plugin.js +5 -7
- package/lib/plugin.js.map +1 -1
- package/lib/plugins/activity-settings/index.d.ts +9 -0
- package/lib/plugins/activity-settings/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/activity-settings/index.e2e-spec.js +6 -11
- package/lib/plugins/activity-settings/index.e2e-spec.js.map +1 -1
- package/lib/plugins/activity-settings/index.js +2 -6
- package/lib/plugins/activity-settings/index.js.map +1 -1
- package/lib/plugins/communities/index.d.ts +10 -0
- package/lib/plugins/communities/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/communities/index.e2e-spec.js +6 -11
- package/lib/plugins/communities/index.e2e-spec.js.map +1 -1
- package/lib/plugins/communities/index.js +2 -6
- package/lib/plugins/communities/index.js.map +1 -1
- package/lib/plugins/company-information/index.d.ts +8 -0
- package/lib/plugins/company-information/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/company-information/index.e2e-spec.js +6 -11
- package/lib/plugins/company-information/index.e2e-spec.js.map +1 -1
- package/lib/plugins/company-information/index.js +2 -6
- package/lib/plugins/company-information/index.js.map +1 -1
- package/lib/plugins/customer-portal/available-custom-objects/index.d.ts +14 -0
- package/lib/plugins/customer-portal/available-custom-objects/index.js +4 -8
- package/lib/plugins/customer-portal/available-custom-objects/index.js.map +1 -1
- package/lib/plugins/customer-portal/available-custom-objects/index.test.d.ts +1 -0
- package/lib/plugins/customer-portal/available-custom-objects/index.test.js +4 -9
- package/lib/plugins/customer-portal/available-custom-objects/index.test.js.map +1 -1
- package/lib/plugins/customer-portal/enabled/index.d.ts +6 -0
- package/lib/plugins/customer-portal/enabled/index.js +2 -6
- package/lib/plugins/customer-portal/enabled/index.js.map +1 -1
- package/lib/plugins/customer-portal/enabled/index.test.d.ts +1 -0
- package/lib/plugins/customer-portal/enabled/index.test.js +4 -9
- package/lib/plugins/customer-portal/enabled/index.test.js.map +1 -1
- package/lib/plugins/customer-portal/index.d.ts +15 -0
- package/lib/plugins/customer-portal/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/customer-portal/index.e2e-spec.js +25 -51
- package/lib/plugins/customer-portal/index.e2e-spec.js.map +1 -1
- package/lib/plugins/customer-portal/index.js +14 -18
- package/lib/plugins/customer-portal/index.js.map +1 -1
- package/lib/plugins/customer-portal/index.test.d.ts +1 -0
- package/lib/plugins/customer-portal/index.test.js +4 -9
- package/lib/plugins/customer-portal/index.test.js.map +1 -1
- package/lib/plugins/customer-portal/portals/index.d.ts +25 -0
- package/lib/plugins/customer-portal/portals/index.js +6 -33
- package/lib/plugins/customer-portal/portals/index.js.map +1 -1
- package/lib/plugins/customer-portal/portals/index.test.d.ts +1 -0
- package/lib/plugins/customer-portal/portals/index.test.js +4 -9
- package/lib/plugins/customer-portal/portals/index.test.js.map +1 -1
- package/lib/plugins/defer-sharing-calculation/index.d.ts +9 -0
- package/lib/plugins/defer-sharing-calculation/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/defer-sharing-calculation/index.e2e-spec.js +14 -40
- package/lib/plugins/defer-sharing-calculation/index.e2e-spec.js.map +1 -1
- package/lib/plugins/defer-sharing-calculation/index.js +2 -6
- package/lib/plugins/defer-sharing-calculation/index.js.map +1 -1
- package/lib/plugins/density-settings/index.d.ts +17 -0
- package/lib/plugins/density-settings/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/density-settings/index.e2e-spec.js +7 -12
- package/lib/plugins/density-settings/index.e2e-spec.js.map +1 -1
- package/lib/plugins/density-settings/index.js +2 -6
- package/lib/plugins/density-settings/index.js.map +1 -1
- package/lib/plugins/email-deliverability/index.d.ts +9 -0
- package/lib/plugins/email-deliverability/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/email-deliverability/index.e2e-spec.js +8 -13
- package/lib/plugins/email-deliverability/index.e2e-spec.js.map +1 -1
- package/lib/plugins/email-deliverability/index.js +2 -6
- package/lib/plugins/email-deliverability/index.js.map +1 -1
- package/lib/plugins/high-velocity-sales-settings/index.d.ts +10 -0
- package/lib/plugins/high-velocity-sales-settings/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/high-velocity-sales-settings/index.e2e-spec.js +6 -11
- package/lib/plugins/high-velocity-sales-settings/index.e2e-spec.js.map +1 -1
- package/lib/plugins/high-velocity-sales-settings/index.js +5 -10
- package/lib/plugins/high-velocity-sales-settings/index.js.map +1 -1
- package/lib/plugins/high-velocity-sales-settings/page.d.ts +7 -0
- package/lib/plugins/high-velocity-sales-settings/page.js +7 -10
- package/lib/plugins/high-velocity-sales-settings/page.js.map +1 -1
- package/lib/plugins/home-page-layouts/index.d.ts +14 -0
- package/lib/plugins/home-page-layouts/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/home-page-layouts/index.e2e-spec.js +6 -11
- package/lib/plugins/home-page-layouts/index.e2e-spec.js.map +1 -1
- package/lib/plugins/home-page-layouts/index.js +2 -6
- package/lib/plugins/home-page-layouts/index.js.map +1 -1
- package/lib/plugins/home-page-layouts/index.test.d.ts +1 -0
- package/lib/plugins/home-page-layouts/index.test.js +4 -9
- package/lib/plugins/home-page-layouts/index.test.js.map +1 -1
- package/lib/plugins/index.d.ts +21 -0
- package/lib/plugins/index.js +21 -41
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/lightning-experience-settings/index.d.ts +17 -0
- package/lib/plugins/lightning-experience-settings/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/lightning-experience-settings/index.e2e-spec.js +7 -12
- package/lib/plugins/lightning-experience-settings/index.e2e-spec.js.map +1 -1
- package/lib/plugins/lightning-experience-settings/index.js +2 -6
- package/lib/plugins/lightning-experience-settings/index.js.map +1 -1
- package/lib/plugins/linkedin-sales-navigator-settings/index.d.ts +8 -0
- package/lib/plugins/linkedin-sales-navigator-settings/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/linkedin-sales-navigator-settings/index.e2e-spec.js +6 -11
- package/lib/plugins/linkedin-sales-navigator-settings/index.e2e-spec.js.map +1 -1
- package/lib/plugins/linkedin-sales-navigator-settings/index.js +5 -9
- package/lib/plugins/linkedin-sales-navigator-settings/index.js.map +1 -1
- package/lib/plugins/linkedin-sales-navigator-settings/page.d.ts +8 -0
- package/lib/plugins/linkedin-sales-navigator-settings/page.js +4 -7
- package/lib/plugins/linkedin-sales-navigator-settings/page.js.map +1 -1
- package/lib/plugins/opportunity-splits/index.d.ts +9 -0
- package/lib/plugins/opportunity-splits/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/opportunity-splits/index.e2e-spec.js +11 -37
- package/lib/plugins/opportunity-splits/index.e2e-spec.js.map +1 -1
- package/lib/plugins/opportunity-splits/index.js +10 -14
- package/lib/plugins/opportunity-splits/index.js.map +1 -1
- package/lib/plugins/opportunity-splits/pages/layout-selection.d.ts +8 -0
- package/lib/plugins/opportunity-splits/pages/layout-selection.js +5 -8
- package/lib/plugins/opportunity-splits/pages/layout-selection.js.map +1 -1
- package/lib/plugins/opportunity-splits/pages/overview.d.ts +10 -0
- package/lib/plugins/opportunity-splits/pages/overview.js +3 -6
- package/lib/plugins/opportunity-splits/pages/overview.js.map +1 -1
- package/lib/plugins/opportunity-splits/pages/setup.d.ts +8 -0
- package/lib/plugins/opportunity-splits/pages/setup.js +5 -8
- package/lib/plugins/opportunity-splits/pages/setup.js.map +1 -1
- package/lib/plugins/picklists/field-dependencies/index.d.ts +11 -0
- package/lib/plugins/picklists/field-dependencies/index.js +10 -14
- package/lib/plugins/picklists/field-dependencies/index.js.map +1 -1
- package/lib/plugins/picklists/field-dependencies/index.test.d.ts +1 -0
- package/lib/plugins/picklists/field-dependencies/index.test.js +4 -9
- package/lib/plugins/picklists/field-dependencies/index.test.js.map +1 -1
- package/lib/plugins/picklists/field-dependencies/pages.d.ts +14 -0
- package/lib/plugins/picklists/field-dependencies/pages.js +9 -12
- package/lib/plugins/picklists/field-dependencies/pages.js.map +1 -1
- package/lib/plugins/picklists/index.d.ts +23 -0
- package/lib/plugins/picklists/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/picklists/index.e2e-spec.js +30 -52
- package/lib/plugins/picklists/index.e2e-spec.js.map +1 -1
- package/lib/plugins/picklists/index.js +17 -21
- package/lib/plugins/picklists/index.js.map +1 -1
- package/lib/plugins/picklists/pages.d.ts +40 -0
- package/lib/plugins/picklists/pages.js +12 -16
- package/lib/plugins/picklists/pages.js.map +1 -1
- package/lib/plugins/picklists/standard-value-set.d.ts +1 -0
- package/lib/plugins/picklists/standard-value-set.js +3 -10
- package/lib/plugins/picklists/standard-value-set.js.map +1 -1
- package/lib/plugins/record-types/index.d.ts +13 -0
- package/lib/plugins/record-types/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/record-types/index.e2e-spec.js +12 -38
- package/lib/plugins/record-types/index.e2e-spec.js.map +1 -1
- package/lib/plugins/record-types/index.js +4 -8
- package/lib/plugins/record-types/index.js.map +1 -1
- package/lib/plugins/record-types/pages.d.ts +15 -0
- package/lib/plugins/record-types/pages.js +5 -8
- package/lib/plugins/record-types/pages.js.map +1 -1
- package/lib/plugins/relate-contact-to-multiple-accounts/index.d.ts +11 -0
- package/lib/plugins/relate-contact-to-multiple-accounts/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/relate-contact-to-multiple-accounts/index.e2e-spec.js +6 -11
- package/lib/plugins/relate-contact-to-multiple-accounts/index.e2e-spec.js.map +1 -1
- package/lib/plugins/relate-contact-to-multiple-accounts/index.js +5 -9
- package/lib/plugins/relate-contact-to-multiple-accounts/index.js.map +1 -1
- package/lib/plugins/reports-and-dashboards/folder-sharing/index.d.ts +8 -0
- package/lib/plugins/reports-and-dashboards/folder-sharing/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/reports-and-dashboards/folder-sharing/index.e2e-spec.js +1 -1
- package/lib/plugins/reports-and-dashboards/folder-sharing/index.js +2 -6
- package/lib/plugins/reports-and-dashboards/folder-sharing/index.js.map +1 -1
- package/lib/plugins/reports-and-dashboards/index.d.ts +11 -0
- package/lib/plugins/reports-and-dashboards/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/reports-and-dashboards/index.e2e-spec.js +1 -1
- package/lib/plugins/reports-and-dashboards/index.js +6 -10
- package/lib/plugins/reports-and-dashboards/index.js.map +1 -1
- package/lib/plugins/salesforce-cpq-config/index.d.ts +7 -0
- package/lib/plugins/salesforce-cpq-config/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/salesforce-cpq-config/index.e2e-spec.js +37 -0
- package/lib/plugins/salesforce-cpq-config/index.e2e-spec.js.map +1 -0
- package/lib/plugins/salesforce-cpq-config/index.js +185 -0
- package/lib/plugins/salesforce-cpq-config/index.js.map +1 -0
- package/lib/plugins/salesforce-cpq-config/types.d.ts +16 -0
- package/lib/plugins/salesforce-cpq-config/types.js +2 -0
- package/lib/plugins/salesforce-cpq-config/types.js.map +1 -0
- package/lib/plugins/salesforce-to-salesforce/index.d.ts +9 -0
- package/lib/plugins/salesforce-to-salesforce/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/salesforce-to-salesforce/index.e2e-spec.js +6 -11
- package/lib/plugins/salesforce-to-salesforce/index.e2e-spec.js.map +1 -1
- package/lib/plugins/salesforce-to-salesforce/index.js +4 -11
- package/lib/plugins/salesforce-to-salesforce/index.js.map +1 -1
- package/lib/plugins/security/certificate-and-key-management/index.d.ts +23 -0
- package/lib/plugins/security/certificate-and-key-management/index.js +6 -33
- package/lib/plugins/security/certificate-and-key-management/index.js.map +1 -1
- package/lib/plugins/security/certificate-and-key-management/index.test.d.ts +1 -0
- package/lib/plugins/security/certificate-and-key-management/index.test.js +4 -9
- package/lib/plugins/security/certificate-and-key-management/index.test.js.map +1 -1
- package/lib/plugins/security/identity-provider/index.d.ts +9 -0
- package/lib/plugins/security/identity-provider/index.js +5 -32
- package/lib/plugins/security/identity-provider/index.js.map +1 -1
- package/lib/plugins/security/index.d.ts +17 -0
- package/lib/plugins/security/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/security/index.e2e-spec.js +13 -18
- package/lib/plugins/security/index.e2e-spec.js.map +1 -1
- package/lib/plugins/security/index.js +18 -22
- package/lib/plugins/security/index.js.map +1 -1
- package/lib/plugins/security/login-access-policies/index.d.ts +8 -0
- package/lib/plugins/security/login-access-policies/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/security/login-access-policies/index.e2e-spec.js +6 -11
- package/lib/plugins/security/login-access-policies/index.e2e-spec.js.map +1 -1
- package/lib/plugins/security/login-access-policies/index.js +2 -6
- package/lib/plugins/security/login-access-policies/index.js.map +1 -1
- package/lib/plugins/security/sharing/index.d.ts +8 -0
- package/lib/plugins/security/sharing/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/security/sharing/index.e2e-spec.js +6 -11
- package/lib/plugins/security/sharing/index.e2e-spec.js.map +1 -1
- package/lib/plugins/security/sharing/index.js +2 -6
- package/lib/plugins/security/sharing/index.js.map +1 -1
- package/lib/plugins/slack/index.d.ts +9 -0
- package/lib/plugins/slack/index.e2e-spec.d.ts +1 -0
- package/lib/plugins/slack/index.e2e-spec.js +7 -12
- package/lib/plugins/slack/index.e2e-spec.js.map +1 -1
- package/lib/plugins/slack/index.js +2 -6
- package/lib/plugins/slack/index.js.map +1 -1
- package/lib/plugins/utils.d.ts +3 -0
- package/lib/plugins/utils.js +6 -12
- package/lib/plugins/utils.js.map +1 -1
- package/oclif.manifest.json +13 -85
- package/package.json +16 -23
- package/messages/browserforce.json +0 -7
|
@@ -1,31 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.IdentityProvider = void 0;
|
|
27
|
-
const p_retry_1 = __importStar(require("p-retry"));
|
|
28
|
-
const plugin_1 = require("../../../plugin");
|
|
1
|
+
import pRetry, { AbortError } from 'p-retry';
|
|
2
|
+
import { BrowserforcePlugin } from '../../../plugin.js';
|
|
29
3
|
const PATHS = {
|
|
30
4
|
EDIT_VIEW: 'setup/secur/idp/IdpPage.apexp'
|
|
31
5
|
};
|
|
@@ -36,7 +10,7 @@ const SELECTORS = {
|
|
|
36
10
|
EDIT_BUTTON: 'input[name$=":edit"]',
|
|
37
11
|
SAVE_BUTTON: 'input[name$=":save"]'
|
|
38
12
|
};
|
|
39
|
-
class IdentityProvider extends
|
|
13
|
+
export class IdentityProvider extends BrowserforcePlugin {
|
|
40
14
|
async retrieve() {
|
|
41
15
|
const page = await this.browserforce.openPage(PATHS.EDIT_VIEW);
|
|
42
16
|
await page.waitForSelector(SELECTORS.EDIT_BUTTON);
|
|
@@ -56,12 +30,12 @@ class IdentityProvider extends plugin_1.BrowserforcePlugin {
|
|
|
56
30
|
if (plan.enabled && plan.certificate && plan.certificate !== '') {
|
|
57
31
|
// enable with required certificate
|
|
58
32
|
// wait for cert to become available in Identity Provider UI
|
|
59
|
-
await (
|
|
33
|
+
await pRetry(async () => {
|
|
60
34
|
const certsResponse = await this.org
|
|
61
35
|
.getConnection()
|
|
62
36
|
.tooling.query(`SELECT Id, DeveloperName FROM Certificate WHERE DeveloperName = '${plan.certificate}'`);
|
|
63
37
|
if (!certsResponse.totalSize) {
|
|
64
|
-
throw new
|
|
38
|
+
throw new AbortError(`Could not find Certificate '${plan.certificate}'`);
|
|
65
39
|
}
|
|
66
40
|
const page = await this.browserforce.openPage(PATHS.EDIT_VIEW);
|
|
67
41
|
await page.waitForSelector(SELECTORS.EDIT_BUTTON);
|
|
@@ -104,5 +78,4 @@ class IdentityProvider extends plugin_1.BrowserforcePlugin {
|
|
|
104
78
|
}
|
|
105
79
|
}
|
|
106
80
|
}
|
|
107
|
-
exports.IdentityProvider = IdentityProvider;
|
|
108
81
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/identity-provider/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/identity-provider/index.ts"],"names":[],"mappings":"AACA,OAAO,MAAM,EAAE,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExD,MAAM,KAAK,GAAG;IACZ,SAAS,EAAE,+BAA+B;CAC3C,CAAC;AACF,MAAM,SAAS,GAAG;IAChB,WAAW,EAAE,2BAA2B;IACxC,cAAc,EAAE,4BAA4B;IAC5C,cAAc,EAAE,yBAAyB;IACzC,WAAW,EAAE,sBAAsB;IACnC,WAAW,EAAE,sBAAsB;CACpC,CAAC;AAYF,MAAM,OAAO,gBAAiB,SAAQ,kBAAkB;IAC/C,KAAK,CAAC,QAAQ;QACnB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC/D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAClD,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QAC7D,MAAM,OAAO,GAAG,aAAa,KAAK,IAAI,CAAC;QACvC,MAAM,QAAQ,GAAW;YACvB,OAAO;SACR,CAAC;QACF,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YAC9D,QAAQ,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAqB,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;QACxG,CAAC;QACD,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,IAAY;QAC7B,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,KAAK,EAAE,EAAE,CAAC;YAChE,mCAAmC;YACnC,4DAA4D;YAC5D,MAAM,MAAM,CACV,KAAK,IAAI,EAAE;gBACT,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,GAAG;qBACjC,aAAa,EAAE;qBACf,OAAO,CAAC,KAAK,CACZ,oEAAoE,IAAI,CAAC,WAAW,GAAG,CACxF,CAAC;gBACJ,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;oBAC7B,MAAM,IAAI,UAAU,CAAC,+BAA+B,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;gBAC3E,CAAC;gBACD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAC/D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;gBAClD,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjF,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;gBAClD,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,MAAM,CACzC,GAAG,SAAS,CAAC,WAAW,SAAS,EACjC,CAAC,OAA4B,EAAE,EAAE;oBAC/B,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;wBAC5B,OAAO;4BACL,IAAI,EAAE,MAAM,CAAC,IAAI;4BACjB,KAAK,EAAE,MAAM,CAAC,KAAK;yBACpB,CAAC;oBACJ,CAAC,CAAC,CAAC;gBACL,CAAC,CACF,CAAC;gBACF,MAAM,gBAAgB,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,WAAW,CAAC,CAAC;gBACpF,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACtB,MAAM,IAAI,KAAK,CACb,4BAA4B,IAAI,CAAC,WAAW,2DAA2D,CACxG,CAAC;gBACJ,CAAC;gBACD,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,WAAW,EAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACjE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;oBACjC,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;gBACxB,CAAC,CAAC,CAAC;gBACH,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;gBAClD,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjF,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YACrB,CAAC,EACD;gBACE,OAAO,EAAE,CAAC;gBACV,UAAU,EAAE,CAAC,GAAG,IAAI;aACrB,CACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,UAAU;YACV,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC/D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;YAClD,MAAM,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YACvC,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;gBACjC,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;YACxB,CAAC,CAAC,CAAC;YACH,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;YACpF,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { BrowserforcePlugin } from '../../plugin.js';
|
|
2
|
+
import { Config as CertificateAndKeyManagementConfig } from './certificate-and-key-management/index.js';
|
|
3
|
+
import { Config as IdentityProviderConfig } from './identity-provider/index.js';
|
|
4
|
+
import { Config as LoginAccessPoliciesConfig } from './login-access-policies/index.js';
|
|
5
|
+
import { Config as SharingConfig } from './sharing/index.js';
|
|
6
|
+
type Config = {
|
|
7
|
+
certificateAndKeyManagement?: CertificateAndKeyManagementConfig;
|
|
8
|
+
identityProvider?: IdentityProviderConfig;
|
|
9
|
+
loginAccessPolicies?: LoginAccessPoliciesConfig;
|
|
10
|
+
sharing?: SharingConfig;
|
|
11
|
+
};
|
|
12
|
+
export declare class Security extends BrowserforcePlugin {
|
|
13
|
+
retrieve(definition?: Config): Promise<Config>;
|
|
14
|
+
diff(state: Config, definition: Config): Config | undefined;
|
|
15
|
+
apply(plan: Config): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,18 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
const core_1 = require("@salesforce/core");
|
|
7
|
-
const assert_1 = __importDefault(require("assert"));
|
|
8
|
-
const certificate_and_key_management_1 = require("./certificate-and-key-management");
|
|
9
|
-
const identity_provider_1 = require("./identity-provider");
|
|
10
|
-
describe(`${certificate_and_key_management_1.CertificateAndKeyManagement.name} and ${identity_provider_1.IdentityProvider.name}`, function () {
|
|
1
|
+
import { Org } from '@salesforce/core';
|
|
2
|
+
import assert from 'assert';
|
|
3
|
+
import { CertificateAndKeyManagement } from './certificate-and-key-management/index.js';
|
|
4
|
+
import { IdentityProvider } from './identity-provider/index.js';
|
|
5
|
+
describe(`${CertificateAndKeyManagement.name} and ${IdentityProvider.name}`, function () {
|
|
11
6
|
let pluginIdentityProvider;
|
|
12
7
|
let pluginCertificateManagement;
|
|
13
8
|
before(() => {
|
|
14
|
-
pluginIdentityProvider = new
|
|
15
|
-
pluginCertificateManagement = new
|
|
9
|
+
pluginIdentityProvider = new IdentityProvider(global.bf);
|
|
10
|
+
pluginCertificateManagement = new CertificateAndKeyManagement(global.bf);
|
|
16
11
|
});
|
|
17
12
|
const configEnabled = {
|
|
18
13
|
enabled: true,
|
|
@@ -45,7 +40,7 @@ describe(`${certificate_and_key_management_1.CertificateAndKeyManagement.name} a
|
|
|
45
40
|
catch (e) {
|
|
46
41
|
err = e;
|
|
47
42
|
}
|
|
48
|
-
|
|
43
|
+
assert.throws(() => {
|
|
49
44
|
throw err;
|
|
50
45
|
}, /Could not find Certificate 'identity_provider'/);
|
|
51
46
|
});
|
|
@@ -55,31 +50,31 @@ describe(`${certificate_and_key_management_1.CertificateAndKeyManagement.name} a
|
|
|
55
50
|
it('should not do anything if self-signed certificate is already available', async () => {
|
|
56
51
|
// explictly pass definition to retrieve
|
|
57
52
|
const res = await pluginCertificateManagement.run(configGeneratedCert);
|
|
58
|
-
|
|
53
|
+
assert.deepStrictEqual(res, { message: 'no action necessary' });
|
|
59
54
|
});
|
|
60
55
|
it('should enable Identity Provider with generated cert', async () => {
|
|
61
56
|
await pluginIdentityProvider.apply(configEnabled);
|
|
62
57
|
});
|
|
63
58
|
it('Identity Provider should be enabled', async () => {
|
|
64
59
|
const state = await pluginIdentityProvider.retrieve();
|
|
65
|
-
|
|
60
|
+
assert.deepStrictEqual(state.enabled, true);
|
|
66
61
|
});
|
|
67
62
|
it('should disable Identity Provider', async () => {
|
|
68
63
|
await pluginIdentityProvider.apply(configDisabled);
|
|
69
64
|
});
|
|
70
65
|
it('Identity Provider should be disabled', async () => {
|
|
71
66
|
const state = await pluginIdentityProvider.retrieve();
|
|
72
|
-
|
|
67
|
+
assert.deepStrictEqual(state.enabled, false);
|
|
73
68
|
});
|
|
74
69
|
it('should import a cert from a keystore', async () => {
|
|
75
70
|
await pluginCertificateManagement.run(configImportFromKeystore);
|
|
76
71
|
});
|
|
77
72
|
it('should not do anything if cert is already available in keystore', async () => {
|
|
78
73
|
const res = await pluginCertificateManagement.run(configImportFromKeystore);
|
|
79
|
-
|
|
74
|
+
assert.deepStrictEqual(res, { message: 'no action necessary' });
|
|
80
75
|
});
|
|
81
76
|
it('should delete certificates using Metadata API', async () => {
|
|
82
|
-
const org = await
|
|
77
|
+
const org = await Org.create({});
|
|
83
78
|
const conn = org.getConnection();
|
|
84
79
|
await conn.metadata.delete('Certificate', ['identity_provider', 'Dummy']);
|
|
85
80
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../src/plugins/security/index.e2e-spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../src/plugins/security/index.e2e-spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,39 +1,36 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const login_access_policies_1 = require("./login-access-policies");
|
|
8
|
-
const sharing_1 = require("./sharing");
|
|
9
|
-
class Security extends plugin_1.BrowserforcePlugin {
|
|
1
|
+
import { BrowserforcePlugin } from '../../plugin.js';
|
|
2
|
+
import { CertificateAndKeyManagement } from './certificate-and-key-management/index.js';
|
|
3
|
+
import { IdentityProvider } from './identity-provider/index.js';
|
|
4
|
+
import { LoginAccessPolicies } from './login-access-policies/index.js';
|
|
5
|
+
import { Sharing } from './sharing/index.js';
|
|
6
|
+
export class Security extends BrowserforcePlugin {
|
|
10
7
|
async retrieve(definition) {
|
|
11
8
|
const response = {};
|
|
12
9
|
if (definition) {
|
|
13
10
|
if (definition.certificateAndKeyManagement) {
|
|
14
|
-
const pluginCKM = new
|
|
11
|
+
const pluginCKM = new CertificateAndKeyManagement(this.browserforce);
|
|
15
12
|
response.certificateAndKeyManagement = await pluginCKM.retrieve(definition.certificateAndKeyManagement);
|
|
16
13
|
}
|
|
17
14
|
if (definition.identityProvider) {
|
|
18
|
-
const pluginIdentityProvider = new
|
|
15
|
+
const pluginIdentityProvider = new IdentityProvider(this.browserforce);
|
|
19
16
|
response.identityProvider = await pluginIdentityProvider.retrieve();
|
|
20
17
|
}
|
|
21
18
|
if (definition.loginAccessPolicies) {
|
|
22
|
-
const pluginLoginAccessPolicies = new
|
|
19
|
+
const pluginLoginAccessPolicies = new LoginAccessPolicies(this.browserforce);
|
|
23
20
|
response.loginAccessPolicies = await pluginLoginAccessPolicies.retrieve();
|
|
24
21
|
}
|
|
25
22
|
if (definition.sharing) {
|
|
26
|
-
const pluginSharing = new
|
|
23
|
+
const pluginSharing = new Sharing(this.browserforce);
|
|
27
24
|
response.sharing = await pluginSharing.retrieve();
|
|
28
25
|
}
|
|
29
26
|
}
|
|
30
27
|
return response;
|
|
31
28
|
}
|
|
32
29
|
diff(state, definition) {
|
|
33
|
-
const certificateAndKeyManagement = new
|
|
34
|
-
const identityProvider = new
|
|
35
|
-
const loginAccessPolicies = new
|
|
36
|
-
const sharing = new
|
|
30
|
+
const certificateAndKeyManagement = new CertificateAndKeyManagement(this.browserforce).diff(state.certificateAndKeyManagement, definition.certificateAndKeyManagement);
|
|
31
|
+
const identityProvider = new IdentityProvider(this.browserforce).diff(state.identityProvider, definition.identityProvider);
|
|
32
|
+
const loginAccessPolicies = new LoginAccessPolicies(this.browserforce).diff(state.loginAccessPolicies, definition.loginAccessPolicies);
|
|
33
|
+
const sharing = new Sharing(this.browserforce).diff(state.sharing, definition.sharing);
|
|
37
34
|
const response = {};
|
|
38
35
|
if (certificateAndKeyManagement !== undefined) {
|
|
39
36
|
response.certificateAndKeyManagement = certificateAndKeyManagement;
|
|
@@ -54,22 +51,21 @@ class Security extends plugin_1.BrowserforcePlugin {
|
|
|
54
51
|
}
|
|
55
52
|
async apply(plan) {
|
|
56
53
|
if (plan.certificateAndKeyManagement) {
|
|
57
|
-
const pluginCKM = new
|
|
54
|
+
const pluginCKM = new CertificateAndKeyManagement(this.browserforce);
|
|
58
55
|
await pluginCKM.apply(plan.certificateAndKeyManagement);
|
|
59
56
|
}
|
|
60
57
|
if (plan.identityProvider) {
|
|
61
|
-
const pluginIdentityProvider = new
|
|
58
|
+
const pluginIdentityProvider = new IdentityProvider(this.browserforce);
|
|
62
59
|
await pluginIdentityProvider.apply(plan.identityProvider);
|
|
63
60
|
}
|
|
64
61
|
if (plan.loginAccessPolicies) {
|
|
65
|
-
const pluginLoginAccessPolicies = new
|
|
62
|
+
const pluginLoginAccessPolicies = new LoginAccessPolicies(this.browserforce);
|
|
66
63
|
await pluginLoginAccessPolicies.apply(plan.loginAccessPolicies);
|
|
67
64
|
}
|
|
68
65
|
if (plan.sharing) {
|
|
69
|
-
const pluginSharing = new
|
|
66
|
+
const pluginSharing = new Sharing(this.browserforce);
|
|
70
67
|
await pluginSharing.apply(plan.sharing);
|
|
71
68
|
}
|
|
72
69
|
}
|
|
73
70
|
}
|
|
74
|
-
exports.Security = Security;
|
|
75
71
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/security/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/security/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EACL,2BAA2B,EAE5B,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAoC,MAAM,8BAA8B,CAAC;AAClG,OAAO,EAAE,mBAAmB,EAAuC,MAAM,kCAAkC,CAAC;AAC5G,OAAO,EAAE,OAAO,EAA2B,MAAM,oBAAoB,CAAC;AAStE,MAAM,OAAO,QAAS,SAAQ,kBAAkB;IACvC,KAAK,CAAC,QAAQ,CAAC,UAAmB;QACvC,MAAM,QAAQ,GAAW,EAAE,CAAC;QAC5B,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,UAAU,CAAC,2BAA2B,EAAE,CAAC;gBAC3C,MAAM,SAAS,GAAG,IAAI,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACrE,QAAQ,CAAC,2BAA2B,GAAG,MAAM,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,2BAA2B,CAAC,CAAC;YAC1G,CAAC;YACD,IAAI,UAAU,CAAC,gBAAgB,EAAE,CAAC;gBAChC,MAAM,sBAAsB,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACvE,QAAQ,CAAC,gBAAgB,GAAG,MAAM,sBAAsB,CAAC,QAAQ,EAAE,CAAC;YACtE,CAAC;YACD,IAAI,UAAU,CAAC,mBAAmB,EAAE,CAAC;gBACnC,MAAM,yBAAyB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC7E,QAAQ,CAAC,mBAAmB,GAAG,MAAM,yBAAyB,CAAC,QAAQ,EAAE,CAAC;YAC5E,CAAC;YACD,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;gBACvB,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACrD,QAAQ,CAAC,OAAO,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,CAAC;YACpD,CAAC;QACH,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,IAAI,CAAC,KAAa,EAAE,UAAkB;QAC3C,MAAM,2BAA2B,GAAG,IAAI,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CACzF,KAAK,CAAC,2BAA2B,EACjC,UAAU,CAAC,2BAA2B,CACvC,CAAC;QACF,MAAM,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CACnE,KAAK,CAAC,gBAAgB,EACtB,UAAU,CAAC,gBAAgB,CACU,CAAC;QACxC,MAAM,mBAAmB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CACzE,KAAK,CAAC,mBAAmB,EACzB,UAAU,CAAC,mBAAmB,CACU,CAAC;QAC3C,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAA8B,CAAC;QACpH,MAAM,QAAQ,GAAW,EAAE,CAAC;QAC5B,IAAI,2BAA2B,KAAK,SAAS,EAAE,CAAC;YAC9C,QAAQ,CAAC,2BAA2B,GAAG,2BAA2B,CAAC;QACrE,CAAC;QACD,IAAI,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACnC,QAAQ,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC/C,CAAC;QACD,IAAI,mBAAmB,KAAK,SAAS,EAAE,CAAC;YACtC,QAAQ,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QACrD,CAAC;QACD,IAAI,mBAAmB,KAAK,SAAS,EAAE,CAAC;YACtC,QAAQ,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QACrD,CAAC;QACD,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAC1B,QAAQ,CAAC,OAAO,GAAG,OAAO,CAAC;QAC7B,CAAC;QACD,OAAO,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7D,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,IAAY;QAC7B,IAAI,IAAI,CAAC,2BAA2B,EAAE,CAAC;YACrC,MAAM,SAAS,GAAG,IAAI,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACrE,MAAM,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,MAAM,sBAAsB,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACvE,MAAM,sBAAsB,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC5D,CAAC;QACD,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC7B,MAAM,yBAAyB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC7E,MAAM,yBAAyB,CAAC,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAClE,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACrD,MAAM,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BrowserforcePlugin } from '../../../plugin.js';
|
|
2
|
+
export type Config = {
|
|
3
|
+
administratorsCanLogInAsAnyUser: boolean;
|
|
4
|
+
};
|
|
5
|
+
export declare class LoginAccessPolicies extends BrowserforcePlugin {
|
|
6
|
+
retrieve(): Promise<Config>;
|
|
7
|
+
apply(config: Config): Promise<void>;
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,14 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const assert_1 = __importDefault(require("assert"));
|
|
7
|
-
const _1 = require(".");
|
|
8
|
-
describe(_1.LoginAccessPolicies.name, function () {
|
|
1
|
+
import assert from 'assert';
|
|
2
|
+
import { LoginAccessPolicies } from './index.js';
|
|
3
|
+
describe(LoginAccessPolicies.name, function () {
|
|
9
4
|
let plugin;
|
|
10
5
|
before(() => {
|
|
11
|
-
plugin = new
|
|
6
|
+
plugin = new LoginAccessPolicies(global.bf);
|
|
12
7
|
});
|
|
13
8
|
describe('administratorsCanLogInAsAnyUser', () => {
|
|
14
9
|
const configDisabled = { administratorsCanLogInAsAnyUser: false };
|
|
@@ -18,14 +13,14 @@ describe(_1.LoginAccessPolicies.name, function () {
|
|
|
18
13
|
});
|
|
19
14
|
it('should be enabled', async () => {
|
|
20
15
|
const res = await plugin.retrieve();
|
|
21
|
-
|
|
16
|
+
assert.deepStrictEqual(res, configEnabled);
|
|
22
17
|
});
|
|
23
18
|
it('should disable', async () => {
|
|
24
19
|
await plugin.apply(configDisabled);
|
|
25
20
|
});
|
|
26
21
|
it('should be disabled', async () => {
|
|
27
22
|
const res = await plugin.retrieve();
|
|
28
|
-
|
|
23
|
+
assert.deepStrictEqual(res, configDisabled);
|
|
29
24
|
});
|
|
30
25
|
});
|
|
31
26
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../../src/plugins/security/login-access-policies/index.e2e-spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../../src/plugins/security/login-access-policies/index.e2e-spec.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAe,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAE9D,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE;IACjC,IAAI,MAA2B,CAAC;IAChC,MAAM,CAAC,GAAG,EAAE;QACV,MAAM,GAAG,IAAI,mBAAmB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC/C,MAAM,cAAc,GAAW,EAAE,+BAA+B,EAAE,KAAK,EAAE,CAAC;QAC1E,MAAM,aAAa,GAAW,EAAE,+BAA+B,EAAE,IAAI,EAAE,CAAC;QAExE,EAAE,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;YAC7B,MAAM,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;YACjC,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,CAAC,eAAe,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;YAC9B,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;YAClC,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,CAAC,eAAe,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LoginAccessPolicies = void 0;
|
|
4
|
-
const plugin_1 = require("../../../plugin");
|
|
1
|
+
import { BrowserforcePlugin } from '../../../plugin.js';
|
|
5
2
|
const PATHS = {
|
|
6
3
|
BASE: 'partnerbt/loginAccessPolicies.apexp'
|
|
7
4
|
};
|
|
@@ -10,7 +7,7 @@ const SELECTORS = {
|
|
|
10
7
|
CONFIRM_MESSAGE: '.message.confirmM3',
|
|
11
8
|
SAVE_BUTTON: 'input[id$=":save"]'
|
|
12
9
|
};
|
|
13
|
-
class LoginAccessPolicies extends
|
|
10
|
+
export class LoginAccessPolicies extends BrowserforcePlugin {
|
|
14
11
|
async retrieve() {
|
|
15
12
|
const page = await this.browserforce.openPage(PATHS.BASE);
|
|
16
13
|
await page.waitForSelector(SELECTORS.ENABLED);
|
|
@@ -30,5 +27,4 @@ class LoginAccessPolicies extends plugin_1.BrowserforcePlugin {
|
|
|
30
27
|
await page.close();
|
|
31
28
|
}
|
|
32
29
|
}
|
|
33
|
-
exports.LoginAccessPolicies = LoginAccessPolicies;
|
|
34
30
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/login-access-policies/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/login-access-policies/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExD,MAAM,KAAK,GAAG;IACZ,IAAI,EAAE,qCAAqC;CAC5C,CAAC;AACF,MAAM,SAAS,GAAG;IAChB,OAAO,EAAE,kCAAkC;IAC3C,eAAe,EAAE,oBAAoB;IACrC,WAAW,EAAE,oBAAoB;CAClC,CAAC;AAMF,MAAM,OAAO,mBAAoB,SAAQ,kBAAkB;IAClD,KAAK,CAAC,QAAQ;QACnB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC9C,MAAM,QAAQ,GAAG;YACf,+BAA+B,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,EAAoB,EAAE,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC;SAC3G,CAAC;QACF,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,MAAc;QAC/B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC9C,MAAM,IAAI,CAAC,KAAK,CACd,SAAS,CAAC,OAAO,EACjB,CAAC,CAAmB,EAAE,CAAU,EAAE,EAAE;YAClC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC;QAChB,CAAC,EACD,MAAM,CAAC,+BAA+B,CACvC,CAAC;QACF,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACxG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,14 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const assert_1 = __importDefault(require("assert"));
|
|
7
|
-
const _1 = require(".");
|
|
8
|
-
describe.skip(_1.Sharing.name, function () {
|
|
1
|
+
import assert from 'assert';
|
|
2
|
+
import { Sharing } from './index.js';
|
|
3
|
+
describe.skip(Sharing.name, function () {
|
|
9
4
|
let plugin;
|
|
10
5
|
before(() => {
|
|
11
|
-
plugin = new
|
|
6
|
+
plugin = new Sharing(global.bf);
|
|
12
7
|
});
|
|
13
8
|
const configEnabled = {
|
|
14
9
|
enableExternalSharingModel: true
|
|
@@ -21,14 +16,14 @@ describe.skip(_1.Sharing.name, function () {
|
|
|
21
16
|
});
|
|
22
17
|
it('should be enabled', async () => {
|
|
23
18
|
const state = await plugin.retrieve();
|
|
24
|
-
|
|
19
|
+
assert.deepStrictEqual(state, configEnabled);
|
|
25
20
|
});
|
|
26
21
|
it('should disable', async () => {
|
|
27
22
|
await plugin.apply(configDisabled);
|
|
28
23
|
});
|
|
29
24
|
it('should be disabled', async () => {
|
|
30
25
|
const state = await plugin.retrieve();
|
|
31
|
-
|
|
26
|
+
assert.deepStrictEqual(state, configDisabled);
|
|
32
27
|
});
|
|
33
28
|
});
|
|
34
29
|
//# sourceMappingURL=index.e2e-spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../../src/plugins/security/sharing/index.e2e-spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../../src/plugins/security/sharing/index.e2e-spec.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAErC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;IAC1B,IAAI,MAAe,CAAC;IACpB,MAAM,CAAC,GAAG,EAAE;QACV,MAAM,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG;QACpB,0BAA0B,EAAE,IAAI;KACjC,CAAC;IACF,MAAM,cAAc,GAAG;QACrB,0BAA0B,EAAE,IAAI;KACjC,CAAC;IAEF,EAAE,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;QAC7B,MAAM,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;QACjC,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;QAC9B,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QAClC,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,CAAC,eAAe,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Sharing = void 0;
|
|
4
|
-
const plugin_1 = require("../../../plugin");
|
|
1
|
+
import { BrowserforcePlugin } from '../../../plugin.js';
|
|
5
2
|
const PATHS = {
|
|
6
3
|
BASE: 'p/own/OrgSharingDetail'
|
|
7
4
|
};
|
|
@@ -11,7 +8,7 @@ const SELECTORS = {
|
|
|
11
8
|
DISABLE_BUTTON: 'input#externalSharingModelButton[onclick*="Modal.confirm"]',
|
|
12
9
|
MODAL_DIALOG: 'Modal.confirm'
|
|
13
10
|
};
|
|
14
|
-
class Sharing extends
|
|
11
|
+
export class Sharing extends BrowserforcePlugin {
|
|
15
12
|
async retrieve() {
|
|
16
13
|
const page = await this.browserforce.openPage(PATHS.BASE);
|
|
17
14
|
await page.waitForSelector(SELECTORS.EXTERNAL_SHARING_MODEL_BUTTON);
|
|
@@ -36,5 +33,4 @@ class Sharing extends plugin_1.BrowserforcePlugin {
|
|
|
36
33
|
await page.close();
|
|
37
34
|
}
|
|
38
35
|
}
|
|
39
|
-
exports.Sharing = Sharing;
|
|
40
36
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/sharing/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/plugins/security/sharing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExD,MAAM,KAAK,GAAG;IACZ,IAAI,EAAE,wBAAwB;CAC/B,CAAC;AACF,MAAM,SAAS,GAAG;IAChB,6BAA6B,EAAE,6BAA6B;IAC5D,aAAa,EAAE,kEAAkE;IACjF,cAAc,EAAE,4DAA4D;IAC5E,YAAY,EAAE,eAAe;CAC9B,CAAC;AAMF,MAAM,OAAO,OAAQ,SAAQ,kBAAkB;IACtC,KAAK,CAAC,QAAQ;QACnB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAC;QACpE,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,KAAK,CACpC,SAAS,CAAC,6BAA6B,EACvC,CAAC,EAAoB,EAAE,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CACvD,CAAC;QACF,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO;YACL,0BAA0B,EAAE,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,YAAY,CAAC;SAC3E,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,MAAc;QAC/B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAC;QACpE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;YACjC,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;QACH,IAAI,MAAM,CAAC,0BAA0B,EAAE,CAAC;YACtC,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QAC3G,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QAC3G,CAAC;QACD,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BrowserforcePlugin } from '../../plugin.js';
|
|
2
|
+
export type Config = {
|
|
3
|
+
agreeToTermsAndConditions: boolean;
|
|
4
|
+
enableSalesCloudForSlack: boolean;
|
|
5
|
+
};
|
|
6
|
+
export declare class Slack extends BrowserforcePlugin {
|
|
7
|
+
retrieve(definition?: Config): Promise<Config>;
|
|
8
|
+
apply(config: Config): Promise<void>;
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,14 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const assert_1 = __importDefault(require("assert"));
|
|
7
|
-
const _1 = require(".");
|
|
8
|
-
describe(_1.Slack.name, function () {
|
|
1
|
+
import assert from 'assert';
|
|
2
|
+
import { Slack } from './index.js';
|
|
3
|
+
describe(Slack.name, function () {
|
|
9
4
|
let plugin;
|
|
10
5
|
before(() => {
|
|
11
|
-
plugin = new
|
|
6
|
+
plugin = new Slack(global.bf);
|
|
12
7
|
});
|
|
13
8
|
const configEnable = {
|
|
14
9
|
agreeToTermsAndConditions: true,
|
|
@@ -27,14 +22,14 @@ describe(_1.Slack.name, function () {
|
|
|
27
22
|
});
|
|
28
23
|
it('should already be accepted', async () => {
|
|
29
24
|
const res = await plugin.run(configEnable);
|
|
30
|
-
|
|
25
|
+
assert.deepStrictEqual(res, { message: 'no action necessary' });
|
|
31
26
|
});
|
|
32
27
|
it('should disable Sales Cloud for Slack', async () => {
|
|
33
28
|
await plugin.run(configDisabledSalesCloud);
|
|
34
29
|
});
|
|
35
30
|
it('should already be disabled', async () => {
|
|
36
31
|
const res = await plugin.run(configDisabledSalesCloud);
|
|
37
|
-
|
|
32
|
+
assert.deepStrictEqual(res, { message: 'no action necessary' });
|
|
38
33
|
});
|
|
39
34
|
it('should fail to unaccept terms and conditions', async () => {
|
|
40
35
|
let err;
|
|
@@ -44,7 +39,7 @@ describe(_1.Slack.name, function () {
|
|
|
44
39
|
catch (e) {
|
|
45
40
|
err = e;
|
|
46
41
|
}
|
|
47
|
-
|
|
42
|
+
assert.throws(() => {
|
|
48
43
|
throw err;
|
|
49
44
|
}, /cannot be unaccepted/);
|
|
50
45
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../src/plugins/slack/index.e2e-spec.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.e2e-spec.js","sourceRoot":"","sources":["../../../src/plugins/slack/index.e2e-spec.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAe,KAAK,EAAE,MAAM,YAAY,CAAC;AAEhD,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE;IACnB,IAAI,MAAa,CAAC;IAClB,MAAM,CAAC,GAAG,EAAE;QACV,MAAM,GAAG,IAAI,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,MAAM,YAAY,GAAW;QAC3B,yBAAyB,EAAE,IAAI;QAC/B,wBAAwB,EAAE,IAAI;KAC/B,CAAC;IACF,MAAM,wBAAwB,GAAW;QACvC,yBAAyB,EAAE,IAAI;QAC/B,wBAAwB,EAAE,KAAK;KAChC,CAAC;IACF,MAAM,cAAc,GAAW;QAC7B,yBAAyB,EAAE,KAAK;QAChC,wBAAwB,EAAE,KAAK;KAChC,CAAC;IACF,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC3C,MAAM,CAAC,eAAe,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,MAAM,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;QACvD,MAAM,CAAC,eAAe,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,IAAI,GAAG,CAAC;QACR,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,GAAG,GAAG,CAAC,CAAC;QACV,CAAC;QACD,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;YACjB,MAAM,GAAG,CAAC;QACZ,CAAC,EAAE,sBAAsB,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Slack = void 0;
|
|
4
|
-
const plugin_1 = require("../../plugin");
|
|
1
|
+
import { BrowserforcePlugin } from '../../plugin.js';
|
|
5
2
|
const PATHS = {
|
|
6
3
|
BASE: 'lightning/setup/SlackSetupAssistant/home'
|
|
7
4
|
};
|
|
@@ -10,7 +7,7 @@ const SELECTORS = {
|
|
|
10
7
|
SALES_CLOUD_FOR_SLACK_TOGGLE: 'pierce/setup_service-slack-setup-assistant-container setup_service-stage setup_service-steps setup_service-step lightning-input:has(lightning-primitive-input-toggle input[name="SlkSetupStepSalesCloudForSlack"])',
|
|
11
8
|
TOAST_MESSAGE: 'div[id^="toastDescription"]'
|
|
12
9
|
};
|
|
13
|
-
class Slack extends
|
|
10
|
+
export class Slack extends BrowserforcePlugin {
|
|
14
11
|
async retrieve(definition) {
|
|
15
12
|
const page = await this.browserforce.openPage(PATHS.BASE);
|
|
16
13
|
await page.waitForSelector(SELECTORS.TOS_LIGHTNING_INPUT, { visible: true });
|
|
@@ -44,5 +41,4 @@ class Slack extends plugin_1.BrowserforcePlugin {
|
|
|
44
41
|
await page.close();
|
|
45
42
|
}
|
|
46
43
|
}
|
|
47
|
-
exports.Slack = Slack;
|
|
48
44
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/slack/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/slack/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,MAAM,KAAK,GAAG;IACZ,IAAI,EAAE,0CAA0C;CACjD,CAAC;AACF,MAAM,SAAS,GAAG;IAChB,mBAAmB,EACjB,yGAAyG;IAC3G,4BAA4B,EAC1B,oNAAoN;IACtN,aAAa,EAAE,6BAA6B;CAC7C,CAAC;AAOF,MAAM,OAAO,KAAM,SAAQ,kBAAkB;IACpC,KAAK,CAAC,QAAQ,CAAC,UAAmB;QACvC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,mBAAmB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7E,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,4BAA4B,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACtF,MAAM,QAAQ,GAAG;YACf,yBAAyB,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,mBAAmB,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YAC9G,wBAAwB,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,4BAA4B,EAAE,CAAC,EAAE,EAAE,EAAE,CACxF,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,CAC3B;SACF,CAAC;QACF,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,MAAc;QAC/B,IAAI,MAAM,CAAC,yBAAyB,KAAK,KAAK,EAAE,CAAC;YAC/C,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;QAC7E,CAAC;QACD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,mBAAmB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7E,IAAI,KAAK,CAAC,yBAAyB,KAAK,MAAM,CAAC,yBAAyB,EAAE,CAAC;YACzE,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;YAC9G,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QACxE,CAAC;QACD,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,4BAA4B,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACtF,IAAI,KAAK,CAAC,wBAAwB,KAAK,MAAM,CAAC,wBAAwB,EAAE,CAAC;YACvE,MAAM,OAAO,CAAC,GAAG,CAAC;gBAChB,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,aAAa,CAAC;gBAC7C,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,4BAA4B,CAAC;aACnD,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QACxE,CAAC;QACD,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export declare function semanticallyCleanObject<T extends unknown>(obj: T, id?: string): T | undefined;
|
|
2
|
+
export declare function isEmptyObjectOrArray(arg: unknown): boolean;
|
|
3
|
+
export declare function deepDiff<T extends unknown>(source: T | undefined, target: T | undefined): T | undefined;
|