@cedarjs/cli-helpers 0.0.4
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/LICENSE +21 -0
- package/README.md +3 -0
- package/dist/auth/authFiles.d.ts +44 -0
- package/dist/auth/authFiles.d.ts.map +1 -0
- package/dist/auth/authFiles.js +74 -0
- package/dist/auth/authTasks.d.ts +49 -0
- package/dist/auth/authTasks.d.ts.map +1 -0
- package/dist/auth/authTasks.js +345 -0
- package/dist/auth/setupHelpers.d.ts +26 -0
- package/dist/auth/setupHelpers.d.ts.map +1 -0
- package/dist/auth/setupHelpers.js +127 -0
- package/dist/build.d.ts +2 -0
- package/dist/build.d.ts.map +1 -0
- package/dist/cjs/auth/authFiles.d.ts +44 -0
- package/dist/cjs/auth/authFiles.d.ts.map +1 -0
- package/dist/cjs/auth/authFiles.js +109 -0
- package/dist/cjs/auth/authTasks.d.ts +49 -0
- package/dist/cjs/auth/authTasks.d.ts.map +1 -0
- package/dist/cjs/auth/authTasks.js +384 -0
- package/dist/cjs/auth/setupHelpers.d.ts +26 -0
- package/dist/cjs/auth/setupHelpers.d.ts.map +1 -0
- package/dist/cjs/auth/setupHelpers.js +151 -0
- package/dist/cjs/index.d.ts +12 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +52 -0
- package/dist/cjs/lib/colors.d.ts +23 -0
- package/dist/cjs/lib/colors.d.ts.map +1 -0
- package/dist/cjs/lib/colors.js +52 -0
- package/dist/cjs/lib/index.d.ts +21 -0
- package/dist/cjs/lib/index.d.ts.map +1 -0
- package/dist/cjs/lib/index.js +140 -0
- package/dist/cjs/lib/installHelpers.d.ts +17 -0
- package/dist/cjs/lib/installHelpers.d.ts.map +1 -0
- package/dist/cjs/lib/installHelpers.js +72 -0
- package/dist/cjs/lib/loadEnvFiles.d.ts +5 -0
- package/dist/cjs/lib/loadEnvFiles.d.ts.map +1 -0
- package/dist/cjs/lib/loadEnvFiles.js +101 -0
- package/dist/cjs/lib/paths.d.ts +6 -0
- package/dist/cjs/lib/paths.d.ts.map +1 -0
- package/dist/cjs/lib/paths.js +42 -0
- package/dist/cjs/lib/project.d.ts +42 -0
- package/dist/cjs/lib/project.d.ts.map +1 -0
- package/dist/cjs/lib/project.js +265 -0
- package/dist/cjs/lib/version.d.ts +17 -0
- package/dist/cjs/lib/version.d.ts.map +1 -0
- package/dist/cjs/lib/version.js +107 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/telemetry/index.d.ts +20 -0
- package/dist/cjs/telemetry/index.d.ts.map +1 -0
- package/dist/cjs/telemetry/index.js +62 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/lib/colors.d.ts +23 -0
- package/dist/lib/colors.d.ts.map +1 -0
- package/dist/lib/colors.js +18 -0
- package/dist/lib/index.d.ts +21 -0
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/index.js +102 -0
- package/dist/lib/installHelpers.d.ts +17 -0
- package/dist/lib/installHelpers.d.ts.map +1 -0
- package/dist/lib/installHelpers.js +35 -0
- package/dist/lib/loadEnvFiles.d.ts +5 -0
- package/dist/lib/loadEnvFiles.d.ts.map +1 -0
- package/dist/lib/loadEnvFiles.js +64 -0
- package/dist/lib/paths.d.ts +6 -0
- package/dist/lib/paths.d.ts.map +1 -0
- package/dist/lib/paths.js +18 -0
- package/dist/lib/project.d.ts +42 -0
- package/dist/lib/project.d.ts.map +1 -0
- package/dist/lib/project.js +227 -0
- package/dist/lib/version.d.ts +17 -0
- package/dist/lib/version.d.ts.map +1 -0
- package/dist/lib/version.js +73 -0
- package/dist/package.json +1 -0
- package/dist/src/auth/__tests__/authFiles.test.d.ts +2 -0
- package/dist/src/auth/__tests__/authFiles.test.d.ts.map +1 -0
- package/dist/src/auth/__tests__/authTasks.test.d.ts +2 -0
- package/dist/src/auth/__tests__/authTasks.test.d.ts.map +1 -0
- package/dist/src/auth/__tests__/mockFsFiles.d.ts +14 -0
- package/dist/src/auth/__tests__/mockFsFiles.d.ts.map +1 -0
- package/dist/src/auth/__tests__/setupHelpers.test.d.ts +2 -0
- package/dist/src/auth/__tests__/setupHelpers.test.d.ts.map +1 -0
- package/dist/src/auth/authFiles.d.ts +44 -0
- package/dist/src/auth/authFiles.d.ts.map +1 -0
- package/dist/src/auth/authTasks.d.ts +49 -0
- package/dist/src/auth/authTasks.d.ts.map +1 -0
- package/dist/src/auth/setupHelpers.d.ts +26 -0
- package/dist/src/auth/setupHelpers.d.ts.map +1 -0
- package/dist/src/index.d.ts +12 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/lib/__tests__/index.test.d.ts +2 -0
- package/dist/src/lib/__tests__/index.test.d.ts.map +1 -0
- package/dist/src/lib/__tests__/loadEnvFiles.test.d.ts +2 -0
- package/dist/src/lib/__tests__/loadEnvFiles.test.d.ts.map +1 -0
- package/dist/src/lib/__tests__/project.addTomlSetting.test.d.ts +2 -0
- package/dist/src/lib/__tests__/project.addTomlSetting.test.d.ts.map +1 -0
- package/dist/src/lib/__tests__/project.test.d.ts +2 -0
- package/dist/src/lib/__tests__/project.test.d.ts.map +1 -0
- package/dist/src/lib/__tests__/version.test.d.ts +2 -0
- package/dist/src/lib/__tests__/version.test.d.ts.map +1 -0
- package/dist/src/lib/colors.d.ts +23 -0
- package/dist/src/lib/colors.d.ts.map +1 -0
- package/dist/src/lib/index.d.ts +21 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/installHelpers.d.ts +17 -0
- package/dist/src/lib/installHelpers.d.ts.map +1 -0
- package/dist/src/lib/loadEnvFiles.d.ts +5 -0
- package/dist/src/lib/loadEnvFiles.d.ts.map +1 -0
- package/dist/src/lib/paths.d.ts +6 -0
- package/dist/src/lib/paths.d.ts.map +1 -0
- package/dist/src/lib/project.d.ts +42 -0
- package/dist/src/lib/project.d.ts.map +1 -0
- package/dist/src/lib/version.d.ts +17 -0
- package/dist/src/lib/version.d.ts.map +1 -0
- package/dist/src/telemetry/index.d.ts +20 -0
- package/dist/src/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.d.ts +20 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +27 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/vitest.config.d.mts +3 -0
- package/dist/vitest.config.d.mts.map +1 -0
- package/package.json +91 -0
|
@@ -0,0 +1,384 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var authTasks_exports = {};
|
|
30
|
+
__export(authTasks_exports, {
|
|
31
|
+
addApiConfig: () => addApiConfig,
|
|
32
|
+
addAuthConfigToGqlApi: () => addAuthConfigToGqlApi,
|
|
33
|
+
addConfigToRoutes: () => addConfigToRoutes,
|
|
34
|
+
addConfigToWebApp: () => addConfigToWebApp,
|
|
35
|
+
createWebAuth: () => createWebAuth,
|
|
36
|
+
generateAuthApiFiles: () => generateAuthApiFiles,
|
|
37
|
+
getWebAppPath: () => getWebAppPath,
|
|
38
|
+
hasAuthProvider: () => hasAuthProvider,
|
|
39
|
+
removeAuthProvider: () => removeAuthProvider,
|
|
40
|
+
setAuthSetupMode: () => setAuthSetupMode
|
|
41
|
+
});
|
|
42
|
+
module.exports = __toCommonJS(authTasks_exports);
|
|
43
|
+
var import_fs = __toESM(require("fs"), 1);
|
|
44
|
+
var import_path = __toESM(require("path"), 1);
|
|
45
|
+
var import_prompt_adapter_enquirer = require("@listr2/prompt-adapter-enquirer");
|
|
46
|
+
var import_project_config = require("@cedarjs/project-config");
|
|
47
|
+
var import_colors = require("../lib/colors.js");
|
|
48
|
+
var import_lib = require("../lib/index.js");
|
|
49
|
+
var import_paths = require("../lib/paths.js");
|
|
50
|
+
var import_project = require("../lib/project.js");
|
|
51
|
+
var import_authFiles = require("./authFiles.js");
|
|
52
|
+
const AUTH_PROVIDER_HOOK_IMPORT = `import { AuthProvider, useAuth } from './auth'`;
|
|
53
|
+
const AUTH_HOOK_IMPORT = `import { useAuth } from './auth'`;
|
|
54
|
+
const getWebAppPath = () => (0, import_paths.getPaths)().web.app;
|
|
55
|
+
function addAuthDecoderToCreateGraphQLHandler(content) {
|
|
56
|
+
if (!new RegExp("(?=(^.*?createGraphQLHandler))\\1.*\\bauthDecoder", "s").test(
|
|
57
|
+
content
|
|
58
|
+
)) {
|
|
59
|
+
return content.replace(
|
|
60
|
+
/^(?<indentation>\s*)(loggerConfig:)(.*)$/m,
|
|
61
|
+
`$<indentation>authDecoder,
|
|
62
|
+
$<indentation>$2$3`
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
return content;
|
|
66
|
+
}
|
|
67
|
+
function replaceAuthDecoderImport(content, decoderImport) {
|
|
68
|
+
return content.replace(/^import { authDecoder .*} from .+/, decoderImport);
|
|
69
|
+
}
|
|
70
|
+
function replaceAuthDecoderArg(content) {
|
|
71
|
+
return content.replace(/^(\s+)authDecoder\b.+/m, "$1authDecoder,");
|
|
72
|
+
}
|
|
73
|
+
const addApiConfig = ({
|
|
74
|
+
replaceExistingImport,
|
|
75
|
+
authDecoderImport
|
|
76
|
+
}) => {
|
|
77
|
+
const graphqlPath = (0, import_project.getGraphqlPath)();
|
|
78
|
+
if (!graphqlPath) {
|
|
79
|
+
throw new Error("Could not find your graphql file path");
|
|
80
|
+
}
|
|
81
|
+
const content = import_fs.default.readFileSync(graphqlPath).toString();
|
|
82
|
+
let newContent = content;
|
|
83
|
+
if (authDecoderImport) {
|
|
84
|
+
if (replaceExistingImport) {
|
|
85
|
+
newContent = replaceAuthDecoderImport(newContent, authDecoderImport);
|
|
86
|
+
newContent = replaceAuthDecoderArg(newContent);
|
|
87
|
+
}
|
|
88
|
+
const didReplace = newContent.includes(authDecoderImport);
|
|
89
|
+
if (!replaceExistingImport || !didReplace) {
|
|
90
|
+
newContent = authDecoderImport + "\n" + newContent;
|
|
91
|
+
newContent = addAuthDecoderToCreateGraphQLHandler(newContent);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
const hasCurrentUserImport = /(^import {.*?getCurrentUser(?!getCurrentUser).*?} from ['"]src\/lib\/auth['"])/s.test(
|
|
95
|
+
newContent
|
|
96
|
+
);
|
|
97
|
+
if (!hasCurrentUserImport) {
|
|
98
|
+
newContent = newContent.replace(
|
|
99
|
+
/^(import { db } from ['"]src\/lib\/db['"])$/m,
|
|
100
|
+
`import { getCurrentUser } from 'src/lib/auth'
|
|
101
|
+
$1`
|
|
102
|
+
);
|
|
103
|
+
newContent = newContent.replace(
|
|
104
|
+
/^(\s*)(loggerConfig:)(.*)$/m,
|
|
105
|
+
`$1getCurrentUser,
|
|
106
|
+
$1$2$3`
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
if (newContent !== content) {
|
|
110
|
+
import_fs.default.writeFileSync(graphqlPath, newContent);
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
const apiSrcDoesExist = () => {
|
|
114
|
+
return import_fs.default.existsSync(import_path.default.join((0, import_paths.getPaths)().api.src));
|
|
115
|
+
};
|
|
116
|
+
const addAuthImportToApp = (content) => {
|
|
117
|
+
const contentLines = content.split("\n");
|
|
118
|
+
const importIndex = contentLines.findLastIndex(
|
|
119
|
+
(line) => /^\s*import (?!.*(?:.css['"]|.scss['"]))/.test(line)
|
|
120
|
+
);
|
|
121
|
+
contentLines.splice(importIndex + 1, 0, "", AUTH_PROVIDER_HOOK_IMPORT);
|
|
122
|
+
return contentLines.join("\n");
|
|
123
|
+
};
|
|
124
|
+
const addAuthImportToRoutes = (content) => {
|
|
125
|
+
const contentLines = content.split("\n");
|
|
126
|
+
const importIndex = contentLines.findLastIndex(
|
|
127
|
+
(line) => /^\s*import (?!.*(?:.css['"]|.scss['"]))/.test(line)
|
|
128
|
+
);
|
|
129
|
+
contentLines.splice(importIndex + 1, 0, "", AUTH_HOOK_IMPORT);
|
|
130
|
+
return contentLines.join("\n");
|
|
131
|
+
};
|
|
132
|
+
const hasAuthProvider = (content) => {
|
|
133
|
+
return /\s*<AuthProvider([\s>]|$)/.test(content);
|
|
134
|
+
};
|
|
135
|
+
const removeAuthProvider = (content) => {
|
|
136
|
+
let remove = false;
|
|
137
|
+
let end = "";
|
|
138
|
+
let unindent = false;
|
|
139
|
+
return content.split("\n").reduce((acc, line) => {
|
|
140
|
+
let keep = !remove;
|
|
141
|
+
if (hasAuthProvider(line)) {
|
|
142
|
+
remove = true;
|
|
143
|
+
keep = false;
|
|
144
|
+
unindent = true;
|
|
145
|
+
end = line.replace(/^(\s*)<Auth.*/s, "$1") + ">";
|
|
146
|
+
}
|
|
147
|
+
if (hasAuthProvider(line) && line.trimEnd().at(-1) === ">" || line.trimEnd() === end) {
|
|
148
|
+
remove = false;
|
|
149
|
+
}
|
|
150
|
+
if (/\s*<\/AuthProvider>/.test(line)) {
|
|
151
|
+
keep = false;
|
|
152
|
+
unindent = false;
|
|
153
|
+
}
|
|
154
|
+
if (keep) {
|
|
155
|
+
if (unindent) {
|
|
156
|
+
acc.push(line.replace(" ", ""));
|
|
157
|
+
} else {
|
|
158
|
+
acc.push(line);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
return acc;
|
|
162
|
+
}, []).join("\n");
|
|
163
|
+
};
|
|
164
|
+
const addAuthProviderToApp = (content, setupMode) => {
|
|
165
|
+
if (setupMode === "FORCE" || setupMode === "REPLACE") {
|
|
166
|
+
content = removeAuthProvider(content);
|
|
167
|
+
}
|
|
168
|
+
const match = content.match(
|
|
169
|
+
/(\s+)(<RedwoodProvider.*?>)(.*)(<\/RedwoodProvider>)/s
|
|
170
|
+
);
|
|
171
|
+
if (!match) {
|
|
172
|
+
throw new Error("Could not find <RedwoodProvider> in App.{jsx,tsx}");
|
|
173
|
+
}
|
|
174
|
+
if (/\s+<AuthProvider>/.test(content)) {
|
|
175
|
+
return content;
|
|
176
|
+
}
|
|
177
|
+
const [
|
|
178
|
+
_,
|
|
179
|
+
newlineAndIndent,
|
|
180
|
+
redwoodProviderOpen,
|
|
181
|
+
redwoodProviderChildren,
|
|
182
|
+
redwoodProviderClose
|
|
183
|
+
] = match;
|
|
184
|
+
const redwoodProviderChildrenLines = redwoodProviderChildren.split("\n").map((line, index) => {
|
|
185
|
+
return `${index === 0 ? "" : " "}` + line;
|
|
186
|
+
});
|
|
187
|
+
const renderContent = newlineAndIndent + redwoodProviderOpen + newlineAndIndent + ` <AuthProvider>` + redwoodProviderChildrenLines.join("\n") + `</AuthProvider>` + newlineAndIndent + redwoodProviderClose;
|
|
188
|
+
return content.replace(
|
|
189
|
+
/\s+<RedwoodProvider.*?>.*<\/RedwoodProvider>/s,
|
|
190
|
+
renderContent
|
|
191
|
+
);
|
|
192
|
+
};
|
|
193
|
+
const hasUseAuthHook = (componentName, content) => {
|
|
194
|
+
return new RegExp(
|
|
195
|
+
`<${componentName}.*useAuth={.*?}.*?>.*</${componentName}>`,
|
|
196
|
+
"s"
|
|
197
|
+
).test(content);
|
|
198
|
+
};
|
|
199
|
+
const addUseAuthHook = (componentName, content) => {
|
|
200
|
+
return content.replace(
|
|
201
|
+
`<${componentName}`,
|
|
202
|
+
`<${componentName} useAuth={useAuth}`
|
|
203
|
+
);
|
|
204
|
+
};
|
|
205
|
+
const addConfigToWebApp = () => {
|
|
206
|
+
return {
|
|
207
|
+
title: "Updating web/src/App.{jsx,tsx}",
|
|
208
|
+
task: (ctx, task) => {
|
|
209
|
+
const webAppPath = getWebAppPath();
|
|
210
|
+
if (!import_fs.default.existsSync(webAppPath)) {
|
|
211
|
+
const ext = (0, import_project.isTypeScriptProject)() ? "tsx" : "jsx";
|
|
212
|
+
throw new Error(`Could not find root App.${ext}`);
|
|
213
|
+
}
|
|
214
|
+
let content = import_fs.default.readFileSync(webAppPath, "utf-8");
|
|
215
|
+
if (!content.includes(AUTH_PROVIDER_HOOK_IMPORT)) {
|
|
216
|
+
content = addAuthImportToApp(content);
|
|
217
|
+
}
|
|
218
|
+
if (ctx.setupMode === "REPLACE" || ctx.setupMode === "FORCE") {
|
|
219
|
+
content = content.replace(
|
|
220
|
+
"import { AuthProvider } from '@cedarjs/auth'\n",
|
|
221
|
+
""
|
|
222
|
+
);
|
|
223
|
+
}
|
|
224
|
+
content = addAuthProviderToApp(content, ctx.setupMode);
|
|
225
|
+
if (/\s*<RedwoodApolloProvider/.test(content)) {
|
|
226
|
+
if (!hasUseAuthHook("RedwoodApolloProvider", content)) {
|
|
227
|
+
content = addUseAuthHook("RedwoodApolloProvider", content);
|
|
228
|
+
}
|
|
229
|
+
} else {
|
|
230
|
+
task.output = import_colors.colors.warning(
|
|
231
|
+
"Could not find <RedwoodApolloProvider>.\nIf you are using a custom GraphQL Client you will have to make sure it gets access to your `useAuth`, if it needs it."
|
|
232
|
+
);
|
|
233
|
+
}
|
|
234
|
+
import_fs.default.writeFileSync(webAppPath, content);
|
|
235
|
+
}
|
|
236
|
+
};
|
|
237
|
+
};
|
|
238
|
+
const createWebAuth = (basedir, webAuthn) => {
|
|
239
|
+
const templatesBaseDir = import_path.default.join(basedir, "templates", "web");
|
|
240
|
+
const templates = import_fs.default.readdirSync(templatesBaseDir);
|
|
241
|
+
const rscEnabled = (0, import_project_config.getConfig)().experimental?.rsc?.enabled;
|
|
242
|
+
const templateStart = "auth" + (webAuthn ? ".webAuthn" : "") + (rscEnabled ? ".rsc" : "") + ".ts";
|
|
243
|
+
const templateFileName = templates.find((template) => {
|
|
244
|
+
return template.startsWith(templateStart);
|
|
245
|
+
});
|
|
246
|
+
if (!templateFileName) {
|
|
247
|
+
throw new Error(
|
|
248
|
+
"Could not find the auth.ts(x) template, looking for filename starting with " + templateStart
|
|
249
|
+
);
|
|
250
|
+
}
|
|
251
|
+
const templateExtension = templateFileName.split(".").at(-2);
|
|
252
|
+
const isTSProject = (0, import_project.isTypeScriptProject)();
|
|
253
|
+
let ext = templateExtension;
|
|
254
|
+
if (!(0, import_project.isTypeScriptProject)()) {
|
|
255
|
+
ext = ext?.replace("ts", "js");
|
|
256
|
+
}
|
|
257
|
+
return {
|
|
258
|
+
title: `Creating web/src/auth.${ext}`,
|
|
259
|
+
task: async (ctx) => {
|
|
260
|
+
let authFileName = import_path.default.join((0, import_paths.getPaths)().web.src, "auth");
|
|
261
|
+
if (ctx.setupMode === "COMBINE") {
|
|
262
|
+
let i = 1;
|
|
263
|
+
while ((0, import_project_config.resolveFile)(authFileName)) {
|
|
264
|
+
const count = i > 1 ? i : "";
|
|
265
|
+
authFileName = import_path.default.join(
|
|
266
|
+
(0, import_paths.getPaths)().web.src,
|
|
267
|
+
ctx.provider + "Auth" + count
|
|
268
|
+
);
|
|
269
|
+
i++;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
authFileName = authFileName + "." + ext;
|
|
273
|
+
let template = import_fs.default.readFileSync(
|
|
274
|
+
import_path.default.join(templatesBaseDir, templateFileName),
|
|
275
|
+
"utf-8"
|
|
276
|
+
);
|
|
277
|
+
template = isTSProject ? template : await (0, import_lib.transformTSToJS)(authFileName, template);
|
|
278
|
+
import_fs.default.writeFileSync(authFileName, template);
|
|
279
|
+
}
|
|
280
|
+
};
|
|
281
|
+
};
|
|
282
|
+
const addConfigToRoutes = () => {
|
|
283
|
+
return {
|
|
284
|
+
title: "Updating Routes file...",
|
|
285
|
+
task: () => {
|
|
286
|
+
const webRoutesPath = (0, import_paths.getPaths)().web.routes;
|
|
287
|
+
let content = import_fs.default.readFileSync(webRoutesPath).toString();
|
|
288
|
+
if (!content.includes(AUTH_HOOK_IMPORT)) {
|
|
289
|
+
content = addAuthImportToRoutes(content);
|
|
290
|
+
}
|
|
291
|
+
if (!hasUseAuthHook("Router", content)) {
|
|
292
|
+
content = addUseAuthHook("Router", content);
|
|
293
|
+
}
|
|
294
|
+
import_fs.default.writeFileSync(webRoutesPath, content);
|
|
295
|
+
}
|
|
296
|
+
};
|
|
297
|
+
};
|
|
298
|
+
const generateAuthApiFiles = (basedir, webAuthn) => {
|
|
299
|
+
return {
|
|
300
|
+
title: "Generating auth api side files...",
|
|
301
|
+
task: async (ctx, task) => {
|
|
302
|
+
if (!apiSrcDoesExist()) {
|
|
303
|
+
return new Error(
|
|
304
|
+
"Could not find api/src directory. Cannot continue setup!"
|
|
305
|
+
);
|
|
306
|
+
}
|
|
307
|
+
let filesRecord = await (0, import_authFiles.apiSideFiles)({ basedir, webAuthn });
|
|
308
|
+
let existingFiles = "FAIL";
|
|
309
|
+
if (ctx.setupMode === "FORCE") {
|
|
310
|
+
existingFiles = "OVERWRITE";
|
|
311
|
+
} else if (ctx.setupMode === "REPLACE") {
|
|
312
|
+
const filesToOverwrite = findExistingFiles(filesRecord);
|
|
313
|
+
const prompt = task.prompt(import_prompt_adapter_enquirer.ListrEnquirerPromptAdapter);
|
|
314
|
+
const overwrite = await prompt.run({
|
|
315
|
+
type: "confirm",
|
|
316
|
+
message: `Overwrite existing ${filesToOverwrite.join(", ")}?`,
|
|
317
|
+
initial: false
|
|
318
|
+
});
|
|
319
|
+
existingFiles = overwrite ? "OVERWRITE" : "SKIP";
|
|
320
|
+
} else if (ctx.setupMode === "COMBINE") {
|
|
321
|
+
const uniqueFilesRecord = (0, import_authFiles.generateUniqueFileNames)(
|
|
322
|
+
filesRecord,
|
|
323
|
+
ctx.provider
|
|
324
|
+
);
|
|
325
|
+
filesRecord = uniqueFilesRecord;
|
|
326
|
+
existingFiles = "FAIL";
|
|
327
|
+
}
|
|
328
|
+
return (0, import_lib.writeFilesTask)(filesRecord, {
|
|
329
|
+
existingFiles
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
};
|
|
333
|
+
};
|
|
334
|
+
function findExistingFiles(filesMap) {
|
|
335
|
+
return Object.keys(filesMap).filter((filePath) => import_fs.default.existsSync(filePath)).map((filePath) => filePath.replace((0, import_paths.getPaths)().base, ""));
|
|
336
|
+
}
|
|
337
|
+
const addAuthConfigToGqlApi = (authDecoderImport) => ({
|
|
338
|
+
title: "Adding auth config to GraphQL API...",
|
|
339
|
+
task: (ctx, _task) => {
|
|
340
|
+
if ((0, import_project.graphFunctionDoesExist)()) {
|
|
341
|
+
addApiConfig({
|
|
342
|
+
authDecoderImport,
|
|
343
|
+
replaceExistingImport: ctx.setupMode === "REPLACE" || ctx.setupMode === "FORCE"
|
|
344
|
+
});
|
|
345
|
+
} else {
|
|
346
|
+
throw new Error(
|
|
347
|
+
"GraphQL function not found. You will need to pass the decoder to the createGraphQLHandler function."
|
|
348
|
+
);
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
});
|
|
352
|
+
const setAuthSetupMode = (force) => {
|
|
353
|
+
return {
|
|
354
|
+
title: "Checking project for existing auth...",
|
|
355
|
+
task: async (ctx, task) => {
|
|
356
|
+
if (force) {
|
|
357
|
+
ctx.setupMode = "FORCE";
|
|
358
|
+
return;
|
|
359
|
+
}
|
|
360
|
+
const webAppContents = import_fs.default.readFileSync(getWebAppPath(), "utf-8");
|
|
361
|
+
if (hasAuthProvider(webAppContents) && ctx.setupMode === "UNKNOWN") {
|
|
362
|
+
const setupMode = "REPLACE";
|
|
363
|
+
ctx.setupMode = setupMode;
|
|
364
|
+
return;
|
|
365
|
+
} else {
|
|
366
|
+
ctx.setupMode = "FORCE";
|
|
367
|
+
task.skip("Setting up Auth from scratch");
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
};
|
|
371
|
+
};
|
|
372
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
373
|
+
0 && (module.exports = {
|
|
374
|
+
addApiConfig,
|
|
375
|
+
addAuthConfigToGqlApi,
|
|
376
|
+
addConfigToRoutes,
|
|
377
|
+
addConfigToWebApp,
|
|
378
|
+
createWebAuth,
|
|
379
|
+
generateAuthApiFiles,
|
|
380
|
+
getWebAppPath,
|
|
381
|
+
hasAuthProvider,
|
|
382
|
+
removeAuthProvider,
|
|
383
|
+
setAuthSetupMode
|
|
384
|
+
});
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { ListrTask } from 'listr2';
|
|
2
|
+
import type { Argv } from 'yargs';
|
|
3
|
+
import type { AuthGeneratorCtx } from './authTasks.js';
|
|
4
|
+
export declare const standardAuthBuilder: (yargs: Argv) => Argv<{
|
|
5
|
+
force: boolean;
|
|
6
|
+
} & {
|
|
7
|
+
verbose: boolean;
|
|
8
|
+
}>;
|
|
9
|
+
export interface AuthHandlerArgs {
|
|
10
|
+
basedir: string;
|
|
11
|
+
forceArg: boolean;
|
|
12
|
+
provider: string;
|
|
13
|
+
authDecoderImport?: string;
|
|
14
|
+
webAuthn?: boolean;
|
|
15
|
+
webPackages?: string[];
|
|
16
|
+
apiPackages?: string[];
|
|
17
|
+
extraTasks?: (ListrTask<AuthGeneratorCtx> | undefined)[];
|
|
18
|
+
notes?: string[];
|
|
19
|
+
verbose?: boolean;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* basedir assumes that you must have a templates folder in that directory.
|
|
23
|
+
* See folder structure of auth providers in packages/auth-providers/<provider>/setup/src
|
|
24
|
+
*/
|
|
25
|
+
export declare const standardAuthHandler: ({ basedir, forceArg, provider, authDecoderImport, webAuthn, webPackages, apiPackages, extraTasks, notes, verbose, }: AuthHandlerArgs) => Promise<void>;
|
|
26
|
+
//# sourceMappingURL=setupHelpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setupHelpers.d.ts","sourceRoot":"","sources":["../../../src/auth/setupHelpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAGvC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,OAAO,CAAA;AAWjC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AAUtD,eAAO,MAAM,mBAAmB,UAAW,IAAI;;;;EAoB9C,CAAA;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,OAAO,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;IAChB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,UAAU,CAAC,EAAE,CAAC,SAAS,CAAC,gBAAgB,CAAC,GAAG,SAAS,CAAC,EAAE,CAAA;IACxD,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AASD;;;GAGG;AACH,eAAO,MAAM,mBAAmB,wHAW7B,eAAe,kBAiFjB,CAAA"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var setupHelpers_exports = {};
|
|
30
|
+
__export(setupHelpers_exports, {
|
|
31
|
+
standardAuthBuilder: () => standardAuthBuilder,
|
|
32
|
+
standardAuthHandler: () => standardAuthHandler
|
|
33
|
+
});
|
|
34
|
+
module.exports = __toCommonJS(setupHelpers_exports);
|
|
35
|
+
var import_listr2 = require("listr2");
|
|
36
|
+
var import_terminal_link = __toESM(require("terminal-link"), 1);
|
|
37
|
+
var import_telemetry = require("@cedarjs/telemetry");
|
|
38
|
+
var import_colors = require("../lib/colors.js");
|
|
39
|
+
var import_installHelpers = require("../lib/installHelpers.js");
|
|
40
|
+
var import_authTasks = require("./authTasks.js");
|
|
41
|
+
const standardAuthBuilder = (yargs) => {
|
|
42
|
+
return yargs.option("force", {
|
|
43
|
+
alias: "f",
|
|
44
|
+
default: false,
|
|
45
|
+
description: "Overwrite existing auth configuration",
|
|
46
|
+
type: "boolean"
|
|
47
|
+
}).option("verbose", {
|
|
48
|
+
alias: "v",
|
|
49
|
+
default: false,
|
|
50
|
+
description: "Log setup output",
|
|
51
|
+
type: "boolean"
|
|
52
|
+
}).epilogue(
|
|
53
|
+
`Also see the ${(0, import_terminal_link.default)(
|
|
54
|
+
"Redwood CLI Reference",
|
|
55
|
+
"https://redwoodjs.com/docs/cli-commands#setup-auth"
|
|
56
|
+
)}`
|
|
57
|
+
);
|
|
58
|
+
};
|
|
59
|
+
function truthy(value) {
|
|
60
|
+
return !!value;
|
|
61
|
+
}
|
|
62
|
+
const standardAuthHandler = async ({
|
|
63
|
+
basedir,
|
|
64
|
+
forceArg,
|
|
65
|
+
provider,
|
|
66
|
+
authDecoderImport,
|
|
67
|
+
webAuthn = false,
|
|
68
|
+
webPackages = [],
|
|
69
|
+
apiPackages = [],
|
|
70
|
+
extraTasks,
|
|
71
|
+
notes,
|
|
72
|
+
verbose
|
|
73
|
+
}) => {
|
|
74
|
+
const tasks = new import_listr2.Listr(
|
|
75
|
+
[
|
|
76
|
+
(0, import_authTasks.setAuthSetupMode)(forceArg),
|
|
77
|
+
(0, import_authTasks.generateAuthApiFiles)(basedir, webAuthn),
|
|
78
|
+
(0, import_authTasks.addConfigToWebApp)(),
|
|
79
|
+
(0, import_authTasks.createWebAuth)(basedir, webAuthn),
|
|
80
|
+
(0, import_authTasks.addConfigToRoutes)(),
|
|
81
|
+
(0, import_authTasks.addAuthConfigToGqlApi)(authDecoderImport),
|
|
82
|
+
webPackages.length && (0, import_installHelpers.addWebPackages)(webPackages),
|
|
83
|
+
apiPackages.length && (0, import_installHelpers.addApiPackages)(apiPackages),
|
|
84
|
+
(webPackages.length || apiPackages.length) && import_installHelpers.installPackages,
|
|
85
|
+
...(extraTasks || []).filter(truthy),
|
|
86
|
+
notes && {
|
|
87
|
+
title: "One more thing...",
|
|
88
|
+
task: (ctx) => {
|
|
89
|
+
if (ctx.setupMode === "REPLACE") {
|
|
90
|
+
notes.push(
|
|
91
|
+
...[
|
|
92
|
+
"",
|
|
93
|
+
`${import_colors.colors.warning(
|
|
94
|
+
"Your existing auth provider has been replaced!"
|
|
95
|
+
)}`,
|
|
96
|
+
"You'll still need to manually remove your old auth provider's config,",
|
|
97
|
+
"functions, and dependencies (in your web and api package.json's)."
|
|
98
|
+
]
|
|
99
|
+
);
|
|
100
|
+
}
|
|
101
|
+
if (ctx.setupMode === "COMBINE") {
|
|
102
|
+
notes.push(
|
|
103
|
+
import_colors.colors.warning(
|
|
104
|
+
`To avoid overwriting existing files we've generated new file names for the newly generated files. This probably means ${ctx.provider} auth doesn't work out of the box. You'll most likely have to manually merge some of the generated files with your existing auth files`
|
|
105
|
+
)
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
].filter(truthy),
|
|
111
|
+
{
|
|
112
|
+
rendererOptions: { collapseSubtasks: false },
|
|
113
|
+
renderer: verbose ? "verbose" : "default",
|
|
114
|
+
ctx: {
|
|
115
|
+
setupMode: "UNKNOWN",
|
|
116
|
+
provider,
|
|
117
|
+
// provider name passed from CLI
|
|
118
|
+
force: forceArg
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
);
|
|
122
|
+
try {
|
|
123
|
+
await tasks.run();
|
|
124
|
+
if (notes) {
|
|
125
|
+
console.log(`
|
|
126
|
+
${notes.join("\n ")}
|
|
127
|
+
`);
|
|
128
|
+
}
|
|
129
|
+
} catch (e) {
|
|
130
|
+
if (isErrorWithMessage(e)) {
|
|
131
|
+
(0, import_telemetry.errorTelemetry)(process.argv, e.message);
|
|
132
|
+
console.error(import_colors.colors.error(e.message));
|
|
133
|
+
}
|
|
134
|
+
if (isErrorWithErrorCode(e)) {
|
|
135
|
+
process.exit(e.exitCode || 1);
|
|
136
|
+
} else {
|
|
137
|
+
process.exit(1);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
function isErrorWithMessage(e) {
|
|
142
|
+
return !!e.message;
|
|
143
|
+
}
|
|
144
|
+
function isErrorWithErrorCode(e) {
|
|
145
|
+
return !isNaN(e.exitCode);
|
|
146
|
+
}
|
|
147
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
148
|
+
0 && (module.exports = {
|
|
149
|
+
standardAuthBuilder,
|
|
150
|
+
standardAuthHandler
|
|
151
|
+
});
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export * from './lib/index.js';
|
|
2
|
+
export * from './lib/colors.js';
|
|
3
|
+
export { loadEnvFiles } from './lib/loadEnvFiles.js';
|
|
4
|
+
export { loadDefaultEnvFiles, loadNodeEnvDerivedEnvFile, loadUserSpecifiedEnvFiles, } from './lib/loadEnvFiles.js';
|
|
5
|
+
export * from './lib/paths.js';
|
|
6
|
+
export * from './lib/project.js';
|
|
7
|
+
export * from './lib/version.js';
|
|
8
|
+
export * from './auth/setupHelpers.js';
|
|
9
|
+
export type { AuthHandlerArgs } from './auth/setupHelpers.js';
|
|
10
|
+
export * from './lib/installHelpers.js';
|
|
11
|
+
export * from './telemetry/index.js';
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAGA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,iBAAiB,CAAA;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EACL,mBAAmB,EACnB,yBAAyB,EACzB,yBAAyB,GAC1B,MAAM,uBAAuB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA;AACtC,YAAY,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AAE7D,cAAc,yBAAyB,CAAA;AAEvC,cAAc,sBAAsB,CAAA"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
19
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
+
var index_exports = {};
|
|
21
|
+
__export(index_exports, {
|
|
22
|
+
loadDefaultEnvFiles: () => import_loadEnvFiles2.loadDefaultEnvFiles,
|
|
23
|
+
loadEnvFiles: () => import_loadEnvFiles.loadEnvFiles,
|
|
24
|
+
loadNodeEnvDerivedEnvFile: () => import_loadEnvFiles2.loadNodeEnvDerivedEnvFile,
|
|
25
|
+
loadUserSpecifiedEnvFiles: () => import_loadEnvFiles2.loadUserSpecifiedEnvFiles
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(index_exports);
|
|
28
|
+
__reExport(index_exports, require("./lib/index.js"), module.exports);
|
|
29
|
+
__reExport(index_exports, require("./lib/colors.js"), module.exports);
|
|
30
|
+
var import_loadEnvFiles = require("./lib/loadEnvFiles.js");
|
|
31
|
+
var import_loadEnvFiles2 = require("./lib/loadEnvFiles.js");
|
|
32
|
+
__reExport(index_exports, require("./lib/paths.js"), module.exports);
|
|
33
|
+
__reExport(index_exports, require("./lib/project.js"), module.exports);
|
|
34
|
+
__reExport(index_exports, require("./lib/version.js"), module.exports);
|
|
35
|
+
__reExport(index_exports, require("./auth/setupHelpers.js"), module.exports);
|
|
36
|
+
__reExport(index_exports, require("./lib/installHelpers.js"), module.exports);
|
|
37
|
+
__reExport(index_exports, require("./telemetry/index.js"), module.exports);
|
|
38
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
39
|
+
0 && (module.exports = {
|
|
40
|
+
loadDefaultEnvFiles,
|
|
41
|
+
loadEnvFiles,
|
|
42
|
+
loadNodeEnvDerivedEnvFile,
|
|
43
|
+
loadUserSpecifiedEnvFiles,
|
|
44
|
+
...require("./lib/index.js"),
|
|
45
|
+
...require("./lib/colors.js"),
|
|
46
|
+
...require("./lib/paths.js"),
|
|
47
|
+
...require("./lib/project.js"),
|
|
48
|
+
...require("./lib/version.js"),
|
|
49
|
+
...require("./auth/setupHelpers.js"),
|
|
50
|
+
...require("./lib/installHelpers.js"),
|
|
51
|
+
...require("./telemetry/index.js")
|
|
52
|
+
});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
/**
|
|
3
|
+
* To keep a consistent color/style palette between cli packages, such as
|
|
4
|
+
* @redwood/cli and @redwood/create-cedar-app, please only use the colors
|
|
5
|
+
* defined here. If you *really* can't find a color that fits your needs,
|
|
6
|
+
* it's better to add it here than to introduce a new one-off color in whatever
|
|
7
|
+
* package you're going to use it in.
|
|
8
|
+
*/
|
|
9
|
+
export declare const colors: {
|
|
10
|
+
error: chalk.Chalk;
|
|
11
|
+
warning: chalk.Chalk;
|
|
12
|
+
highlight: chalk.Chalk;
|
|
13
|
+
success: chalk.Chalk;
|
|
14
|
+
info: chalk.Chalk;
|
|
15
|
+
bold: chalk.Chalk;
|
|
16
|
+
underline: chalk.Chalk;
|
|
17
|
+
note: chalk.Chalk;
|
|
18
|
+
tip: chalk.Chalk;
|
|
19
|
+
important: chalk.Chalk;
|
|
20
|
+
caution: chalk.Chalk;
|
|
21
|
+
link: chalk.Chalk;
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=colors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../../src/lib/colors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB;;;;;;GAMG;AACH,eAAO,MAAM,MAAM;;;;;;;;;;;;;CAalB,CAAA"}
|