0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2024-12-30 20:33:54 -05:00

feat(cli,core,shared): install demo connectors only in cloud (#3414)

This commit is contained in:
wangsijie 2023-03-15 15:24:31 +08:00 committed by GitHub
parent d8d1cfeeb5
commit 63938d6d4b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 31 additions and 11 deletions

View file

@ -25,7 +25,8 @@ packages/**/*.config.js packages/**/*.config.ts packages/**/tsconfig*.json \
-prune -exec rm -rf {} + -prune -exec rm -rf {} +
# Add official connectors # Add official connectors
pnpm cli connector add --official -p . cloud_option=$( [[ "$IS_CLOUD" =~ ^(1|true|y|yes|yep|yeah)$ ]] && echo "--cloud" || echo "" )
pnpm cli connector add --official $cloud_option -p .
echo Tar echo Tar
cd .. cd ..

View file

@ -5,7 +5,7 @@ import { addConnectors, addOfficialConnectors, inquireInstancePath } from './uti
const add: CommandModule< const add: CommandModule<
{ path?: string }, { path?: string },
{ packages?: string[]; path?: string; official: boolean } { packages?: string[]; path?: string; official: boolean; cloud: boolean }
> = { > = {
command: ['add [packages...]', 'a', 'install', 'i'], command: ['add [packages...]', 'a', 'install', 'i'],
describe: 'Add specific Logto connectors', describe: 'Add specific Logto connectors',
@ -24,12 +24,23 @@ const add: CommandModule<
describe: describe:
'Add all official connectors.\n' + 'Add all official connectors.\n' +
"If it's true, the specified package names will be ignored.", "If it's true, the specified package names will be ignored.",
})
.option('cloud', {
describe: 'Add additional connectors for Logto Cloud',
type: 'boolean',
default: false,
hidden: true,
}), }),
handler: async ({ packages: packageNames, path, official }) => { handler: async ({ packages: packageNames, path, official, cloud }) => {
const instancePath = await inquireInstancePath(path); const instancePath = await inquireInstancePath(path);
if (cloud && !official) {
log.error('--cloud option can only be used with --official option');
}
if (official) { if (official) {
await addOfficialConnectors(instancePath); // Add demo connectors for Logto Cloud only
await addOfficialConnectors(instancePath, cloud);
} else { } else {
if (!packageNames?.length) { if (!packageNames?.length) {
log.error('No connector name provided'); log.error('No connector name provided');

View file

@ -181,7 +181,7 @@ const officialConnectorPrefix = '@logto/connector-';
type PackageMeta = { name: string; scope: string; version: string }; type PackageMeta = { name: string; scope: string; version: string };
const fetchOfficialConnectorList = async () => { const fetchOfficialConnectorList = async (includingCloudConnectors = false) => {
// See https://github.com/npm/registry/blob/master/docs/REGISTRY-API.md#get-v1search // See https://github.com/npm/registry/blob/master/docs/REGISTRY-API.md#get-v1search
type FetchResult = { type FetchResult = {
objects: Array<{ objects: Array<{
@ -211,13 +211,15 @@ const fetchOfficialConnectorList = async () => {
// eslint-disable-next-line no-await-in-loop // eslint-disable-next-line no-await-in-loop
const { objects } = await fetchList(page * 20, 20); const { objects } = await fetchList(page * 20, 20);
const excludeList = ['mock', 'kit', ...(includingCloudConnectors ? [] : ['logto'])];
// eslint-disable-next-line @silverhand/fp/no-mutating-methods // eslint-disable-next-line @silverhand/fp/no-mutating-methods
packages.push( packages.push(
...objects ...objects
.filter( .filter(
({ package: { name, scope } }) => ({ package: { name, scope } }) =>
scope === 'logto' && scope === 'logto' &&
['mock', 'kit'].every( excludeList.every(
(excluded) => !name.slice(officialConnectorPrefix.length).startsWith(excluded) (excluded) => !name.slice(officialConnectorPrefix.length).startsWith(excluded)
) )
) )
@ -232,8 +234,11 @@ const fetchOfficialConnectorList = async () => {
return packages; return packages;
}; };
export const addOfficialConnectors = async (instancePath: string) => { export const addOfficialConnectors = async (
const packages = await oraPromise(fetchOfficialConnectorList(), { instancePath: string,
includingCloudConnectors = false
) => {
const packages = await oraPromise(fetchOfficialConnectorList(includingCloudConnectors), {
text: 'Fetch official connector list', text: 'Fetch official connector list',
prefixText: chalk.blue('[info]'), prefixText: chalk.blue('[info]'),
}); });

View file

@ -2,6 +2,7 @@ import { buildRawConnector } from '@logto/cli/lib/connector/index.js';
import { VerificationCodeType, validateConfig } from '@logto/connector-kit'; import { VerificationCodeType, validateConfig } from '@logto/connector-kit';
import { emailRegEx, phoneRegEx, buildIdGenerator } from '@logto/core-kit'; import { emailRegEx, phoneRegEx, buildIdGenerator } from '@logto/core-kit';
import { arbitraryObjectGuard, Connectors, ConnectorType } from '@logto/schemas'; import { arbitraryObjectGuard, Connectors, ConnectorType } from '@logto/schemas';
import { demoConnectorIds } from '@logto/shared';
import cleanDeep from 'clean-deep'; import cleanDeep from 'clean-deep';
import { string, object } from 'zod'; import { string, object } from 'zod';
@ -69,9 +70,9 @@ export default function connectorRoutes<T extends AuthedRouter>(
router.get('/connector-factories', async (ctx, next) => { router.get('/connector-factories', async (ctx, next) => {
const connectorFactories = await loadConnectorFactories(); const connectorFactories = await loadConnectorFactories();
ctx.body = connectorFactories.map((connectorFactory) => ctx.body = connectorFactories
transpileConnectorFactory(connectorFactory) .map((connectorFactory) => transpileConnectorFactory(connectorFactory))
); .filter(({ id }) => !demoConnectorIds.includes(id));
return next(); return next();
}); });

View file

@ -0,0 +1 @@
export const demoConnectorIds = ['logto-email', 'logto-sms'];

View file

@ -1 +1,2 @@
export * from './tenant.js'; export * from './tenant.js';
export * from './connector.js';