diff options
| author | Bertrand Yuan <bert.yuan@outlook.com> | 2025-12-16 00:25:04 +0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-12-16 00:25:04 +0800 |
| commit | 39c83fbb69ef06d2d56790d75abc254ba7e34394 (patch) | |
| tree | dd006593448c3500bdcb414af3b4656f7a7683d4 /scripts | |
| parent | 48b07bc308a35734a6a7a305c8fdccbfa47de7d8 (diff) | |
| parent | 785371bb3eccca455e5ce5fccbe9b6e3752a03f6 (diff) | |
Merge pull request #1 from bertyuan/feat-introduce-payloadv1.0
Feat: introduce payload
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/check-payload-users.mts | 40 | ||||
| -rw-r--r-- | scripts/create-payload-schema.mts | 43 |
2 files changed, 83 insertions, 0 deletions
diff --git a/scripts/check-payload-users.mts b/scripts/check-payload-users.mts new file mode 100644 index 0000000..e8ab91e --- /dev/null +++ b/scripts/check-payload-users.mts @@ -0,0 +1,40 @@ +import pg from 'pg'; +import { readFileSync } from 'node:fs'; +import { join } from 'node:path'; + +// 读取 .env 文件 +const envPath = join(process.cwd(), '.env'); +const envContent = readFileSync(envPath, 'utf-8'); +const envLines = envContent.split('\n'); +for (const line of envLines) { + const match = line.match(/^([^=]+)=(.*)$/); + if (match) { + const key = match[1]?.trim(); + let value = match[2]?.trim() || ''; + if ((value.startsWith('"') && value.endsWith('"')) || (value.startsWith("'") && value.endsWith("'"))) { + value = value.slice(1, -1); + } + if (key) { + process.env[key] = value; + } + } +} + +const { Pool } = pg; + +async function checkUsers() { + const pool = new Pool({ + connectionString: process.env.DATABASE_URL, + }); + + try { + const result = await pool.query('SELECT id, email, name FROM payload.users'); + console.log('Payload users:', result.rows); + } catch (error) { + console.error('Error:', error); + } finally { + await pool.end(); + } +} + +checkUsers(); diff --git a/scripts/create-payload-schema.mts b/scripts/create-payload-schema.mts new file mode 100644 index 0000000..35c13a6 --- /dev/null +++ b/scripts/create-payload-schema.mts @@ -0,0 +1,43 @@ +import { config } from 'node:process'; +import pg from 'pg'; +import { readFileSync } from 'node:fs'; +import { join } from 'node:path'; + +// 读取 .env 文件 +const envPath = join(process.cwd(), '.env'); +const envContent = readFileSync(envPath, 'utf-8'); +const envLines = envContent.split('\n'); +for (const line of envLines) { + const match = line.match(/^([^=]+)=(.*)$/); + if (match) { + const key = match[1]?.trim(); + let value = match[2]?.trim() || ''; + // 移除引号 + if ((value.startsWith('"') && value.endsWith('"')) || (value.startsWith("'") && value.endsWith("'"))) { + value = value.slice(1, -1); + } + if (key) { + process.env[key] = value; + } + } +} + +const { Pool } = pg; + +async function createPayloadSchema() { + const pool = new Pool({ + connectionString: process.env.DATABASE_URL, + }); + + try { + await pool.query('CREATE SCHEMA IF NOT EXISTS payload'); + console.log('✅ Payload schema created successfully'); + } catch (error) { + console.error('❌ Error creating schema:', error); + process.exit(1); + } finally { + await pool.end(); + } +} + +createPayloadSchema(); |
