create-payload-app 0.5.1 → 1.0.0-beta.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,188 +1,168 @@
1
1
  "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __generator = (this && this.__generator) || function (thisArg, body) {
12
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
- function verb(n) { return function (v) { return step([n, v]); }; }
15
- function step(op) {
16
- if (f) throw new TypeError("Generator is already executing.");
17
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
- 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;
19
- if (y = 0, t) op = [op[0] & 2, t.value];
20
- switch (op[0]) {
21
- case 0: case 1: t = op; break;
22
- case 4: _.label++; return { value: op[1], done: false };
23
- case 5: _.label++; y = op[1]; op = [0]; continue;
24
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
- default:
26
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
- if (t[2]) _.ops.pop();
31
- _.trys.pop(); continue;
32
- }
33
- op = body.call(thisArg, _);
34
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
- }
37
- };
38
- var __importDefault = (this && this.__importDefault) || function (mod) {
39
- return (mod && mod.__esModule) ? mod : { "default": mod };
40
- };
41
- Object.defineProperty(exports, "__esModule", { value: true });
42
- var fs_extra_1 = __importDefault(require("fs-extra"));
43
- var path_1 = __importDefault(require("path"));
44
- var create_project_1 = require("./create-project");
45
- var packages_1 = require("./packages");
46
- var projectDir = path_1.default.resolve(__dirname, './tmp');
47
- describe('createProject', function () {
48
- beforeAll(function () {
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ const _fsextra = /*#__PURE__*/ _interop_require_default(require("fs-extra"));
6
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
7
+ const _createproject = require("./create-project");
8
+ const _packages = require("./packages");
9
+ const _templates = require("./templates");
10
+ function _interop_require_default(obj) {
11
+ return obj && obj.__esModule ? obj : {
12
+ default: obj
13
+ };
14
+ }
15
+ const projectDir = _path.default.resolve(__dirname, './tmp');
16
+ describe('createProject', ()=>{
17
+ beforeAll(()=>{
49
18
  console.log = jest.fn();
50
19
  });
51
- beforeEach(function () {
52
- if (fs_extra_1.default.existsSync(projectDir)) {
53
- fs_extra_1.default.rmdirSync(projectDir, { recursive: true });
20
+ beforeEach(()=>{
21
+ if (_fsextra.default.existsSync(projectDir)) {
22
+ _fsextra.default.rmdirSync(projectDir, {
23
+ recursive: true
24
+ });
54
25
  }
55
26
  });
56
- afterEach(function () {
57
- if (fs_extra_1.default.existsSync(projectDir)) {
58
- fs_extra_1.default.rmdirSync(projectDir, { recursive: true });
27
+ afterEach(()=>{
28
+ if (_fsextra.default.existsSync(projectDir)) {
29
+ _fsextra.default.rmSync(projectDir, {
30
+ recursive: true
31
+ });
59
32
  }
60
33
  });
61
- describe('#createProject', function () {
34
+ describe('#createProject', ()=>{
62
35
  // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
63
- var args = {
64
- _: ['project-name'],
36
+ const args = {
37
+ _: [
38
+ 'project-name'
39
+ ],
65
40
  '--db': 'mongodb',
66
- '--no-deps': true,
41
+ '--no-deps': true
67
42
  };
68
- var packageManager = 'yarn';
69
- it('creates starter project', function () { return __awaiter(void 0, void 0, void 0, function () {
70
- var projectName, template, packageJsonPath, packageJson;
71
- return __generator(this, function (_a) {
72
- switch (_a.label) {
73
- case 0:
74
- projectName = 'starter-project';
75
- template = {
76
- name: 'blank',
77
- type: 'starter',
78
- url: 'https://github.com/payloadcms/payload/templates/blank',
79
- description: 'Blank Template',
80
- };
81
- return [4 /*yield*/, (0, create_project_1.createProject)({
82
- cliArgs: args,
83
- projectName: projectName,
84
- projectDir: projectDir,
85
- template: template,
86
- packageManager: packageManager,
87
- })];
88
- case 1:
89
- _a.sent();
90
- packageJsonPath = path_1.default.resolve(projectDir, 'package.json');
91
- packageJson = fs_extra_1.default.readJsonSync(packageJsonPath);
92
- // Check package name and description
93
- expect(packageJson.name).toEqual(projectName);
94
- return [2 /*return*/];
95
- }
43
+ const packageManager = 'yarn';
44
+ it('creates starter project', async ()=>{
45
+ const projectName = 'starter-project';
46
+ const template = {
47
+ name: 'blank',
48
+ type: 'starter',
49
+ url: 'https://github.com/payloadcms/payload/templates/blank',
50
+ description: 'Blank Template'
51
+ };
52
+ await (0, _createproject.createProject)({
53
+ cliArgs: args,
54
+ projectName,
55
+ projectDir,
56
+ template,
57
+ packageManager
96
58
  });
97
- }); });
98
- it('creates plugin template', function () { return __awaiter(void 0, void 0, void 0, function () {
99
- var projectName, template, packageJsonPath, packageJson;
100
- return __generator(this, function (_a) {
101
- switch (_a.label) {
102
- case 0:
103
- projectName = 'plugin';
104
- template = {
105
- name: 'plugin',
106
- type: 'plugin',
107
- url: 'https://github.com/payloadcms/payload-plugin-template',
108
- description: 'Template for creating a Payload plugin',
109
- };
110
- return [4 /*yield*/, (0, create_project_1.createProject)({
111
- cliArgs: args,
112
- projectName: projectName,
113
- projectDir: projectDir,
114
- template: template,
115
- packageManager: packageManager,
116
- })];
117
- case 1:
118
- _a.sent();
119
- packageJsonPath = path_1.default.resolve(projectDir, 'package.json');
120
- packageJson = fs_extra_1.default.readJsonSync(packageJsonPath);
121
- // Check package name and description
122
- expect(packageJson.name).toEqual(projectName);
123
- return [2 /*return*/];
124
- }
59
+ const packageJsonPath = _path.default.resolve(projectDir, 'package.json');
60
+ const packageJson = _fsextra.default.readJsonSync(packageJsonPath);
61
+ // Check package name and description
62
+ expect(packageJson.name).toEqual(projectName);
63
+ });
64
+ it('creates plugin template', async ()=>{
65
+ const projectName = 'plugin';
66
+ const template = {
67
+ name: 'plugin',
68
+ type: 'plugin',
69
+ url: 'https://github.com/payloadcms/payload-plugin-template',
70
+ description: 'Template for creating a Payload plugin'
71
+ };
72
+ await (0, _createproject.createProject)({
73
+ cliArgs: args,
74
+ projectName,
75
+ projectDir,
76
+ template,
77
+ packageManager
125
78
  });
126
- }); });
127
- describe('db adapters and bundlers', function () {
79
+ const packageJsonPath = _path.default.resolve(projectDir, 'package.json');
80
+ const packageJson = _fsextra.default.readJsonSync(packageJsonPath);
81
+ // Check package name and description
82
+ expect(packageJson.name).toEqual(projectName);
83
+ });
84
+ describe('db adapters and bundlers', ()=>{
85
+ const templates = (0, _templates.getValidTemplates)();
128
86
  it.each([
129
- ['mongodb', 'webpack'],
130
- ['postgres', 'webpack'],
131
- ])('update config and deps: %s, %s', function (db, bundler) { return __awaiter(void 0, void 0, void 0, function () {
132
- var projectName, template, dbReplacement, bundlerReplacement, editorReplacement, packageJsonPath, packageJson, payloadConfigPath, content;
133
- return __generator(this, function (_a) {
134
- switch (_a.label) {
135
- case 0:
136
- projectName = 'starter-project';
137
- template = {
138
- name: 'blank',
139
- type: 'starter',
140
- url: 'https://github.com/payloadcms/payload/templates/blank',
141
- description: 'Blank Template',
142
- };
143
- return [4 /*yield*/, (0, create_project_1.createProject)({
144
- cliArgs: args,
145
- projectName: projectName,
146
- projectDir: projectDir,
147
- template: template,
148
- packageManager: packageManager,
149
- dbDetails: {
150
- dbUri: "".concat(db, "://localhost:27017/create-project-test"),
151
- type: db,
152
- },
153
- })];
154
- case 1:
155
- _a.sent();
156
- dbReplacement = packages_1.dbPackages[db];
157
- bundlerReplacement = packages_1.bundlerPackages[bundler];
158
- editorReplacement = packages_1.editorPackages['slate'];
159
- packageJsonPath = path_1.default.resolve(projectDir, 'package.json');
160
- packageJson = fs_extra_1.default.readJsonSync(packageJsonPath);
161
- // Check deps
162
- expect(packageJson.dependencies['payload']).toEqual('^2.0.0');
163
- expect(packageJson.dependencies[dbReplacement.packageName]).toEqual(dbReplacement.version);
164
- expect(packageJson.dependencies[bundlerReplacement.packageName]).toEqual(bundlerReplacement.version);
165
- expect(packageJson.dependencies[editorReplacement.packageName]).toEqual(editorReplacement.version);
166
- payloadConfigPath = path_1.default.resolve(projectDir, 'src/payload.config.ts');
167
- content = fs_extra_1.default.readFileSync(payloadConfigPath, 'utf-8');
168
- // Check payload.config.ts
169
- expect(content).not.toContain('// database-adapter-import');
170
- expect(content).toContain(dbReplacement.importReplacement);
171
- expect(content).not.toContain('// database-adapter-config-start');
172
- expect(content).not.toContain('// database-adapter-config-end');
173
- expect(content).toContain(dbReplacement.configReplacement.join('\n'));
174
- expect(content).not.toContain('// bundler-config-import');
175
- expect(content).toContain(bundlerReplacement.importReplacement);
176
- expect(content).not.toContain('// bundler-config');
177
- expect(content).toContain(bundlerReplacement.configReplacement);
178
- return [2 /*return*/];
87
+ [
88
+ 'blank',
89
+ 'mongodb',
90
+ 'webpack'
91
+ ],
92
+ [
93
+ 'blank',
94
+ 'postgres',
95
+ 'webpack'
96
+ ],
97
+ [
98
+ 'website',
99
+ 'mongodb',
100
+ 'webpack'
101
+ ],
102
+ [
103
+ 'website',
104
+ 'postgres',
105
+ 'webpack'
106
+ ],
107
+ [
108
+ 'ecommerce',
109
+ 'mongodb',
110
+ 'webpack'
111
+ ],
112
+ [
113
+ 'ecommerce',
114
+ 'postgres',
115
+ 'webpack'
116
+ ]
117
+ ])('update config and deps: %s, %s, %s', async (templateName, db, bundler)=>{
118
+ const projectName = 'starter-project';
119
+ const template = templates.find((t)=>t.name === templateName);
120
+ await (0, _createproject.createProject)({
121
+ cliArgs: args,
122
+ projectName,
123
+ projectDir,
124
+ template,
125
+ packageManager,
126
+ dbDetails: {
127
+ dbUri: `${db}://localhost:27017/create-project-test`,
128
+ type: db
179
129
  }
180
130
  });
181
- }); });
131
+ const dbReplacement = _packages.dbPackages[db];
132
+ const bundlerReplacement = _packages.bundlerPackages[bundler];
133
+ const editorReplacement = _packages.editorPackages['slate'];
134
+ const packageJsonPath = _path.default.resolve(projectDir, 'package.json');
135
+ const packageJson = _fsextra.default.readJsonSync(packageJsonPath);
136
+ // Check deps
137
+ expect(packageJson.dependencies['payload']).toEqual('^2.0.0');
138
+ expect(packageJson.dependencies[dbReplacement.packageName]).toEqual(dbReplacement.version);
139
+ // Should only have one db adapter
140
+ expect(Object.keys(packageJson.dependencies).filter((n)=>n.startsWith('@payloadcms/db-'))).toHaveLength(1);
141
+ expect(packageJson.dependencies[bundlerReplacement.packageName]).toEqual(bundlerReplacement.version);
142
+ expect(packageJson.dependencies[editorReplacement.packageName]).toEqual(editorReplacement.version);
143
+ let payloadConfigPath = _path.default.resolve(projectDir, 'src/payload.config.ts');
144
+ // Website and ecommerce templates have payload.config.ts in src/payload
145
+ if (!_fsextra.default.existsSync(payloadConfigPath)) {
146
+ payloadConfigPath = _path.default.resolve(projectDir, 'src/payload/payload.config.ts');
147
+ }
148
+ const content = _fsextra.default.readFileSync(payloadConfigPath, 'utf-8');
149
+ // Check payload.config.ts
150
+ expect(content).not.toContain('// database-adapter-import');
151
+ expect(content).toContain(dbReplacement.importReplacement);
152
+ expect(content).not.toContain('// database-adapter-config-start');
153
+ expect(content).not.toContain('// database-adapter-config-end');
154
+ expect(content).toContain(dbReplacement.configReplacement.join('\n'));
155
+ expect(content).not.toContain('// bundler-config-import');
156
+ expect(content).toContain(bundlerReplacement.importReplacement);
157
+ expect(content).not.toContain('// bundler-config');
158
+ expect(content).toContain(bundlerReplacement.configReplacement);
159
+ });
182
160
  });
183
161
  });
184
- describe('Templates', function () {
162
+ describe('Templates', ()=>{
185
163
  it.todo('Verify that all templates are valid');
186
- // Loop through all templates.ts that should have replacement comments, and verify that they are present
164
+ // Loop through all templates.ts that should have replacement comments, and verify that they are present
187
165
  });
188
166
  });
167
+
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/lib/create-project.spec.ts"],"sourcesContent":["import fse from 'fs-extra'\nimport path from 'path'\nimport type { BundlerType, CliArgs, DbType, ProjectTemplate } from '../types'\nimport { createProject } from './create-project'\nimport { bundlerPackages, dbPackages, editorPackages } from './packages'\nimport exp from 'constants'\nimport { getValidTemplates } from './templates'\n\nconst projectDir = path.resolve(__dirname, './tmp')\ndescribe('createProject', () => {\n  beforeAll(() => {\n    console.log = jest.fn()\n  })\n\n  beforeEach(() => {\n    if (fse.existsSync(projectDir)) {\n      fse.rmdirSync(projectDir, { recursive: true })\n    }\n  })\n  afterEach(() => {\n    if (fse.existsSync(projectDir)) {\n      fse.rmSync(projectDir, { recursive: true })\n    }\n  })\n\n  describe('#createProject', () => {\n    // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n    const args = {\n      _: ['project-name'],\n      '--db': 'mongodb',\n      '--no-deps': true,\n    } as CliArgs\n    const packageManager = 'yarn'\n\n    it('creates starter project', async () => {\n      const projectName = 'starter-project'\n      const template: ProjectTemplate = {\n        name: 'blank',\n        type: 'starter',\n        url: 'https://github.com/payloadcms/payload/templates/blank',\n        description: 'Blank Template',\n      }\n      await createProject({\n        cliArgs: args,\n        projectName,\n        projectDir,\n        template,\n        packageManager,\n      })\n\n      const packageJsonPath = path.resolve(projectDir, 'package.json')\n      const packageJson = fse.readJsonSync(packageJsonPath)\n\n      // Check package name and description\n      expect(packageJson.name).toEqual(projectName)\n    })\n\n    it('creates plugin template', async () => {\n      const projectName = 'plugin'\n      const template: ProjectTemplate = {\n        name: 'plugin',\n        type: 'plugin',\n        url: 'https://github.com/payloadcms/payload-plugin-template',\n        description: 'Template for creating a Payload plugin',\n      }\n      await createProject({\n        cliArgs: args,\n        projectName,\n        projectDir,\n        template,\n        packageManager,\n      })\n\n      const packageJsonPath = path.resolve(projectDir, 'package.json')\n      const packageJson = fse.readJsonSync(packageJsonPath)\n\n      // Check package name and description\n      expect(packageJson.name).toEqual(projectName)\n    })\n\n    describe('db adapters and bundlers', () => {\n      const templates = getValidTemplates()\n\n      it.each([\n        ['blank', 'mongodb', 'webpack'],\n        ['blank', 'postgres', 'webpack'],\n        ['website', 'mongodb', 'webpack'],\n        ['website', 'postgres', 'webpack'],\n        ['ecommerce', 'mongodb', 'webpack'],\n        ['ecommerce', 'postgres', 'webpack'],\n      ])('update config and deps: %s, %s, %s', async (templateName, db, bundler) => {\n        const projectName = 'starter-project'\n\n        const template = templates.find((t) => t.name === templateName)\n\n        await createProject({\n          cliArgs: args,\n          projectName,\n          projectDir,\n          template,\n          packageManager,\n          dbDetails: {\n            dbUri: `${db}://localhost:27017/create-project-test`,\n            type: db as DbType,\n          },\n        })\n\n        const dbReplacement = dbPackages[db as DbType]\n        const bundlerReplacement = bundlerPackages[bundler as BundlerType]\n        const editorReplacement = editorPackages['slate']\n\n        const packageJsonPath = path.resolve(projectDir, 'package.json')\n        const packageJson = fse.readJsonSync(packageJsonPath)\n\n        // Check deps\n        expect(packageJson.dependencies['payload']).toEqual('^2.0.0')\n        expect(packageJson.dependencies[dbReplacement.packageName]).toEqual(dbReplacement.version)\n\n        // Should only have one db adapter\n        expect(\n          Object.keys(packageJson.dependencies).filter((n) => n.startsWith('@payloadcms/db-')),\n        ).toHaveLength(1)\n\n        expect(packageJson.dependencies[bundlerReplacement.packageName]).toEqual(\n          bundlerReplacement.version,\n        )\n        expect(packageJson.dependencies[editorReplacement.packageName]).toEqual(\n          editorReplacement.version,\n        )\n\n        let payloadConfigPath = path.resolve(projectDir, 'src/payload.config.ts')\n\n        // Website and ecommerce templates have payload.config.ts in src/payload\n        if (!fse.existsSync(payloadConfigPath)) {\n          payloadConfigPath = path.resolve(projectDir, 'src/payload/payload.config.ts')\n        }\n        const content = fse.readFileSync(payloadConfigPath, 'utf-8')\n\n        // Check payload.config.ts\n        expect(content).not.toContain('// database-adapter-import')\n        expect(content).toContain(dbReplacement.importReplacement)\n\n        expect(content).not.toContain('// database-adapter-config-start')\n        expect(content).not.toContain('// database-adapter-config-end')\n        expect(content).toContain(dbReplacement.configReplacement.join('\\n'))\n\n        expect(content).not.toContain('// bundler-config-import')\n        expect(content).toContain(bundlerReplacement.importReplacement)\n\n        expect(content).not.toContain('// bundler-config')\n        expect(content).toContain(bundlerReplacement.configReplacement)\n      })\n    })\n  })\n\n  describe('Templates', () => {\n    it.todo('Verify that all templates are valid')\n    // Loop through all templates.ts that should have replacement comments, and verify that they are present\n  })\n})\n"],"names":["projectDir","path","resolve","__dirname","describe","beforeAll","console","log","jest","fn","beforeEach","fse","existsSync","rmdirSync","recursive","afterEach","rmSync","args","_","packageManager","it","projectName","template","name","type","url","description","createProject","cliArgs","packageJsonPath","packageJson","readJsonSync","expect","toEqual","templates","getValidTemplates","each","templateName","db","bundler","find","t","dbDetails","dbUri","dbReplacement","dbPackages","bundlerReplacement","bundlerPackages","editorReplacement","editorPackages","dependencies","packageName","version","Object","keys","filter","n","startsWith","toHaveLength","payloadConfigPath","content","readFileSync","not","toContain","importReplacement","configReplacement","join","todo"],"mappings":"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"}
@@ -1,48 +1,16 @@
1
1
  "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __generator = (this && this.__generator) || function (thisArg, body) {
12
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
- function verb(n) { return function (v) { return step([n, v]); }; }
15
- function step(op) {
16
- if (f) throw new TypeError("Generator is already executing.");
17
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
- 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;
19
- if (y = 0, t) op = [op[0] & 2, t.value];
20
- switch (op[0]) {
21
- case 0: case 1: t = op; break;
22
- case 4: _.label++; return { value: op[1], done: false };
23
- case 5: _.label++; y = op[1]; op = [0]; continue;
24
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
- default:
26
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
- if (t[2]) _.ops.pop();
31
- _.trys.pop(); continue;
32
- }
33
- op = body.call(thisArg, _);
34
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "generateSecret", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return generateSecret;
36
9
  }
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.generateSecret = void 0;
40
- var crypto_1 = require("crypto");
10
+ });
11
+ const _crypto = require("crypto");
41
12
  function generateSecret() {
42
- return __awaiter(this, void 0, void 0, function () {
43
- return __generator(this, function (_a) {
44
- return [2 /*return*/, (0, crypto_1.randomBytes)(32).toString('hex').slice(0, 24)];
45
- });
46
- });
13
+ return (0, _crypto.randomBytes)(32).toString('hex').slice(0, 24);
47
14
  }
48
- exports.generateSecret = generateSecret;
15
+
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvZ2VuZXJhdGUtc2VjcmV0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJhbmRvbUJ5dGVzIH0gZnJvbSAnY3J5cHRvJ1xuXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVTZWNyZXQoKTogc3RyaW5nIHtcbiAgcmV0dXJuIHJhbmRvbUJ5dGVzKDMyKS50b1N0cmluZygnaGV4Jykuc2xpY2UoMCwgMjQpXG59XG4iXSwibmFtZXMiOlsiZ2VuZXJhdGVTZWNyZXQiLCJyYW5kb21CeXRlcyIsInRvU3RyaW5nIiwic2xpY2UiXSwibWFwcGluZ3MiOiI7Ozs7K0JBRWdCQTs7O2VBQUFBOzs7d0JBRlk7QUFFckIsU0FBU0E7SUFDZCxPQUFPQyxJQUFBQSxtQkFBVyxFQUFDLElBQUlDLFFBQVEsQ0FBQyxPQUFPQyxLQUFLLENBQUMsR0FBRztBQUNsRCJ9
@@ -1,61 +1,81 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.editorPackages = exports.bundlerPackages = exports.dbPackages = void 0;
4
- var mongodbReplacement = {
5
- packageName: '@payloadcms/db-mongodb',
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ dbPackages: function() {
13
+ return dbPackages;
14
+ },
15
+ bundlerPackages: function() {
16
+ return bundlerPackages;
17
+ },
18
+ editorPackages: function() {
19
+ return editorPackages;
20
+ }
21
+ });
22
+ const mongodbReplacement = {
6
23
  importReplacement: "import { mongooseAdapter } from '@payloadcms/db-mongodb'",
24
+ packageName: '@payloadcms/db-mongodb',
7
25
  // Replacement between `// database-adapter-config-start` and `// database-adapter-config-end`
8
26
  configReplacement: [
9
27
  ' db: mongooseAdapter({',
10
28
  ' url: process.env.DATABASE_URI,',
11
- ' }),',
29
+ ' }),'
12
30
  ],
13
- version: '^1.0.0',
31
+ version: '^1.0.0'
14
32
  };
15
- var postgresReplacement = {
16
- packageName: '@payloadcms/db-postgres',
17
- importReplacement: "import { postgresAdapter } from '@payloadcms/db-postgres'",
33
+ const postgresReplacement = {
18
34
  configReplacement: [
19
35
  ' db: postgresAdapter({',
20
36
  ' pool: {',
21
37
  ' connectionString: process.env.DATABASE_URI,',
22
38
  ' },',
23
- ' }),',
39
+ ' }),'
24
40
  ],
25
- version: '^0.x', // up to, not including 1.0.0
41
+ importReplacement: "import { postgresAdapter } from '@payloadcms/db-postgres'",
42
+ packageName: '@payloadcms/db-postgres',
43
+ version: '^0.x'
26
44
  };
27
- exports.dbPackages = {
45
+ const dbPackages = {
28
46
  mongodb: mongodbReplacement,
29
- postgres: postgresReplacement,
47
+ postgres: postgresReplacement
30
48
  };
31
- var webpackReplacement = {
32
- packageName: '@payloadcms/bundler-webpack',
49
+ const webpackReplacement = {
33
50
  importReplacement: "import { webpackBundler } from '@payloadcms/bundler-webpack'",
51
+ packageName: '@payloadcms/bundler-webpack',
34
52
  // Replacement of line containing `// bundler-config`
35
53
  configReplacement: ' bundler: webpackBundler(),',
36
- version: '^1.0.0',
54
+ version: '^1.0.0'
37
55
  };
38
- var viteReplacement = {
39
- packageName: '@payloadcms/bundler-vite',
40
- importReplacement: "import { viteBundler } from '@payloadcms/bundler-vite'",
56
+ const viteReplacement = {
41
57
  configReplacement: ' bundler: viteBundler(),',
42
- version: '^0.x', // up to, not including 1.0.0
58
+ importReplacement: "import { viteBundler } from '@payloadcms/bundler-vite'",
59
+ packageName: '@payloadcms/bundler-vite',
60
+ version: '^0.x'
43
61
  };
44
- exports.bundlerPackages = {
45
- webpack: webpackReplacement,
62
+ const bundlerPackages = {
46
63
  vite: viteReplacement,
64
+ webpack: webpackReplacement
47
65
  };
48
- exports.editorPackages = {
49
- slate: {
50
- packageName: '@payloadcms/richtext-slate',
51
- importReplacement: "import { slateEditor } from '@payloadcms/richtext-slate'",
52
- configReplacement: ' editor: slateEditor({}),',
53
- version: '^1.0.0',
54
- },
66
+ const editorPackages = {
55
67
  lexical: {
56
- packageName: '@payloadcms/richtext-lexical',
57
- importReplacement: "import { lexicalEditor } from '@payloadcms/richtext-lexical'",
58
68
  configReplacement: ' editor: lexicalEditor({}),',
59
- version: '^0.x', // up to, not including 1.0.0
69
+ importReplacement: "import { lexicalEditor } from '@payloadcms/richtext-lexical'",
70
+ packageName: '@payloadcms/richtext-lexical',
71
+ version: '^0.x'
60
72
  },
73
+ slate: {
74
+ configReplacement: ' editor: slateEditor({}),',
75
+ importReplacement: "import { slateEditor } from '@payloadcms/richtext-slate'",
76
+ packageName: '@payloadcms/richtext-slate',
77
+ version: '^1.0.0'
78
+ }
61
79
  };
80
+
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcGFja2FnZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCdW5kbGVyVHlwZSwgRGJUeXBlLCBFZGl0b3JUeXBlIH0gZnJvbSAnLi4vdHlwZXMnXG5cbnR5cGUgRGJBZGFwdGVyUmVwbGFjZW1lbnQgPSB7XG4gIGNvbmZpZ1JlcGxhY2VtZW50OiBzdHJpbmdbXVxuICBpbXBvcnRSZXBsYWNlbWVudDogc3RyaW5nXG4gIHBhY2thZ2VOYW1lOiBzdHJpbmdcbiAgdmVyc2lvbjogc3RyaW5nXG59XG5cbnR5cGUgQnVuZGxlclJlcGxhY2VtZW50ID0ge1xuICBjb25maWdSZXBsYWNlbWVudDogc3RyaW5nXG4gIGltcG9ydFJlcGxhY2VtZW50OiBzdHJpbmdcbiAgcGFja2FnZU5hbWU6IHN0cmluZ1xuICB2ZXJzaW9uOiBzdHJpbmdcbn1cblxudHlwZSBFZGl0b3JSZXBsYWNlbWVudCA9IHtcbiAgY29uZmlnUmVwbGFjZW1lbnQ6IHN0cmluZ1xuICBpbXBvcnRSZXBsYWNlbWVudDogc3RyaW5nXG4gIHBhY2thZ2VOYW1lOiBzdHJpbmdcbiAgdmVyc2lvbjogc3RyaW5nXG59XG5cbmNvbnN0IG1vbmdvZGJSZXBsYWNlbWVudDogRGJBZGFwdGVyUmVwbGFjZW1lbnQgPSB7XG4gIGltcG9ydFJlcGxhY2VtZW50OiBcImltcG9ydCB7IG1vbmdvb3NlQWRhcHRlciB9IGZyb20gJ0BwYXlsb2FkY21zL2RiLW1vbmdvZGInXCIsXG4gIHBhY2thZ2VOYW1lOiAnQHBheWxvYWRjbXMvZGItbW9uZ29kYicsXG4gIC8vIFJlcGxhY2VtZW50IGJldHdlZW4gYC8vIGRhdGFiYXNlLWFkYXB0ZXItY29uZmlnLXN0YXJ0YCBhbmQgYC8vIGRhdGFiYXNlLWFkYXB0ZXItY29uZmlnLWVuZGBcbiAgY29uZmlnUmVwbGFjZW1lbnQ6IFsnICBkYjogbW9uZ29vc2VBZGFwdGVyKHsnLCAnICAgIHVybDogcHJvY2Vzcy5lbnYuREFUQUJBU0VfVVJJLCcsICcgIH0pLCddLFxuICB2ZXJzaW9uOiAnXjEuMC4wJyxcbn1cblxuY29uc3QgcG9zdGdyZXNSZXBsYWNlbWVudDogRGJBZGFwdGVyUmVwbGFjZW1lbnQgPSB7XG4gIGNvbmZpZ1JlcGxhY2VtZW50OiBbXG4gICAgJyAgZGI6IHBvc3RncmVzQWRhcHRlcih7JyxcbiAgICAnICAgIHBvb2w6IHsnLFxuICAgICcgICAgICBjb25uZWN0aW9uU3RyaW5nOiBwcm9jZXNzLmVudi5EQVRBQkFTRV9VUkksJyxcbiAgICAnICAgIH0sJyxcbiAgICAnICB9KSwnLFxuICBdLFxuICBpbXBvcnRSZXBsYWNlbWVudDogXCJpbXBvcnQgeyBwb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICdAcGF5bG9hZGNtcy9kYi1wb3N0Z3JlcydcIixcbiAgcGFja2FnZU5hbWU6ICdAcGF5bG9hZGNtcy9kYi1wb3N0Z3JlcycsXG4gIHZlcnNpb246ICdeMC54JywgLy8gdXAgdG8sIG5vdCBpbmNsdWRpbmcgMS4wLjBcbn1cblxuZXhwb3J0IGNvbnN0IGRiUGFja2FnZXM6IFJlY29yZDxEYlR5cGUsIERiQWRhcHRlclJlcGxhY2VtZW50PiA9IHtcbiAgbW9uZ29kYjogbW9uZ29kYlJlcGxhY2VtZW50LFxuICBwb3N0Z3JlczogcG9zdGdyZXNSZXBsYWNlbWVudCxcbn1cblxuY29uc3Qgd2VicGFja1JlcGxhY2VtZW50OiBCdW5kbGVyUmVwbGFjZW1lbnQgPSB7XG4gIGltcG9ydFJlcGxhY2VtZW50OiBcImltcG9ydCB7IHdlYnBhY2tCdW5kbGVyIH0gZnJvbSAnQHBheWxvYWRjbXMvYnVuZGxlci13ZWJwYWNrJ1wiLFxuICBwYWNrYWdlTmFtZTogJ0BwYXlsb2FkY21zL2J1bmRsZXItd2VicGFjaycsXG4gIC8vIFJlcGxhY2VtZW50IG9mIGxpbmUgY29udGFpbmluZyBgLy8gYnVuZGxlci1jb25maWdgXG4gIGNvbmZpZ1JlcGxhY2VtZW50OiAnICAgIGJ1bmRsZXI6IHdlYnBhY2tCdW5kbGVyKCksJyxcbiAgdmVyc2lvbjogJ14xLjAuMCcsXG59XG5cbmNvbnN0IHZpdGVSZXBsYWNlbWVudDogQnVuZGxlclJlcGxhY2VtZW50ID0ge1xuICBjb25maWdSZXBsYWNlbWVudDogJyAgYnVuZGxlcjogdml0ZUJ1bmRsZXIoKSwnLFxuICBpbXBvcnRSZXBsYWNlbWVudDogXCJpbXBvcnQgeyB2aXRlQnVuZGxlciB9IGZyb20gJ0BwYXlsb2FkY21zL2J1bmRsZXItdml0ZSdcIixcbiAgcGFja2FnZU5hbWU6ICdAcGF5bG9hZGNtcy9idW5kbGVyLXZpdGUnLFxuICB2ZXJzaW9uOiAnXjAueCcsIC8vIHVwIHRvLCBub3QgaW5jbHVkaW5nIDEuMC4wXG59XG5cbmV4cG9ydCBjb25zdCBidW5kbGVyUGFja2FnZXM6IFJlY29yZDxCdW5kbGVyVHlwZSwgQnVuZGxlclJlcGxhY2VtZW50PiA9IHtcbiAgdml0ZTogdml0ZVJlcGxhY2VtZW50LFxuICB3ZWJwYWNrOiB3ZWJwYWNrUmVwbGFjZW1lbnQsXG59XG5cbmV4cG9ydCBjb25zdCBlZGl0b3JQYWNrYWdlczogUmVjb3JkPEVkaXRvclR5cGUsIEVkaXRvclJlcGxhY2VtZW50PiA9IHtcbiAgbGV4aWNhbDoge1xuICAgIGNvbmZpZ1JlcGxhY2VtZW50OiAnICBlZGl0b3I6IGxleGljYWxFZGl0b3Ioe30pLCcsXG4gICAgaW1wb3J0UmVwbGFjZW1lbnQ6IFwiaW1wb3J0IHsgbGV4aWNhbEVkaXRvciB9IGZyb20gJ0BwYXlsb2FkY21zL3JpY2h0ZXh0LWxleGljYWwnXCIsXG4gICAgcGFja2FnZU5hbWU6ICdAcGF5bG9hZGNtcy9yaWNodGV4dC1sZXhpY2FsJyxcbiAgICB2ZXJzaW9uOiAnXjAueCcsIC8vIHVwIHRvLCBub3QgaW5jbHVkaW5nIDEuMC4wXG4gIH0sXG4gIHNsYXRlOiB7XG4gICAgY29uZmlnUmVwbGFjZW1lbnQ6ICcgIGVkaXRvcjogc2xhdGVFZGl0b3Ioe30pLCcsXG4gICAgaW1wb3J0UmVwbGFjZW1lbnQ6IFwiaW1wb3J0IHsgc2xhdGVFZGl0b3IgfSBmcm9tICdAcGF5bG9hZGNtcy9yaWNodGV4dC1zbGF0ZSdcIixcbiAgICBwYWNrYWdlTmFtZTogJ0BwYXlsb2FkY21zL3JpY2h0ZXh0LXNsYXRlJyxcbiAgICB2ZXJzaW9uOiAnXjEuMC4wJyxcbiAgfSxcbn1cbiJdLCJuYW1lcyI6WyJkYlBhY2thZ2VzIiwiYnVuZGxlclBhY2thZ2VzIiwiZWRpdG9yUGFja2FnZXMiLCJtb25nb2RiUmVwbGFjZW1lbnQiLCJpbXBvcnRSZXBsYWNlbWVudCIsInBhY2thZ2VOYW1lIiwiY29uZmlnUmVwbGFjZW1lbnQiLCJ2ZXJzaW9uIiwicG9zdGdyZXNSZXBsYWNlbWVudCIsIm1vbmdvZGIiLCJwb3N0Z3JlcyIsIndlYnBhY2tSZXBsYWNlbWVudCIsInZpdGVSZXBsYWNlbWVudCIsInZpdGUiLCJ3ZWJwYWNrIiwibGV4aWNhbCIsInNsYXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztJQTRDYUEsVUFBVTtlQUFWQTs7SUFvQkFDLGVBQWU7ZUFBZkE7O0lBS0FDLGNBQWM7ZUFBZEE7OztBQTlDYixNQUFNQyxxQkFBMkM7SUFDL0NDLG1CQUFtQjtJQUNuQkMsYUFBYTtJQUNiLDhGQUE4RjtJQUM5RkMsbUJBQW1CO1FBQUM7UUFBMkI7UUFBc0M7S0FBUTtJQUM3RkMsU0FBUztBQUNYO0FBRUEsTUFBTUMsc0JBQTRDO0lBQ2hERixtQkFBbUI7UUFDakI7UUFDQTtRQUNBO1FBQ0E7UUFDQTtLQUNEO0lBQ0RGLG1CQUFtQjtJQUNuQkMsYUFBYTtJQUNiRSxTQUFTO0FBQ1g7QUFFTyxNQUFNUCxhQUFtRDtJQUM5RFMsU0FBU047SUFDVE8sVUFBVUY7QUFDWjtBQUVBLE1BQU1HLHFCQUF5QztJQUM3Q1AsbUJBQW1CO0lBQ25CQyxhQUFhO0lBQ2IscURBQXFEO0lBQ3JEQyxtQkFBbUI7SUFDbkJDLFNBQVM7QUFDWDtBQUVBLE1BQU1LLGtCQUFzQztJQUMxQ04sbUJBQW1CO0lBQ25CRixtQkFBbUI7SUFDbkJDLGFBQWE7SUFDYkUsU0FBUztBQUNYO0FBRU8sTUFBTU4sa0JBQTJEO0lBQ3RFWSxNQUFNRDtJQUNORSxTQUFTSDtBQUNYO0FBRU8sTUFBTVQsaUJBQXdEO0lBQ25FYSxTQUFTO1FBQ1BULG1CQUFtQjtRQUNuQkYsbUJBQW1CO1FBQ25CQyxhQUFhO1FBQ2JFLFNBQVM7SUFDWDtJQUNBUyxPQUFPO1FBQ0xWLG1CQUFtQjtRQUNuQkYsbUJBQW1CO1FBQ25CQyxhQUFhO1FBQ2JFLFNBQVM7SUFDWDtBQUNGIn0=