create-strapi-app 5.12.1 → 5.12.3
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/dist/cloud.js +65 -0
- package/dist/cloud.js.map +1 -0
- package/dist/cloud.mjs +63 -0
- package/dist/cloud.mjs.map +1 -0
- package/dist/create-strapi.js +251 -0
- package/dist/create-strapi.js.map +1 -0
- package/dist/create-strapi.mjs +249 -0
- package/dist/create-strapi.mjs.map +1 -0
- package/dist/index.js +35 -1330
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +15 -1291
- package/dist/index.mjs.map +1 -1
- package/dist/prompts.js +66 -0
- package/dist/prompts.js.map +1 -0
- package/dist/prompts.mjs +60 -0
- package/dist/prompts.mjs.map +1 -0
- package/dist/types.js +8 -0
- package/dist/types.js.map +1 -0
- package/dist/types.mjs +6 -0
- package/dist/types.mjs.map +1 -0
- package/dist/utils/check-install-path.js +28 -0
- package/dist/utils/check-install-path.js.map +1 -0
- package/dist/utils/check-install-path.mjs +26 -0
- package/dist/utils/check-install-path.mjs.map +1 -0
- package/dist/utils/check-requirements.js +26 -0
- package/dist/utils/check-requirements.js.map +1 -0
- package/dist/utils/check-requirements.mjs +24 -0
- package/dist/utils/check-requirements.mjs.map +1 -0
- package/dist/utils/database.js +190 -0
- package/dist/utils/database.js.map +1 -0
- package/dist/utils/database.mjs +187 -0
- package/dist/utils/database.mjs.map +1 -0
- package/dist/utils/dot-env.js +46 -0
- package/dist/utils/dot-env.js.map +1 -0
- package/dist/utils/dot-env.mjs +44 -0
- package/dist/utils/dot-env.mjs.map +1 -0
- package/dist/utils/engines.js +9 -0
- package/dist/utils/engines.js.map +1 -0
- package/dist/utils/engines.mjs +7 -0
- package/dist/utils/engines.mjs.map +1 -0
- package/dist/utils/get-package-manager-args.js +135 -0
- package/dist/utils/get-package-manager-args.js.map +1 -0
- package/dist/utils/get-package-manager-args.mjs +132 -0
- package/dist/utils/get-package-manager-args.mjs.map +1 -0
- package/dist/utils/git.js +73 -0
- package/dist/utils/git.js.map +1 -0
- package/dist/utils/git.mjs +71 -0
- package/dist/utils/git.mjs.map +1 -0
- package/dist/utils/gitignore.js +139 -0
- package/dist/utils/gitignore.js.map +1 -0
- package/dist/utils/gitignore.mjs +137 -0
- package/dist/utils/gitignore.mjs.map +1 -0
- package/dist/utils/logger.js +54 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/logger.mjs +52 -0
- package/dist/utils/logger.mjs.map +1 -0
- package/dist/utils/machine-id.js +17 -0
- package/dist/utils/machine-id.js.map +1 -0
- package/dist/utils/machine-id.mjs +15 -0
- package/dist/utils/machine-id.mjs.map +1 -0
- package/dist/utils/package-json.js +32 -0
- package/dist/utils/package-json.js.map +1 -0
- package/dist/utils/package-json.mjs +30 -0
- package/dist/utils/package-json.mjs.map +1 -0
- package/dist/utils/parse-to-chalk.js +25 -0
- package/dist/utils/parse-to-chalk.js.map +1 -0
- package/dist/utils/parse-to-chalk.mjs +23 -0
- package/dist/utils/parse-to-chalk.mjs.map +1 -0
- package/dist/utils/template.js +180 -0
- package/dist/utils/template.js.map +1 -0
- package/dist/utils/template.mjs +159 -0
- package/dist/utils/template.mjs.map +1 -0
- package/dist/utils/usage.js +90 -0
- package/dist/utils/usage.js.map +1 -0
- package/dist/utils/usage.mjs +87 -0
- package/dist/utils/usage.mjs.map +1 -0
- package/package.json +4 -4
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var execa = require('execa');
|
|
4
|
+
var semver = require('semver');
|
|
5
|
+
|
|
6
|
+
const installArguments = [
|
|
7
|
+
'install'
|
|
8
|
+
];
|
|
9
|
+
// Set command line options for specific package managers, with full semver ranges
|
|
10
|
+
const installArgumentsMap = {
|
|
11
|
+
npm: {
|
|
12
|
+
'*': [
|
|
13
|
+
'--legacy-peer-deps'
|
|
14
|
+
]
|
|
15
|
+
},
|
|
16
|
+
yarn: {
|
|
17
|
+
'<4': [
|
|
18
|
+
'--network-timeout',
|
|
19
|
+
'1000000'
|
|
20
|
+
],
|
|
21
|
+
'*': []
|
|
22
|
+
},
|
|
23
|
+
pnpm: {
|
|
24
|
+
'*': []
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
// Set environment variables for specific package managers, with full semver ranges
|
|
28
|
+
const installEnvMap = {
|
|
29
|
+
yarn: {
|
|
30
|
+
'>=4': {
|
|
31
|
+
YARN_HTTP_TIMEOUT: '1000000'
|
|
32
|
+
},
|
|
33
|
+
'*': {}
|
|
34
|
+
},
|
|
35
|
+
npm: {
|
|
36
|
+
'*': {}
|
|
37
|
+
},
|
|
38
|
+
pnpm: {
|
|
39
|
+
'*': {}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
/**
|
|
43
|
+
* Retrieves the version of the specified package manager.
|
|
44
|
+
*
|
|
45
|
+
* Executes the package manager's `--version` command to determine its version.
|
|
46
|
+
*
|
|
47
|
+
* @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').
|
|
48
|
+
* @param options - Optional execution options to pass to `execa`.
|
|
49
|
+
* @returns A promise that resolves to the trimmed version string of the package manager.
|
|
50
|
+
*
|
|
51
|
+
* @throws Will throw an error if the package manager's version cannot be determined.
|
|
52
|
+
*/ const getPackageManagerVersion = async (packageManager, options)=>{
|
|
53
|
+
try {
|
|
54
|
+
const { stdout } = await execa(packageManager, [
|
|
55
|
+
'--version'
|
|
56
|
+
], options);
|
|
57
|
+
return stdout.trim();
|
|
58
|
+
} catch (err) {
|
|
59
|
+
throw new Error(`Error detecting ${packageManager} version: ${err}`);
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Merges all matching semver ranges using a custom merge function.
|
|
64
|
+
*
|
|
65
|
+
* Iterates over the `versionMap`, checking if the provided `version` satisfies each semver range.
|
|
66
|
+
* If it does, the corresponding value is merged using the provided `mergeFn`.
|
|
67
|
+
* The merging starts with the value associated with the wildcard '*' key.
|
|
68
|
+
*
|
|
69
|
+
* @param version - The package manager version to check against the ranges.
|
|
70
|
+
* @param versionMap - A map of semver ranges to corresponding values (arguments or environment variables).
|
|
71
|
+
* @param mergeFn - A function that defines how to merge two values (accumulated and current).
|
|
72
|
+
* @returns The merged result of all matching ranges.
|
|
73
|
+
*/ function mergeMatchingVersionRanges(version, versionMap, mergeFn) {
|
|
74
|
+
return Object.keys(versionMap).reduce((acc, range)=>{
|
|
75
|
+
if (semver.satisfies(version, range) || range === '*') {
|
|
76
|
+
return mergeFn(acc, versionMap[range]);
|
|
77
|
+
}
|
|
78
|
+
return acc;
|
|
79
|
+
}, versionMap['*']); // Start with the wildcard entry
|
|
80
|
+
}
|
|
81
|
+
function mergeArguments(acc, curr) {
|
|
82
|
+
return [
|
|
83
|
+
...acc,
|
|
84
|
+
...curr
|
|
85
|
+
];
|
|
86
|
+
}
|
|
87
|
+
function mergeEnvVars(acc, curr) {
|
|
88
|
+
return {
|
|
89
|
+
...acc,
|
|
90
|
+
...curr
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Retrieves the install arguments and environment variables for a given package manager.
|
|
95
|
+
*
|
|
96
|
+
* This function determines the correct command line arguments and environment variables
|
|
97
|
+
* based on the package manager's version. It uses predefined semver ranges to match
|
|
98
|
+
* the package manager's version and merges all applicable settings.
|
|
99
|
+
*
|
|
100
|
+
* The arguments and environment variables are sourced from:
|
|
101
|
+
* - `installArgumentsMap` for command line arguments.
|
|
102
|
+
* - `installEnvMap` for environment variables.
|
|
103
|
+
*
|
|
104
|
+
* The function ensures that all matching semver ranges are considered and merged appropriately.
|
|
105
|
+
* It always includes the base `installArguments` (e.g., `['install']`) and applies any additional
|
|
106
|
+
* arguments or environment variables as defined by the matched version ranges.
|
|
107
|
+
*
|
|
108
|
+
* @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').
|
|
109
|
+
* @param options - Optional execution options to pass to `execa`.
|
|
110
|
+
* @returns An object containing:
|
|
111
|
+
* - `cmdArgs`: The full array of install arguments for the given package manager and version.
|
|
112
|
+
* - `envArgs`: The merged environment variables applicable to the package manager and version.
|
|
113
|
+
*
|
|
114
|
+
* @throws Will throw an error if the package manager version cannot be determined.
|
|
115
|
+
*/ const getInstallArgs = async (packageManager, options)=>{
|
|
116
|
+
const packageManagerVersion = await getPackageManagerVersion(packageManager, options);
|
|
117
|
+
// Get environment variables
|
|
118
|
+
const envMap = installEnvMap[packageManager];
|
|
119
|
+
const envArgs = packageManagerVersion ? mergeMatchingVersionRanges(packageManagerVersion, envMap, mergeEnvVars) : envMap['*'];
|
|
120
|
+
// Get install arguments
|
|
121
|
+
const argsMap = installArgumentsMap[packageManager];
|
|
122
|
+
const cmdArgs = packageManagerVersion ? mergeMatchingVersionRanges(packageManagerVersion, argsMap, mergeArguments) : argsMap['*'];
|
|
123
|
+
return {
|
|
124
|
+
envArgs,
|
|
125
|
+
cmdArgs: [
|
|
126
|
+
...installArguments,
|
|
127
|
+
...cmdArgs
|
|
128
|
+
],
|
|
129
|
+
version: packageManagerVersion
|
|
130
|
+
};
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
exports.getInstallArgs = getInstallArgs;
|
|
134
|
+
exports.getPackageManagerVersion = getPackageManagerVersion;
|
|
135
|
+
//# sourceMappingURL=get-package-manager-args.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-package-manager-args.js","sources":["../../src/utils/get-package-manager-args.ts"],"sourcesContent":["import execa from 'execa';\nimport semver from 'semver';\n\nconst installArguments = ['install'];\n\ntype VersionedArgumentsMap = {\n [key: string]: string[]; // Maps semver ranges to argument arrays\n};\n\ntype VersionedEnvMap = {\n [key: string]: Record<string, string>; // Maps semver ranges to environment variables\n};\n\n// Set command line options for specific package managers, with full semver ranges\nconst installArgumentsMap: {\n [key: string]: VersionedArgumentsMap;\n} = {\n npm: {\n '*': ['--legacy-peer-deps'],\n },\n yarn: {\n '<4': ['--network-timeout', '1000000'],\n '*': [],\n },\n pnpm: {\n '*': [],\n },\n};\n\n// Set environment variables for specific package managers, with full semver ranges\nconst installEnvMap: {\n [key: string]: VersionedEnvMap;\n} = {\n yarn: {\n '>=4': { YARN_HTTP_TIMEOUT: '1000000' },\n '*': {},\n },\n npm: {\n '*': {},\n },\n pnpm: {\n '*': {},\n },\n};\n\n/**\n * Retrieves the version of the specified package manager.\n *\n * Executes the package manager's `--version` command to determine its version.\n *\n * @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').\n * @param options - Optional execution options to pass to `execa`.\n * @returns A promise that resolves to the trimmed version string of the package manager.\n *\n * @throws Will throw an error if the package manager's version cannot be determined.\n */\nexport const getPackageManagerVersion = async (\n packageManager: string,\n options?: execa.Options\n): Promise<string> => {\n try {\n const { stdout } = await execa(packageManager, ['--version'], options);\n return stdout.trim();\n } catch (err) {\n throw new Error(`Error detecting ${packageManager} version: ${err}`);\n }\n};\n\n/**\n * Merges all matching semver ranges using a custom merge function.\n *\n * Iterates over the `versionMap`, checking if the provided `version` satisfies each semver range.\n * If it does, the corresponding value is merged using the provided `mergeFn`.\n * The merging starts with the value associated with the wildcard '*' key.\n *\n * @param version - The package manager version to check against the ranges.\n * @param versionMap - A map of semver ranges to corresponding values (arguments or environment variables).\n * @param mergeFn - A function that defines how to merge two values (accumulated and current).\n * @returns The merged result of all matching ranges.\n */\nfunction mergeMatchingVersionRanges<T>(\n version: string,\n versionMap: { [key: string]: T },\n mergeFn: (acc: T, curr: T) => T\n): T {\n return Object.keys(versionMap).reduce((acc, range) => {\n if (semver.satisfies(version, range) || range === '*') {\n return mergeFn(acc, versionMap[range]);\n }\n return acc;\n }, versionMap['*']); // Start with the wildcard entry\n}\n\nfunction mergeArguments(acc: string[], curr: string[]): string[] {\n return [...acc, ...curr];\n}\n\nfunction mergeEnvVars(\n acc: Record<string, string>,\n curr: Record<string, string>\n): Record<string, string> {\n return { ...acc, ...curr };\n}\n\n/**\n * Retrieves the install arguments and environment variables for a given package manager.\n *\n * This function determines the correct command line arguments and environment variables\n * based on the package manager's version. It uses predefined semver ranges to match\n * the package manager's version and merges all applicable settings.\n *\n * The arguments and environment variables are sourced from:\n * - `installArgumentsMap` for command line arguments.\n * - `installEnvMap` for environment variables.\n *\n * The function ensures that all matching semver ranges are considered and merged appropriately.\n * It always includes the base `installArguments` (e.g., `['install']`) and applies any additional\n * arguments or environment variables as defined by the matched version ranges.\n *\n * @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').\n * @param options - Optional execution options to pass to `execa`.\n * @returns An object containing:\n * - `cmdArgs`: The full array of install arguments for the given package manager and version.\n * - `envArgs`: The merged environment variables applicable to the package manager and version.\n *\n * @throws Will throw an error if the package manager version cannot be determined.\n */\nexport const getInstallArgs = async (packageManager: string, options?: execa.Options) => {\n const packageManagerVersion = await getPackageManagerVersion(packageManager, options);\n\n // Get environment variables\n const envMap = installEnvMap[packageManager];\n const envArgs = packageManagerVersion\n ? mergeMatchingVersionRanges(packageManagerVersion, envMap, mergeEnvVars)\n : envMap['*'];\n\n // Get install arguments\n const argsMap = installArgumentsMap[packageManager];\n const cmdArgs = packageManagerVersion\n ? mergeMatchingVersionRanges(packageManagerVersion, argsMap, mergeArguments)\n : argsMap['*'];\n\n return { envArgs, cmdArgs: [...installArguments, ...cmdArgs], version: packageManagerVersion };\n};\n"],"names":["installArguments","installArgumentsMap","npm","yarn","pnpm","installEnvMap","YARN_HTTP_TIMEOUT","getPackageManagerVersion","packageManager","options","stdout","execa","trim","err","Error","mergeMatchingVersionRanges","version","versionMap","mergeFn","Object","keys","reduce","acc","range","semver","satisfies","mergeArguments","curr","mergeEnvVars","getInstallArgs","packageManagerVersion","envMap","envArgs","argsMap","cmdArgs"],"mappings":"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"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import semver from 'semver';
|
|
3
|
+
|
|
4
|
+
const installArguments = [
|
|
5
|
+
'install'
|
|
6
|
+
];
|
|
7
|
+
// Set command line options for specific package managers, with full semver ranges
|
|
8
|
+
const installArgumentsMap = {
|
|
9
|
+
npm: {
|
|
10
|
+
'*': [
|
|
11
|
+
'--legacy-peer-deps'
|
|
12
|
+
]
|
|
13
|
+
},
|
|
14
|
+
yarn: {
|
|
15
|
+
'<4': [
|
|
16
|
+
'--network-timeout',
|
|
17
|
+
'1000000'
|
|
18
|
+
],
|
|
19
|
+
'*': []
|
|
20
|
+
},
|
|
21
|
+
pnpm: {
|
|
22
|
+
'*': []
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
// Set environment variables for specific package managers, with full semver ranges
|
|
26
|
+
const installEnvMap = {
|
|
27
|
+
yarn: {
|
|
28
|
+
'>=4': {
|
|
29
|
+
YARN_HTTP_TIMEOUT: '1000000'
|
|
30
|
+
},
|
|
31
|
+
'*': {}
|
|
32
|
+
},
|
|
33
|
+
npm: {
|
|
34
|
+
'*': {}
|
|
35
|
+
},
|
|
36
|
+
pnpm: {
|
|
37
|
+
'*': {}
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Retrieves the version of the specified package manager.
|
|
42
|
+
*
|
|
43
|
+
* Executes the package manager's `--version` command to determine its version.
|
|
44
|
+
*
|
|
45
|
+
* @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').
|
|
46
|
+
* @param options - Optional execution options to pass to `execa`.
|
|
47
|
+
* @returns A promise that resolves to the trimmed version string of the package manager.
|
|
48
|
+
*
|
|
49
|
+
* @throws Will throw an error if the package manager's version cannot be determined.
|
|
50
|
+
*/ const getPackageManagerVersion = async (packageManager, options)=>{
|
|
51
|
+
try {
|
|
52
|
+
const { stdout } = await execa(packageManager, [
|
|
53
|
+
'--version'
|
|
54
|
+
], options);
|
|
55
|
+
return stdout.trim();
|
|
56
|
+
} catch (err) {
|
|
57
|
+
throw new Error(`Error detecting ${packageManager} version: ${err}`);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* Merges all matching semver ranges using a custom merge function.
|
|
62
|
+
*
|
|
63
|
+
* Iterates over the `versionMap`, checking if the provided `version` satisfies each semver range.
|
|
64
|
+
* If it does, the corresponding value is merged using the provided `mergeFn`.
|
|
65
|
+
* The merging starts with the value associated with the wildcard '*' key.
|
|
66
|
+
*
|
|
67
|
+
* @param version - The package manager version to check against the ranges.
|
|
68
|
+
* @param versionMap - A map of semver ranges to corresponding values (arguments or environment variables).
|
|
69
|
+
* @param mergeFn - A function that defines how to merge two values (accumulated and current).
|
|
70
|
+
* @returns The merged result of all matching ranges.
|
|
71
|
+
*/ function mergeMatchingVersionRanges(version, versionMap, mergeFn) {
|
|
72
|
+
return Object.keys(versionMap).reduce((acc, range)=>{
|
|
73
|
+
if (semver.satisfies(version, range) || range === '*') {
|
|
74
|
+
return mergeFn(acc, versionMap[range]);
|
|
75
|
+
}
|
|
76
|
+
return acc;
|
|
77
|
+
}, versionMap['*']); // Start with the wildcard entry
|
|
78
|
+
}
|
|
79
|
+
function mergeArguments(acc, curr) {
|
|
80
|
+
return [
|
|
81
|
+
...acc,
|
|
82
|
+
...curr
|
|
83
|
+
];
|
|
84
|
+
}
|
|
85
|
+
function mergeEnvVars(acc, curr) {
|
|
86
|
+
return {
|
|
87
|
+
...acc,
|
|
88
|
+
...curr
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Retrieves the install arguments and environment variables for a given package manager.
|
|
93
|
+
*
|
|
94
|
+
* This function determines the correct command line arguments and environment variables
|
|
95
|
+
* based on the package manager's version. It uses predefined semver ranges to match
|
|
96
|
+
* the package manager's version and merges all applicable settings.
|
|
97
|
+
*
|
|
98
|
+
* The arguments and environment variables are sourced from:
|
|
99
|
+
* - `installArgumentsMap` for command line arguments.
|
|
100
|
+
* - `installEnvMap` for environment variables.
|
|
101
|
+
*
|
|
102
|
+
* The function ensures that all matching semver ranges are considered and merged appropriately.
|
|
103
|
+
* It always includes the base `installArguments` (e.g., `['install']`) and applies any additional
|
|
104
|
+
* arguments or environment variables as defined by the matched version ranges.
|
|
105
|
+
*
|
|
106
|
+
* @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').
|
|
107
|
+
* @param options - Optional execution options to pass to `execa`.
|
|
108
|
+
* @returns An object containing:
|
|
109
|
+
* - `cmdArgs`: The full array of install arguments for the given package manager and version.
|
|
110
|
+
* - `envArgs`: The merged environment variables applicable to the package manager and version.
|
|
111
|
+
*
|
|
112
|
+
* @throws Will throw an error if the package manager version cannot be determined.
|
|
113
|
+
*/ const getInstallArgs = async (packageManager, options)=>{
|
|
114
|
+
const packageManagerVersion = await getPackageManagerVersion(packageManager, options);
|
|
115
|
+
// Get environment variables
|
|
116
|
+
const envMap = installEnvMap[packageManager];
|
|
117
|
+
const envArgs = packageManagerVersion ? mergeMatchingVersionRanges(packageManagerVersion, envMap, mergeEnvVars) : envMap['*'];
|
|
118
|
+
// Get install arguments
|
|
119
|
+
const argsMap = installArgumentsMap[packageManager];
|
|
120
|
+
const cmdArgs = packageManagerVersion ? mergeMatchingVersionRanges(packageManagerVersion, argsMap, mergeArguments) : argsMap['*'];
|
|
121
|
+
return {
|
|
122
|
+
envArgs,
|
|
123
|
+
cmdArgs: [
|
|
124
|
+
...installArguments,
|
|
125
|
+
...cmdArgs
|
|
126
|
+
],
|
|
127
|
+
version: packageManagerVersion
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
export { getInstallArgs, getPackageManagerVersion };
|
|
132
|
+
//# sourceMappingURL=get-package-manager-args.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-package-manager-args.mjs","sources":["../../src/utils/get-package-manager-args.ts"],"sourcesContent":["import execa from 'execa';\nimport semver from 'semver';\n\nconst installArguments = ['install'];\n\ntype VersionedArgumentsMap = {\n [key: string]: string[]; // Maps semver ranges to argument arrays\n};\n\ntype VersionedEnvMap = {\n [key: string]: Record<string, string>; // Maps semver ranges to environment variables\n};\n\n// Set command line options for specific package managers, with full semver ranges\nconst installArgumentsMap: {\n [key: string]: VersionedArgumentsMap;\n} = {\n npm: {\n '*': ['--legacy-peer-deps'],\n },\n yarn: {\n '<4': ['--network-timeout', '1000000'],\n '*': [],\n },\n pnpm: {\n '*': [],\n },\n};\n\n// Set environment variables for specific package managers, with full semver ranges\nconst installEnvMap: {\n [key: string]: VersionedEnvMap;\n} = {\n yarn: {\n '>=4': { YARN_HTTP_TIMEOUT: '1000000' },\n '*': {},\n },\n npm: {\n '*': {},\n },\n pnpm: {\n '*': {},\n },\n};\n\n/**\n * Retrieves the version of the specified package manager.\n *\n * Executes the package manager's `--version` command to determine its version.\n *\n * @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').\n * @param options - Optional execution options to pass to `execa`.\n * @returns A promise that resolves to the trimmed version string of the package manager.\n *\n * @throws Will throw an error if the package manager's version cannot be determined.\n */\nexport const getPackageManagerVersion = async (\n packageManager: string,\n options?: execa.Options\n): Promise<string> => {\n try {\n const { stdout } = await execa(packageManager, ['--version'], options);\n return stdout.trim();\n } catch (err) {\n throw new Error(`Error detecting ${packageManager} version: ${err}`);\n }\n};\n\n/**\n * Merges all matching semver ranges using a custom merge function.\n *\n * Iterates over the `versionMap`, checking if the provided `version` satisfies each semver range.\n * If it does, the corresponding value is merged using the provided `mergeFn`.\n * The merging starts with the value associated with the wildcard '*' key.\n *\n * @param version - The package manager version to check against the ranges.\n * @param versionMap - A map of semver ranges to corresponding values (arguments or environment variables).\n * @param mergeFn - A function that defines how to merge two values (accumulated and current).\n * @returns The merged result of all matching ranges.\n */\nfunction mergeMatchingVersionRanges<T>(\n version: string,\n versionMap: { [key: string]: T },\n mergeFn: (acc: T, curr: T) => T\n): T {\n return Object.keys(versionMap).reduce((acc, range) => {\n if (semver.satisfies(version, range) || range === '*') {\n return mergeFn(acc, versionMap[range]);\n }\n return acc;\n }, versionMap['*']); // Start with the wildcard entry\n}\n\nfunction mergeArguments(acc: string[], curr: string[]): string[] {\n return [...acc, ...curr];\n}\n\nfunction mergeEnvVars(\n acc: Record<string, string>,\n curr: Record<string, string>\n): Record<string, string> {\n return { ...acc, ...curr };\n}\n\n/**\n * Retrieves the install arguments and environment variables for a given package manager.\n *\n * This function determines the correct command line arguments and environment variables\n * based on the package manager's version. It uses predefined semver ranges to match\n * the package manager's version and merges all applicable settings.\n *\n * The arguments and environment variables are sourced from:\n * - `installArgumentsMap` for command line arguments.\n * - `installEnvMap` for environment variables.\n *\n * The function ensures that all matching semver ranges are considered and merged appropriately.\n * It always includes the base `installArguments` (e.g., `['install']`) and applies any additional\n * arguments or environment variables as defined by the matched version ranges.\n *\n * @param packageManager - The name of the package manager (e.g., 'npm', 'yarn', 'pnpm').\n * @param options - Optional execution options to pass to `execa`.\n * @returns An object containing:\n * - `cmdArgs`: The full array of install arguments for the given package manager and version.\n * - `envArgs`: The merged environment variables applicable to the package manager and version.\n *\n * @throws Will throw an error if the package manager version cannot be determined.\n */\nexport const getInstallArgs = async (packageManager: string, options?: execa.Options) => {\n const packageManagerVersion = await getPackageManagerVersion(packageManager, options);\n\n // Get environment variables\n const envMap = installEnvMap[packageManager];\n const envArgs = packageManagerVersion\n ? mergeMatchingVersionRanges(packageManagerVersion, envMap, mergeEnvVars)\n : envMap['*'];\n\n // Get install arguments\n const argsMap = installArgumentsMap[packageManager];\n const cmdArgs = packageManagerVersion\n ? mergeMatchingVersionRanges(packageManagerVersion, argsMap, mergeArguments)\n : argsMap['*'];\n\n return { envArgs, cmdArgs: [...installArguments, ...cmdArgs], version: packageManagerVersion };\n};\n"],"names":["installArguments","installArgumentsMap","npm","yarn","pnpm","installEnvMap","YARN_HTTP_TIMEOUT","getPackageManagerVersion","packageManager","options","stdout","execa","trim","err","Error","mergeMatchingVersionRanges","version","versionMap","mergeFn","Object","keys","reduce","acc","range","semver","satisfies","mergeArguments","curr","mergeEnvVars","getInstallArgs","packageManagerVersion","envMap","envArgs","argsMap","cmdArgs"],"mappings":"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"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var execa = require('execa');
|
|
4
|
+
|
|
5
|
+
async function isInGitRepository(rootDir) {
|
|
6
|
+
try {
|
|
7
|
+
await execa('git', [
|
|
8
|
+
'rev-parse',
|
|
9
|
+
'--is-inside-work-tree'
|
|
10
|
+
], {
|
|
11
|
+
stdio: 'ignore',
|
|
12
|
+
cwd: rootDir
|
|
13
|
+
});
|
|
14
|
+
return true;
|
|
15
|
+
} catch (_) {
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
async function isInMercurialRepository(rootDir) {
|
|
20
|
+
try {
|
|
21
|
+
await execa('hg', [
|
|
22
|
+
'-cwd',
|
|
23
|
+
'.',
|
|
24
|
+
'root'
|
|
25
|
+
], {
|
|
26
|
+
stdio: 'ignore',
|
|
27
|
+
cwd: rootDir
|
|
28
|
+
});
|
|
29
|
+
return true;
|
|
30
|
+
} catch (_) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async function tryGitInit(rootDir) {
|
|
35
|
+
try {
|
|
36
|
+
await execa('git', [
|
|
37
|
+
'--version'
|
|
38
|
+
], {
|
|
39
|
+
stdio: 'ignore'
|
|
40
|
+
});
|
|
41
|
+
if (await isInGitRepository(rootDir) || await isInMercurialRepository(rootDir)) {
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
await execa('git', [
|
|
45
|
+
'init'
|
|
46
|
+
], {
|
|
47
|
+
stdio: 'ignore',
|
|
48
|
+
cwd: rootDir
|
|
49
|
+
});
|
|
50
|
+
await execa('git', [
|
|
51
|
+
'add',
|
|
52
|
+
'.'
|
|
53
|
+
], {
|
|
54
|
+
stdio: 'ignore',
|
|
55
|
+
cwd: rootDir
|
|
56
|
+
});
|
|
57
|
+
await execa('git', [
|
|
58
|
+
'commit',
|
|
59
|
+
'-m',
|
|
60
|
+
'Initial commit from Strapi'
|
|
61
|
+
], {
|
|
62
|
+
stdio: 'ignore',
|
|
63
|
+
cwd: rootDir
|
|
64
|
+
});
|
|
65
|
+
return true;
|
|
66
|
+
} catch (e) {
|
|
67
|
+
console.error('Error while trying to initialize git:', e);
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
exports.tryGitInit = tryGitInit;
|
|
73
|
+
//# sourceMappingURL=git.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git.js","sources":["../../src/utils/git.ts"],"sourcesContent":["import execa from 'execa';\n\nasync function isInGitRepository(rootDir: string) {\n try {\n await execa('git', ['rev-parse', '--is-inside-work-tree'], { stdio: 'ignore', cwd: rootDir });\n return true;\n } catch (_) {\n return false;\n }\n}\n\nasync function isInMercurialRepository(rootDir: string) {\n try {\n await execa('hg', ['-cwd', '.', 'root'], { stdio: 'ignore', cwd: rootDir });\n return true;\n } catch (_) {\n return false;\n }\n}\n\nexport async function tryGitInit(rootDir: string) {\n try {\n await execa('git', ['--version'], { stdio: 'ignore' });\n if ((await isInGitRepository(rootDir)) || (await isInMercurialRepository(rootDir))) {\n return false;\n }\n\n await execa('git', ['init'], { stdio: 'ignore', cwd: rootDir });\n\n await execa('git', ['add', '.'], { stdio: 'ignore', cwd: rootDir });\n await execa('git', ['commit', '-m', 'Initial commit from Strapi'], {\n stdio: 'ignore',\n cwd: rootDir,\n });\n\n return true;\n } catch (e) {\n console.error('Error while trying to initialize git:', e);\n return false;\n }\n}\n"],"names":["isInGitRepository","rootDir","execa","stdio","cwd","_","isInMercurialRepository","tryGitInit","e","console","error"],"mappings":";;;;AAEA,eAAeA,kBAAkBC,OAAe,EAAA;IAC9C,IAAI;AACF,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,WAAA;AAAa,YAAA;SAAwB,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;QAC3F,OAAO,IAAA;AACT,KAAA,CAAE,OAAOI,CAAG,EAAA;QACV,OAAO,KAAA;AACT;AACF;AAEA,eAAeC,wBAAwBL,OAAe,EAAA;IACpD,IAAI;AACF,QAAA,MAAMC,MAAM,IAAM,EAAA;AAAC,YAAA,MAAA;AAAQ,YAAA,GAAA;AAAK,YAAA;SAAO,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;QACzE,OAAO,IAAA;AACT,KAAA,CAAE,OAAOI,CAAG,EAAA;QACV,OAAO,KAAA;AACT;AACF;AAEO,eAAeE,WAAWN,OAAe,EAAA;IAC9C,IAAI;AACF,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA;SAAY,EAAE;YAAEC,KAAO,EAAA;AAAS,SAAA,CAAA;AACpD,QAAA,IAAI,MAAOH,iBAAAA,CAAkBC,OAAc,CAAA,IAAA,MAAMK,wBAAwBL,OAAW,CAAA,EAAA;YAClF,OAAO,KAAA;AACT;AAEA,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA;SAAO,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;AAE7D,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA;SAAI,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;AACjE,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,QAAA;AAAU,YAAA,IAAA;AAAM,YAAA;SAA6B,EAAE;YACjEC,KAAO,EAAA,QAAA;YACPC,GAAKH,EAAAA;AACP,SAAA,CAAA;QAEA,OAAO,IAAA;AACT,KAAA,CAAE,OAAOO,CAAG,EAAA;QACVC,OAAQC,CAAAA,KAAK,CAAC,uCAAyCF,EAAAA,CAAAA,CAAAA;QACvD,OAAO,KAAA;AACT;AACF;;;;"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
|
|
3
|
+
async function isInGitRepository(rootDir) {
|
|
4
|
+
try {
|
|
5
|
+
await execa('git', [
|
|
6
|
+
'rev-parse',
|
|
7
|
+
'--is-inside-work-tree'
|
|
8
|
+
], {
|
|
9
|
+
stdio: 'ignore',
|
|
10
|
+
cwd: rootDir
|
|
11
|
+
});
|
|
12
|
+
return true;
|
|
13
|
+
} catch (_) {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
async function isInMercurialRepository(rootDir) {
|
|
18
|
+
try {
|
|
19
|
+
await execa('hg', [
|
|
20
|
+
'-cwd',
|
|
21
|
+
'.',
|
|
22
|
+
'root'
|
|
23
|
+
], {
|
|
24
|
+
stdio: 'ignore',
|
|
25
|
+
cwd: rootDir
|
|
26
|
+
});
|
|
27
|
+
return true;
|
|
28
|
+
} catch (_) {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async function tryGitInit(rootDir) {
|
|
33
|
+
try {
|
|
34
|
+
await execa('git', [
|
|
35
|
+
'--version'
|
|
36
|
+
], {
|
|
37
|
+
stdio: 'ignore'
|
|
38
|
+
});
|
|
39
|
+
if (await isInGitRepository(rootDir) || await isInMercurialRepository(rootDir)) {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
await execa('git', [
|
|
43
|
+
'init'
|
|
44
|
+
], {
|
|
45
|
+
stdio: 'ignore',
|
|
46
|
+
cwd: rootDir
|
|
47
|
+
});
|
|
48
|
+
await execa('git', [
|
|
49
|
+
'add',
|
|
50
|
+
'.'
|
|
51
|
+
], {
|
|
52
|
+
stdio: 'ignore',
|
|
53
|
+
cwd: rootDir
|
|
54
|
+
});
|
|
55
|
+
await execa('git', [
|
|
56
|
+
'commit',
|
|
57
|
+
'-m',
|
|
58
|
+
'Initial commit from Strapi'
|
|
59
|
+
], {
|
|
60
|
+
stdio: 'ignore',
|
|
61
|
+
cwd: rootDir
|
|
62
|
+
});
|
|
63
|
+
return true;
|
|
64
|
+
} catch (e) {
|
|
65
|
+
console.error('Error while trying to initialize git:', e);
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export { tryGitInit };
|
|
71
|
+
//# sourceMappingURL=git.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git.mjs","sources":["../../src/utils/git.ts"],"sourcesContent":["import execa from 'execa';\n\nasync function isInGitRepository(rootDir: string) {\n try {\n await execa('git', ['rev-parse', '--is-inside-work-tree'], { stdio: 'ignore', cwd: rootDir });\n return true;\n } catch (_) {\n return false;\n }\n}\n\nasync function isInMercurialRepository(rootDir: string) {\n try {\n await execa('hg', ['-cwd', '.', 'root'], { stdio: 'ignore', cwd: rootDir });\n return true;\n } catch (_) {\n return false;\n }\n}\n\nexport async function tryGitInit(rootDir: string) {\n try {\n await execa('git', ['--version'], { stdio: 'ignore' });\n if ((await isInGitRepository(rootDir)) || (await isInMercurialRepository(rootDir))) {\n return false;\n }\n\n await execa('git', ['init'], { stdio: 'ignore', cwd: rootDir });\n\n await execa('git', ['add', '.'], { stdio: 'ignore', cwd: rootDir });\n await execa('git', ['commit', '-m', 'Initial commit from Strapi'], {\n stdio: 'ignore',\n cwd: rootDir,\n });\n\n return true;\n } catch (e) {\n console.error('Error while trying to initialize git:', e);\n return false;\n }\n}\n"],"names":["isInGitRepository","rootDir","execa","stdio","cwd","_","isInMercurialRepository","tryGitInit","e","console","error"],"mappings":";;AAEA,eAAeA,kBAAkBC,OAAe,EAAA;IAC9C,IAAI;AACF,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,WAAA;AAAa,YAAA;SAAwB,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;QAC3F,OAAO,IAAA;AACT,KAAA,CAAE,OAAOI,CAAG,EAAA;QACV,OAAO,KAAA;AACT;AACF;AAEA,eAAeC,wBAAwBL,OAAe,EAAA;IACpD,IAAI;AACF,QAAA,MAAMC,MAAM,IAAM,EAAA;AAAC,YAAA,MAAA;AAAQ,YAAA,GAAA;AAAK,YAAA;SAAO,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;QACzE,OAAO,IAAA;AACT,KAAA,CAAE,OAAOI,CAAG,EAAA;QACV,OAAO,KAAA;AACT;AACF;AAEO,eAAeE,WAAWN,OAAe,EAAA;IAC9C,IAAI;AACF,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA;SAAY,EAAE;YAAEC,KAAO,EAAA;AAAS,SAAA,CAAA;AACpD,QAAA,IAAI,MAAOH,iBAAAA,CAAkBC,OAAc,CAAA,IAAA,MAAMK,wBAAwBL,OAAW,CAAA,EAAA;YAClF,OAAO,KAAA;AACT;AAEA,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA;SAAO,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;AAE7D,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA;SAAI,EAAE;YAAEC,KAAO,EAAA,QAAA;YAAUC,GAAKH,EAAAA;AAAQ,SAAA,CAAA;AACjE,QAAA,MAAMC,MAAM,KAAO,EAAA;AAAC,YAAA,QAAA;AAAU,YAAA,IAAA;AAAM,YAAA;SAA6B,EAAE;YACjEC,KAAO,EAAA,QAAA;YACPC,GAAKH,EAAAA;AACP,SAAA,CAAA;QAEA,OAAO,IAAA;AACT,KAAA,CAAE,OAAOO,CAAG,EAAA;QACVC,OAAQC,CAAAA,KAAK,CAAC,uCAAyCF,EAAAA,CAAAA,CAAAA;QACvD,OAAO,KAAA;AACT;AACF;;;;"}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const baseGitIgnore = `
|
|
4
|
+
############################
|
|
5
|
+
# OS X
|
|
6
|
+
############################
|
|
7
|
+
|
|
8
|
+
.DS_Store
|
|
9
|
+
.AppleDouble
|
|
10
|
+
.LSOverride
|
|
11
|
+
Icon
|
|
12
|
+
.Spotlight-V100
|
|
13
|
+
.Trashes
|
|
14
|
+
._*
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
############################
|
|
18
|
+
# Linux
|
|
19
|
+
############################
|
|
20
|
+
|
|
21
|
+
*~
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
############################
|
|
25
|
+
# Windows
|
|
26
|
+
############################
|
|
27
|
+
|
|
28
|
+
Thumbs.db
|
|
29
|
+
ehthumbs.db
|
|
30
|
+
Desktop.ini
|
|
31
|
+
$RECYCLE.BIN/
|
|
32
|
+
*.cab
|
|
33
|
+
*.msi
|
|
34
|
+
*.msm
|
|
35
|
+
*.msp
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
############################
|
|
39
|
+
# Packages
|
|
40
|
+
############################
|
|
41
|
+
|
|
42
|
+
*.7z
|
|
43
|
+
*.csv
|
|
44
|
+
*.dat
|
|
45
|
+
*.dmg
|
|
46
|
+
*.gz
|
|
47
|
+
*.iso
|
|
48
|
+
*.jar
|
|
49
|
+
*.rar
|
|
50
|
+
*.tar
|
|
51
|
+
*.zip
|
|
52
|
+
*.com
|
|
53
|
+
*.class
|
|
54
|
+
*.dll
|
|
55
|
+
*.exe
|
|
56
|
+
*.o
|
|
57
|
+
*.seed
|
|
58
|
+
*.so
|
|
59
|
+
*.swo
|
|
60
|
+
*.swp
|
|
61
|
+
*.swn
|
|
62
|
+
*.swm
|
|
63
|
+
*.out
|
|
64
|
+
*.pid
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
############################
|
|
68
|
+
# Logs and databases
|
|
69
|
+
############################
|
|
70
|
+
|
|
71
|
+
.tmp
|
|
72
|
+
*.log
|
|
73
|
+
*.sql
|
|
74
|
+
*.sqlite
|
|
75
|
+
*.sqlite3
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
############################
|
|
79
|
+
# Misc.
|
|
80
|
+
############################
|
|
81
|
+
|
|
82
|
+
*#
|
|
83
|
+
ssl
|
|
84
|
+
.idea
|
|
85
|
+
nbproject
|
|
86
|
+
public/uploads/*
|
|
87
|
+
!public/uploads/.gitkeep
|
|
88
|
+
.tsbuildinfo
|
|
89
|
+
.eslintcache
|
|
90
|
+
|
|
91
|
+
############################
|
|
92
|
+
# Node.js
|
|
93
|
+
############################
|
|
94
|
+
|
|
95
|
+
lib-cov
|
|
96
|
+
lcov.info
|
|
97
|
+
pids
|
|
98
|
+
logs
|
|
99
|
+
results
|
|
100
|
+
node_modules
|
|
101
|
+
.node_history
|
|
102
|
+
|
|
103
|
+
############################
|
|
104
|
+
# Package managers
|
|
105
|
+
############################
|
|
106
|
+
|
|
107
|
+
.yarn/*
|
|
108
|
+
!.yarn/cache
|
|
109
|
+
!.yarn/unplugged
|
|
110
|
+
!.yarn/patches
|
|
111
|
+
!.yarn/releases
|
|
112
|
+
!.yarn/sdks
|
|
113
|
+
!.yarn/versions
|
|
114
|
+
.pnp.*
|
|
115
|
+
yarn-error.log
|
|
116
|
+
|
|
117
|
+
############################
|
|
118
|
+
# Tests
|
|
119
|
+
############################
|
|
120
|
+
|
|
121
|
+
coverage
|
|
122
|
+
|
|
123
|
+
############################
|
|
124
|
+
# Strapi
|
|
125
|
+
############################
|
|
126
|
+
|
|
127
|
+
.env
|
|
128
|
+
license.txt
|
|
129
|
+
exports
|
|
130
|
+
.strapi
|
|
131
|
+
dist
|
|
132
|
+
build
|
|
133
|
+
.strapi-updater.json
|
|
134
|
+
.strapi-cloud.json
|
|
135
|
+
`;
|
|
136
|
+
const gitIgnore = baseGitIgnore.trim();
|
|
137
|
+
|
|
138
|
+
exports.gitIgnore = gitIgnore;
|
|
139
|
+
//# sourceMappingURL=gitignore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitignore.js","sources":["../../src/utils/gitignore.ts"],"sourcesContent":["const baseGitIgnore = `\n############################\n# OS X\n############################\n\n.DS_Store\n.AppleDouble\n.LSOverride\nIcon\n.Spotlight-V100\n.Trashes\n._*\n\n\n############################\n# Linux\n############################\n\n*~\n\n\n############################\n# Windows\n############################\n\nThumbs.db\nehthumbs.db\nDesktop.ini\n$RECYCLE.BIN/\n*.cab\n*.msi\n*.msm\n*.msp\n\n\n############################\n# Packages\n############################\n\n*.7z\n*.csv\n*.dat\n*.dmg\n*.gz\n*.iso\n*.jar\n*.rar\n*.tar\n*.zip\n*.com\n*.class\n*.dll\n*.exe\n*.o\n*.seed\n*.so\n*.swo\n*.swp\n*.swn\n*.swm\n*.out\n*.pid\n\n\n############################\n# Logs and databases\n############################\n\n.tmp\n*.log\n*.sql\n*.sqlite\n*.sqlite3\n\n\n############################\n# Misc.\n############################\n\n*#\nssl\n.idea\nnbproject\npublic/uploads/*\n!public/uploads/.gitkeep\n.tsbuildinfo\n.eslintcache\n\n############################\n# Node.js\n############################\n\nlib-cov\nlcov.info\npids\nlogs\nresults\nnode_modules\n.node_history\n\n############################\n# Package managers\n############################\n\n.yarn/*\n!.yarn/cache\n!.yarn/unplugged\n!.yarn/patches\n!.yarn/releases\n!.yarn/sdks\n!.yarn/versions\n.pnp.*\nyarn-error.log\n\n############################\n# Tests\n############################\n\ncoverage\n\n############################\n# Strapi\n############################\n\n.env\nlicense.txt\nexports\n.strapi\ndist\nbuild\n.strapi-updater.json\n.strapi-cloud.json\n`;\n\nexport const gitIgnore = baseGitIgnore.trim();\n"],"names":["baseGitIgnore","gitIgnore","trim"],"mappings":";;AAAA,MAAMA,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoItB,CAAC;AAEYC,MAAAA,SAAAA,GAAYD,aAAcE,CAAAA,IAAI;;;;"}
|