mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
feat: add an internal for now studio package (#11037)
* feat: add an internal for now studio package * fix: remove test commands * fix: use getenvs from studio package * fix: packagejson * chore: changeset * fix: remove unused error * fix: of course Bjorn was right all along
This commit is contained in:
parent
3830e5d416
commit
9332bb1c1f
21 changed files with 186 additions and 37 deletions
5
.changeset/silent-socks-return.md
Normal file
5
.changeset/silent-socks-return.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
"@astrojs/db": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Internal refactor, this change should have no visible effect
|
5
.changeset/young-plums-doubt.md
Normal file
5
.changeset/young-plums-doubt.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
"@astrojs/studio": minor
|
||||||
|
---
|
||||||
|
|
||||||
|
Created package. This package contain shared code between integrations that interact with Astro Studio and is not intended to be used by end-users at this time
|
|
@ -70,6 +70,7 @@
|
||||||
"test:match": "mocha --timeout 20000 \"test/*.js\" \"test/unit/*.js\" -g"
|
"test:match": "mocha --timeout 20000 \"test/*.js\" \"test/unit/*.js\" -g"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@astrojs/studio": "workspace:*",
|
||||||
"@libsql/client": "^0.6.0",
|
"@libsql/client": "^0.6.0",
|
||||||
"async-listen": "^3.0.1",
|
"async-listen": "^3.0.1",
|
||||||
"ci-info": "^4.0.0",
|
"ci-info": "^4.0.0",
|
||||||
|
|
|
@ -14,7 +14,7 @@ import {
|
||||||
getStudioVirtualModContents,
|
getStudioVirtualModContents,
|
||||||
} from '../../../integration/vite-plugin-db.js';
|
} from '../../../integration/vite-plugin-db.js';
|
||||||
import { bundleFile, importBundledFile } from '../../../load-file.js';
|
import { bundleFile, importBundledFile } from '../../../load-file.js';
|
||||||
import { getManagedAppTokenOrExit } from '../../../tokens.js';
|
import { getManagedAppTokenOrExit } from '@astrojs/studio';
|
||||||
import type { DBConfig } from '../../../types.js';
|
import type { DBConfig } from '../../../types.js';
|
||||||
|
|
||||||
export async function cmd({
|
export async function cmd({
|
||||||
|
|
|
@ -6,9 +6,8 @@ import { bgRed, cyan } from 'kleur/colors';
|
||||||
import ora from 'ora';
|
import ora from 'ora';
|
||||||
import prompts from 'prompts';
|
import prompts from 'prompts';
|
||||||
import { safeFetch } from '../../../../runtime/utils.js';
|
import { safeFetch } from '../../../../runtime/utils.js';
|
||||||
import { MISSING_SESSION_ID_ERROR } from '../../../errors.js';
|
import { PROJECT_ID_FILE, MISSING_SESSION_ID_ERROR, getAstroStudioUrl, getSessionIdFromFile } from '@astrojs/studio';
|
||||||
import { PROJECT_ID_FILE, getSessionIdFromFile } from '../../../tokens.js';
|
import { type Result } from '../../../utils.js';
|
||||||
import { type Result, getAstroStudioUrl } from '../../../utils.js';
|
|
||||||
|
|
||||||
export async function cmd() {
|
export async function cmd() {
|
||||||
const sessionToken = await getSessionIdFromFile();
|
const sessionToken = await getSessionIdFromFile();
|
||||||
|
|
|
@ -7,9 +7,8 @@ import open from 'open';
|
||||||
import ora from 'ora';
|
import ora from 'ora';
|
||||||
import prompt from 'prompts';
|
import prompt from 'prompts';
|
||||||
import type { Arguments } from 'yargs-parser';
|
import type { Arguments } from 'yargs-parser';
|
||||||
import { SESSION_LOGIN_FILE } from '../../../tokens.js';
|
import { SESSION_LOGIN_FILE, getAstroStudioUrl } from '@astrojs/studio';
|
||||||
import type { DBConfig } from '../../../types.js';
|
import type { DBConfig } from '../../../types.js';
|
||||||
import { getAstroStudioUrl } from '../../../utils.js';
|
|
||||||
|
|
||||||
const isWebContainer =
|
const isWebContainer =
|
||||||
// Stackblitz heuristic
|
// Stackblitz heuristic
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { unlink } from 'node:fs/promises';
|
import { unlink } from 'node:fs/promises';
|
||||||
import { SESSION_LOGIN_FILE } from '../../../tokens.js';
|
import { SESSION_LOGIN_FILE } from '@astrojs/studio'
|
||||||
|
|
||||||
export async function cmd() {
|
export async function cmd() {
|
||||||
await unlink(SESSION_LOGIN_FILE);
|
await unlink(SESSION_LOGIN_FILE);
|
||||||
|
|
|
@ -3,7 +3,7 @@ import prompts from 'prompts';
|
||||||
import type { Arguments } from 'yargs-parser';
|
import type { Arguments } from 'yargs-parser';
|
||||||
import { safeFetch } from '../../../../runtime/utils.js';
|
import { safeFetch } from '../../../../runtime/utils.js';
|
||||||
import { MIGRATION_VERSION } from '../../../consts.js';
|
import { MIGRATION_VERSION } from '../../../consts.js';
|
||||||
import { getManagedAppTokenOrExit } from '../../../tokens.js';
|
import { getManagedAppTokenOrExit } from '@astrojs/studio';
|
||||||
import { type DBConfig, type DBSnapshot } from '../../../types.js';
|
import { type DBConfig, type DBSnapshot } from '../../../types.js';
|
||||||
import { type Result, getRemoteDatabaseUrl } from '../../../utils.js';
|
import { type Result, getRemoteDatabaseUrl } from '../../../utils.js';
|
||||||
import {
|
import {
|
||||||
|
|
|
@ -8,7 +8,7 @@ import {
|
||||||
import { normalizeDatabaseUrl } from '../../../../runtime/index.js';
|
import { normalizeDatabaseUrl } from '../../../../runtime/index.js';
|
||||||
import { DB_PATH } from '../../../consts.js';
|
import { DB_PATH } from '../../../consts.js';
|
||||||
import { SHELL_QUERY_MISSING_ERROR } from '../../../errors.js';
|
import { SHELL_QUERY_MISSING_ERROR } from '../../../errors.js';
|
||||||
import { getManagedAppTokenOrExit } from '../../../tokens.js';
|
import { getManagedAppTokenOrExit } from '@astrojs/studio';
|
||||||
import type { DBConfigInput } from '../../../types.js';
|
import type { DBConfigInput } from '../../../types.js';
|
||||||
import { getAstroEnv, getRemoteDatabaseUrl } from '../../../utils.js';
|
import { getAstroEnv, getRemoteDatabaseUrl } from '../../../utils.js';
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import type { AstroConfig } from 'astro';
|
import type { AstroConfig } from 'astro';
|
||||||
import type { Arguments } from 'yargs-parser';
|
import type { Arguments } from 'yargs-parser';
|
||||||
import { getManagedAppTokenOrExit } from '../../../tokens.js';
|
import { getManagedAppTokenOrExit } from '@astrojs/studio';
|
||||||
import type { DBConfig } from '../../../types.js';
|
import type { DBConfig } from '../../../types.js';
|
||||||
import {
|
import {
|
||||||
createCurrentSnapshot,
|
createCurrentSnapshot,
|
||||||
|
|
|
@ -1,19 +1,5 @@
|
||||||
import { bold, cyan, red } from 'kleur/colors';
|
import { bold, cyan, red } from 'kleur/colors';
|
||||||
|
|
||||||
export const MISSING_SESSION_ID_CI_ERROR = `${red('▶ ASTRO_STUDIO_APP_TOKEN required')}
|
|
||||||
|
|
||||||
To authenticate with Astro Studio add the token to your CI's environment variables.\n`;
|
|
||||||
|
|
||||||
export const MISSING_SESSION_ID_ERROR = `${red('▶ Login required!')}
|
|
||||||
|
|
||||||
To authenticate with Astro Studio, run
|
|
||||||
${cyan('astro db login')}\n`;
|
|
||||||
|
|
||||||
export const MISSING_PROJECT_ID_ERROR = `${red('▶ Directory not linked.')}
|
|
||||||
|
|
||||||
To link this directory to an Astro Studio project, run
|
|
||||||
${cyan('astro db link')}\n`;
|
|
||||||
|
|
||||||
export const MISSING_EXECUTE_PATH_ERROR = `${red(
|
export const MISSING_EXECUTE_PATH_ERROR = `${red(
|
||||||
'▶ No file path provided.'
|
'▶ No file path provided.'
|
||||||
)} Provide a path by running ${cyan('astro db execute <path>')}\n`;
|
)} Provide a path by running ${cyan('astro db execute <path>')}\n`;
|
||||||
|
|
|
@ -19,7 +19,7 @@ import { CONFIG_FILE_NAMES, DB_PATH } from '../consts.js';
|
||||||
import { EXEC_DEFAULT_EXPORT_ERROR, EXEC_ERROR } from '../errors.js';
|
import { EXEC_DEFAULT_EXPORT_ERROR, EXEC_ERROR } from '../errors.js';
|
||||||
import { resolveDbConfig } from '../load-file.js';
|
import { resolveDbConfig } from '../load-file.js';
|
||||||
import { SEED_DEV_FILE_NAME } from '../queries.js';
|
import { SEED_DEV_FILE_NAME } from '../queries.js';
|
||||||
import { type ManagedAppToken, getManagedAppTokenOrExit } from '../tokens.js';
|
import { type ManagedAppToken, getManagedAppTokenOrExit } from '@astrojs/studio';
|
||||||
import { type VitePlugin, getDbDirectoryUrl } from '../utils.js';
|
import { type VitePlugin, getDbDirectoryUrl } from '../utils.js';
|
||||||
import { fileURLIntegration } from './file-url.js';
|
import { fileURLIntegration } from './file-url.js';
|
||||||
import { typegenInternal } from './typegen.js';
|
import { typegenInternal } from './typegen.js';
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
import type { AstroConfig, AstroIntegration } from 'astro';
|
import type { AstroConfig, AstroIntegration } from 'astro';
|
||||||
import { loadEnv } from 'vite';
|
import { loadEnv } from 'vite';
|
||||||
import type { AstroDbIntegration } from './types.js';
|
import type { AstroDbIntegration } from './types.js';
|
||||||
|
import { getAstroStudioEnv } from '@astrojs/studio';
|
||||||
|
|
||||||
export type VitePlugin = Required<AstroConfig['vite']>['plugins'][number];
|
export type VitePlugin = Required<AstroConfig['vite']>['plugins'][number];
|
||||||
|
|
||||||
export function getAstroStudioEnv(envMode = ''): Record<`ASTRO_STUDIO_${string}`, string> {
|
|
||||||
const env = loadEnv(envMode, process.cwd(), 'ASTRO_STUDIO_');
|
|
||||||
return env;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getAstroEnv(envMode = ''): Record<`ASTRO_${string}`, string> {
|
export function getAstroEnv(envMode = ''): Record<`ASTRO_${string}`, string> {
|
||||||
const env = loadEnv(envMode, process.cwd(), 'ASTRO_');
|
const env = loadEnv(envMode, process.cwd(), 'ASTRO_');
|
||||||
return env;
|
return env;
|
||||||
|
@ -19,11 +15,6 @@ export function getRemoteDatabaseUrl(): string {
|
||||||
return env.ASTRO_STUDIO_REMOTE_DB_URL || 'https://db.services.astro.build';
|
return env.ASTRO_STUDIO_REMOTE_DB_URL || 'https://db.services.astro.build';
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getAstroStudioUrl(): string {
|
|
||||||
const env = getAstroStudioEnv();
|
|
||||||
return env.ASTRO_STUDIO_URL || 'https://studio.astro.build';
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getDbDirectoryUrl(root: URL | string) {
|
export function getDbDirectoryUrl(root: URL | string) {
|
||||||
return new URL('db/', root);
|
return new URL('db/', root);
|
||||||
}
|
}
|
||||||
|
|
34
packages/studio/README.md
Normal file
34
packages/studio/README.md
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
# @astrojs/studio
|
||||||
|
|
||||||
|
This package manages the connection between a local Astro project and [Astro Studio](studio). At this time, this package is not intended for direct use by end users, but rather as a dependency of other Astro packages.
|
||||||
|
|
||||||
|
## Support
|
||||||
|
|
||||||
|
- Get help in the [Astro Discord][discord]. Post questions in our `#support` forum, or visit our dedicated `#dev` channel to discuss current development and more!
|
||||||
|
|
||||||
|
- Check our [Astro Integration Documentation][astro-integration] for more on integrations.
|
||||||
|
|
||||||
|
- Submit bug reports and feature requests as [GitHub issues][issues].
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
This package is maintained by Astro's Core team. You're welcome to submit an issue or PR! These links will help you get started:
|
||||||
|
|
||||||
|
- [Contributor Manual][contributing]
|
||||||
|
- [Code of Conduct][coc]
|
||||||
|
- [Community Guide][community]
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
MIT
|
||||||
|
|
||||||
|
Copyright (c) 2023–present [Astro][astro]
|
||||||
|
|
||||||
|
[astro]: https://astro.build/
|
||||||
|
[contributing]: https://github.com/withastro/astro/blob/main/CONTRIBUTING.md
|
||||||
|
[coc]: https://github.com/withastro/.github/blob/main/CODE_OF_CONDUCT.md
|
||||||
|
[community]: https://github.com/withastro/.github/blob/main/COMMUNITY_GUIDE.md
|
||||||
|
[discord]: https://astro.build/chat/
|
||||||
|
[issues]: https://github.com/withastro/astro/issues
|
||||||
|
[astro-integration]: https://docs.astro.build/en/guides/integrations-guide/
|
||||||
|
[studio]: https://studio.astro.build/
|
47
packages/studio/package.json
Normal file
47
packages/studio/package.json
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
{
|
||||||
|
"name": "@astrojs/studio",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "Internal package powering integrations between Astro projects and Astro Studio",
|
||||||
|
"license": "MIT",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/withastro/astro.git",
|
||||||
|
"directory": "packages/studio"
|
||||||
|
},
|
||||||
|
"bugs": "https://github.com/withastro/astro/issues",
|
||||||
|
"homepage": "https://docs.astro.build/en/guides/integrations-guide/studio/",
|
||||||
|
"type": "module",
|
||||||
|
"author": "withastro",
|
||||||
|
"types": "./dist/index.js",
|
||||||
|
"main": "./dist/index.js",
|
||||||
|
"exports": {
|
||||||
|
".": {
|
||||||
|
"types": "./dist/index.d.ts",
|
||||||
|
"import": "./dist/index.js"
|
||||||
|
},
|
||||||
|
"./package.json": "./package.json"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"dist"
|
||||||
|
],
|
||||||
|
"keywords": [
|
||||||
|
"withastro",
|
||||||
|
"astro-integration"
|
||||||
|
],
|
||||||
|
"scripts": {
|
||||||
|
"build": "astro-scripts build \"src/**/*.ts\" && tsc",
|
||||||
|
"build:ci": "astro-scripts build \"src/**/*.ts\"",
|
||||||
|
"dev": "astro-scripts dev \"src/**/*.ts\""
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"ci-info": "^4.0.0",
|
||||||
|
"kleur": "^4.1.5",
|
||||||
|
"ora": "^8.0.1"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"astro": "workspace:*",
|
||||||
|
"astro-scripts": "workspace:*",
|
||||||
|
"typescript": "^5.4.5",
|
||||||
|
"vite": "^5.2.11"
|
||||||
|
}
|
||||||
|
}
|
15
packages/studio/src/core/errors.ts
Normal file
15
packages/studio/src/core/errors.ts
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
import { cyan, red } from 'kleur/colors';
|
||||||
|
|
||||||
|
export const MISSING_SESSION_ID_CI_ERROR = `${red('▶ ASTRO_STUDIO_APP_TOKEN required')}
|
||||||
|
|
||||||
|
To authenticate with Astro Studio add the token to your CI's environment variables.\n`;
|
||||||
|
|
||||||
|
export const MISSING_SESSION_ID_ERROR = `${red('▶ Login required!')}
|
||||||
|
|
||||||
|
To authenticate with Astro Studio, run
|
||||||
|
${cyan('astro login')}\n`;
|
||||||
|
|
||||||
|
export const MISSING_PROJECT_ID_ERROR = `${red('▶ Directory not linked.')}
|
||||||
|
|
||||||
|
To link this directory to an Astro Studio project, run
|
||||||
|
${cyan('astro link')}\n`;
|
|
@ -5,7 +5,6 @@ import { pathToFileURL } from 'node:url';
|
||||||
import ci from 'ci-info';
|
import ci from 'ci-info';
|
||||||
import { green } from 'kleur/colors';
|
import { green } from 'kleur/colors';
|
||||||
import ora from 'ora';
|
import ora from 'ora';
|
||||||
import { safeFetch } from '../runtime/utils.js';
|
|
||||||
import {
|
import {
|
||||||
MISSING_PROJECT_ID_ERROR,
|
MISSING_PROJECT_ID_ERROR,
|
||||||
MISSING_SESSION_ID_CI_ERROR,
|
MISSING_SESSION_ID_CI_ERROR,
|
||||||
|
@ -209,3 +208,22 @@ function getExpiresFromTtl(ttl: number): Date {
|
||||||
// ttl is in minutes
|
// ttl is in minutes
|
||||||
return new Date(Date.now() + ttl * 60 * 1000);
|
return new Date(Date.now() + ttl * 60 * 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Small wrapper around fetch that throws an error if the response is not OK. Allows for custom error handling as well through the onNotOK callback.
|
||||||
|
*/
|
||||||
|
async function safeFetch(
|
||||||
|
url: Parameters<typeof fetch>[0],
|
||||||
|
options: Parameters<typeof fetch>[1] = {},
|
||||||
|
onNotOK: (response: Response) => void | Promise<void> = () => {
|
||||||
|
throw new Error(`Request to ${url} returned a non-OK status code.`);
|
||||||
|
}
|
||||||
|
): Promise<Response> {
|
||||||
|
const response = await fetch(url, options);
|
||||||
|
|
||||||
|
if (!response.ok) {
|
||||||
|
await onNotOK(response);
|
||||||
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
11
packages/studio/src/core/utils.ts
Normal file
11
packages/studio/src/core/utils.ts
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
import { loadEnv } from 'vite';
|
||||||
|
|
||||||
|
export function getAstroStudioEnv(envMode = ''): Record<`ASTRO_STUDIO_${string}`, string> {
|
||||||
|
const env = loadEnv(envMode, process.cwd(), 'ASTRO_STUDIO_');
|
||||||
|
return env;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getAstroStudioUrl(): string {
|
||||||
|
const env = getAstroStudioEnv();
|
||||||
|
return env.ASTRO_STUDIO_URL || 'https://studio.astro.build';
|
||||||
|
}
|
3
packages/studio/src/index.ts
Normal file
3
packages/studio/src/index.ts
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
export * from './core/tokens.js';
|
||||||
|
export * from './core/utils.js';
|
||||||
|
export * from './core/errors.js';
|
7
packages/studio/tsconfig.json
Normal file
7
packages/studio/tsconfig.json
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
"extends": "../../tsconfig.base.json",
|
||||||
|
"include": ["src"],
|
||||||
|
"compilerOptions": {
|
||||||
|
"outDir": "./dist"
|
||||||
|
}
|
||||||
|
}
|
|
@ -3943,6 +3943,9 @@ importers:
|
||||||
|
|
||||||
packages/db:
|
packages/db:
|
||||||
dependencies:
|
dependencies:
|
||||||
|
'@astrojs/studio':
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../studio
|
||||||
'@libsql/client':
|
'@libsql/client':
|
||||||
specifier: ^0.6.0
|
specifier: ^0.6.0
|
||||||
version: 0.6.0
|
version: 0.6.0
|
||||||
|
@ -5533,6 +5536,31 @@ importers:
|
||||||
specifier: ^2.0.0
|
specifier: ^2.0.0
|
||||||
version: 2.0.0
|
version: 2.0.0
|
||||||
|
|
||||||
|
packages/studio:
|
||||||
|
dependencies:
|
||||||
|
ci-info:
|
||||||
|
specifier: ^4.0.0
|
||||||
|
version: 4.0.0
|
||||||
|
kleur:
|
||||||
|
specifier: ^4.1.5
|
||||||
|
version: 4.1.5
|
||||||
|
ora:
|
||||||
|
specifier: ^8.0.1
|
||||||
|
version: 8.0.1
|
||||||
|
devDependencies:
|
||||||
|
astro:
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../astro
|
||||||
|
astro-scripts:
|
||||||
|
specifier: workspace:*
|
||||||
|
version: link:../../scripts
|
||||||
|
typescript:
|
||||||
|
specifier: ^5.4.5
|
||||||
|
version: 5.4.5
|
||||||
|
vite:
|
||||||
|
specifier: ^5.2.11
|
||||||
|
version: 5.2.11(@types/node@18.19.31)(sass@1.77.1)
|
||||||
|
|
||||||
packages/telemetry:
|
packages/telemetry:
|
||||||
dependencies:
|
dependencies:
|
||||||
ci-info:
|
ci-info:
|
||||||
|
|
Loading…
Reference in a new issue