chore(root): migrate to biome
This commit is contained in:
@@ -19,4 +19,4 @@
|
||||
"devDependencies": {
|
||||
"@types/bcrypt": "^5.0.2"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
57
self-hosting/pnpm-lock.yaml
generated
57
self-hosting/pnpm-lock.yaml
generated
@@ -16,7 +16,7 @@ dependencies:
|
||||
version: 5.1.1
|
||||
inquirer:
|
||||
specifier: ^9.3.1
|
||||
version: 9.3.1
|
||||
version: 9.3.6
|
||||
jiti:
|
||||
specifier: ^1.21.6
|
||||
version: 1.21.6
|
||||
@@ -31,8 +31,8 @@ devDependencies:
|
||||
|
||||
packages:
|
||||
|
||||
/@inquirer/figures@1.0.3:
|
||||
resolution: {integrity: sha512-ErXXzENMH5pJt5/ssXV0DfWUZqly8nGzf0UcBV9xTnP+KyffE2mqyxIMBrZ8ijQck2nU0TQm40EQB53YreyWHw==}
|
||||
/@inquirer/figures@1.0.6:
|
||||
resolution: {integrity: sha512-yfZzps3Cso2UbM7WlxKwZQh2Hs6plrbjs1QnzQDZhK2DgyCo6D8AaHps9olkNcUFlcYERMqU3uJSp1gmy3s/qQ==}
|
||||
engines: {node: '>=18'}
|
||||
dev: false
|
||||
|
||||
@@ -57,7 +57,7 @@ packages:
|
||||
/@types/bcrypt@5.0.2:
|
||||
resolution: {integrity: sha512-6atioO8Y75fNcbmj0G7UjI9lXN2pQ/IGJ2FWT4a/btd0Lk9lQalHLKhkgKVZ3r+spnmWUKfbMi1GEe9wyHQfNQ==}
|
||||
dependencies:
|
||||
'@types/node': 20.14.9
|
||||
'@types/node': 22.5.5
|
||||
dev: true
|
||||
|
||||
/@types/inquirer@9.0.7:
|
||||
@@ -71,15 +71,15 @@ packages:
|
||||
resolution: {integrity: sha512-k4MGaQl5TGo/iipqb2UDG2UwjXziSWkh0uysQelTlJpX1qGlpUZYm8PnO4DxG1qBomtJUdYJ6qR6xdIah10JLg==}
|
||||
dev: false
|
||||
|
||||
/@types/node@20.14.9:
|
||||
resolution: {integrity: sha512-06OCtnTXtWOZBJlRApleWndH4JsRVs1pDCc8dLSQp+7PpUpX3ePdHyeNSFTeSe7FtKyQkrlPvHwJOW3SLd8Oyg==}
|
||||
/@types/node@22.5.5:
|
||||
resolution: {integrity: sha512-Xjs4y5UPO/CLdzpgR6GirZJx36yScjh73+2NlLlkFRSoQN8B0DpfXPdZGnvVmLRLOsqDpOfTNv7D9trgGhmOIA==}
|
||||
dependencies:
|
||||
undici-types: 5.26.5
|
||||
undici-types: 6.19.8
|
||||
|
||||
/@types/through@0.0.33:
|
||||
resolution: {integrity: sha512-HsJ+z3QuETzP3cswwtzt2vEIiHBk/dCcHGhbmG5X3ecnwFD/lPrMpliGXxSCg03L9AhrdwA4Oz/qfspkDW+xGQ==}
|
||||
dependencies:
|
||||
'@types/node': 20.14.9
|
||||
'@types/node': 22.5.5
|
||||
dev: false
|
||||
|
||||
/abbrev@1.1.1:
|
||||
@@ -90,7 +90,7 @@ packages:
|
||||
resolution: {integrity: sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==}
|
||||
engines: {node: '>= 6.0.0'}
|
||||
dependencies:
|
||||
debug: 4.3.6
|
||||
debug: 4.3.7
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: false
|
||||
@@ -236,8 +236,8 @@ packages:
|
||||
resolution: {integrity: sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==}
|
||||
dev: false
|
||||
|
||||
/debug@4.3.6:
|
||||
resolution: {integrity: sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==}
|
||||
/debug@4.3.7:
|
||||
resolution: {integrity: sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==}
|
||||
engines: {node: '>=6.0'}
|
||||
peerDependencies:
|
||||
supports-color: '*'
|
||||
@@ -245,7 +245,7 @@ packages:
|
||||
supports-color:
|
||||
optional: true
|
||||
dependencies:
|
||||
ms: 2.1.2
|
||||
ms: 2.1.3
|
||||
dev: false
|
||||
|
||||
/defaults@1.0.4:
|
||||
@@ -329,7 +329,7 @@ packages:
|
||||
engines: {node: '>= 6'}
|
||||
dependencies:
|
||||
agent-base: 6.0.2
|
||||
debug: 4.3.6
|
||||
debug: 4.3.7
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: false
|
||||
@@ -357,22 +357,22 @@ packages:
|
||||
resolution: {integrity: sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==}
|
||||
dev: false
|
||||
|
||||
/inquirer@9.3.1:
|
||||
resolution: {integrity: sha512-A5IdVr1I04XqPlwrGgTJMKmzRg5ropqNpSeqo0vj1ZmluSCNSFaPZz4eazdPrhVcZfej7fCEYvD2NYa1KjkTJA==}
|
||||
/inquirer@9.3.6:
|
||||
resolution: {integrity: sha512-riK/iQB2ctwkpWYgjjWIRv3MBLt2gzb2Sj0JNQNbyTXgyXsLWcDPJ5WS5ZDTCx7BRFnJsARtYh+58fjP5M2Y0Q==}
|
||||
engines: {node: '>=18'}
|
||||
dependencies:
|
||||
'@inquirer/figures': 1.0.3
|
||||
'@inquirer/figures': 1.0.6
|
||||
ansi-escapes: 4.3.2
|
||||
cli-width: 4.1.0
|
||||
external-editor: 3.1.0
|
||||
mute-stream: 1.0.0
|
||||
ora: 5.4.1
|
||||
picocolors: 1.0.1
|
||||
run-async: 3.0.0
|
||||
rxjs: 7.8.1
|
||||
string-width: 4.2.3
|
||||
strip-ansi: 6.0.1
|
||||
wrap-ansi: 6.2.0
|
||||
yoctocolors-cjs: 2.1.2
|
||||
dev: false
|
||||
|
||||
/is-fullwidth-code-point@3.0.0:
|
||||
@@ -454,8 +454,8 @@ packages:
|
||||
hasBin: true
|
||||
dev: false
|
||||
|
||||
/ms@2.1.2:
|
||||
resolution: {integrity: sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==}
|
||||
/ms@2.1.3:
|
||||
resolution: {integrity: sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==}
|
||||
dev: false
|
||||
|
||||
/mute-stream@1.0.0:
|
||||
@@ -540,10 +540,6 @@ packages:
|
||||
engines: {node: '>=0.10.0'}
|
||||
dev: false
|
||||
|
||||
/picocolors@1.0.1:
|
||||
resolution: {integrity: sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==}
|
||||
dev: false
|
||||
|
||||
/readable-stream@3.6.2:
|
||||
resolution: {integrity: sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==}
|
||||
engines: {node: '>= 6'}
|
||||
@@ -577,7 +573,7 @@ packages:
|
||||
/rxjs@7.8.1:
|
||||
resolution: {integrity: sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==}
|
||||
dependencies:
|
||||
tslib: 2.6.3
|
||||
tslib: 2.7.0
|
||||
dev: false
|
||||
|
||||
/safe-buffer@5.2.1:
|
||||
@@ -659,8 +655,8 @@ packages:
|
||||
resolution: {integrity: sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==}
|
||||
dev: false
|
||||
|
||||
/tslib@2.6.3:
|
||||
resolution: {integrity: sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==}
|
||||
/tslib@2.7.0:
|
||||
resolution: {integrity: sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==}
|
||||
dev: false
|
||||
|
||||
/type-fest@0.21.3:
|
||||
@@ -668,8 +664,8 @@ packages:
|
||||
engines: {node: '>=10'}
|
||||
dev: false
|
||||
|
||||
/undici-types@5.26.5:
|
||||
resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==}
|
||||
/undici-types@6.19.8:
|
||||
resolution: {integrity: sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==}
|
||||
|
||||
/util-deprecate@1.0.2:
|
||||
resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==}
|
||||
@@ -714,3 +710,8 @@ packages:
|
||||
/yallist@4.0.0:
|
||||
resolution: {integrity: sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==}
|
||||
dev: false
|
||||
|
||||
/yoctocolors-cjs@2.1.2:
|
||||
resolution: {integrity: sha512-cYVsTjKl8b+FrnidjibDWskAv7UKOfcwaVZdp/it9n1s9fU3IkgDbhdIRKCW4JDsAlECJY0ytoVPT3sK6kideA==}
|
||||
engines: {node: '>=18'}
|
||||
dev: false
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
import fs from 'fs';
|
||||
import os from 'os';
|
||||
import path from 'path';
|
||||
import fs from 'node:fs';
|
||||
import os from 'node:os';
|
||||
import path from 'node:path';
|
||||
import bcrypt from 'bcrypt';
|
||||
import inquirer from 'inquirer';
|
||||
import yaml from 'js-yaml';
|
||||
@@ -19,7 +19,7 @@ function writeCaddyfile(domainName: string, basicAuthPassword: string) {
|
||||
const caddyfileTemplatePath = path.resolve(
|
||||
__dirname,
|
||||
'caddy',
|
||||
'Caddyfile.template'
|
||||
'Caddyfile.template',
|
||||
);
|
||||
const caddyfilePath = path.resolve(__dirname, 'caddy', 'Caddyfile');
|
||||
fs.writeFileSync(
|
||||
@@ -29,12 +29,12 @@ function writeCaddyfile(domainName: string, basicAuthPassword: string) {
|
||||
.replaceAll('$DOMAIN_NAME', domainName.replace(/https?:\/\//, ''))
|
||||
.replaceAll(
|
||||
'$BASIC_AUTH_PASSWORD',
|
||||
bcrypt.hashSync(basicAuthPassword, 10)
|
||||
bcrypt.hashSync(basicAuthPassword, 10),
|
||||
)
|
||||
.replaceAll(
|
||||
'$SSL_CONFIG',
|
||||
domainName.includes('localhost:443') ? '\n\ttls internal' : ''
|
||||
)
|
||||
domainName.includes('localhost:443') ? '\n\ttls internal' : '',
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
@@ -61,7 +61,7 @@ function searchAndReplaceDockerCompose(replacements: [string, string][]) {
|
||||
const dockerComposeContent = fs.readFileSync(dockerComposePath, 'utf-8');
|
||||
const dockerComposeReplaced = replacements.reduce(
|
||||
(acc, [search, replace]) => acc.replaceAll(search, replace),
|
||||
dockerComposeContent
|
||||
dockerComposeContent,
|
||||
);
|
||||
|
||||
fs.writeFileSync(dockerComposePath, dockerComposeReplaced);
|
||||
@@ -75,7 +75,7 @@ function removeServiceFromDockerCompose(serviceName: string) {
|
||||
const dockerCompose = yaml.load(dockerComposeContent) as DockerComposeFile;
|
||||
|
||||
// Remove the service
|
||||
if (dockerCompose.services && dockerCompose.services[serviceName]) {
|
||||
if (dockerCompose.services[serviceName]) {
|
||||
delete dockerCompose.services[serviceName];
|
||||
console.log(`Service '${serviceName}' has been removed.`);
|
||||
} else {
|
||||
@@ -124,7 +124,7 @@ function writeEnvFile(envs: {
|
||||
const envPath = path.resolve(__dirname, '.env');
|
||||
const envTemplate = fs.readFileSync(envTemplatePath, 'utf-8');
|
||||
|
||||
let newEnvFile = envTemplate
|
||||
const newEnvFile = envTemplate
|
||||
.replace('$CLICKHOUSE_URL', envs.CLICKHOUSE_URL)
|
||||
.replace('$REDIS_URL', envs.REDIS_URL)
|
||||
.replace('$DATABASE_URL', envs.DATABASE_URL)
|
||||
@@ -132,11 +132,11 @@ function writeEnvFile(envs: {
|
||||
.replace('$NEXT_PUBLIC_DASHBOARD_URL', stripTrailingSlash(envs.DOMAIN_NAME))
|
||||
.replace(
|
||||
'$NEXT_PUBLIC_API_URL',
|
||||
`${stripTrailingSlash(envs.DOMAIN_NAME)}/api`
|
||||
`${stripTrailingSlash(envs.DOMAIN_NAME)}/api`,
|
||||
)
|
||||
.replace(
|
||||
'$NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY',
|
||||
envs.NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY
|
||||
envs.NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY,
|
||||
)
|
||||
.replace('$CLERK_SECRET_KEY', envs.CLERK_SECRET_KEY)
|
||||
.replace('$CLERK_SIGNING_SECRET', envs.CLERK_SIGNING_SECRET);
|
||||
@@ -148,7 +148,7 @@ function writeEnvFile(envs: {
|
||||
.filter((line) => {
|
||||
return !line.includes('=""');
|
||||
})
|
||||
.join('\n')
|
||||
.join('\n'),
|
||||
);
|
||||
}
|
||||
|
||||
@@ -166,7 +166,7 @@ async function initiateOnboarding() {
|
||||
"With that said let's get started! 🤠",
|
||||
'',
|
||||
`Hey and welcome to Openpanel's self-hosting setup! 🚀\n`,
|
||||
`Before you continue, please make sure you have the following:`,
|
||||
'Before you continue, please make sure you have the following:',
|
||||
`${T}1. Docker and Docker Compose installed on your machine.`,
|
||||
`${T}2. A domain name that you can use for this setup and point it to this machine's ip`,
|
||||
`${T}3. A Clerk.com account`,
|
||||
@@ -177,11 +177,11 @@ async function initiateOnboarding() {
|
||||
];
|
||||
|
||||
console.log(
|
||||
'******************************************************************************\n'
|
||||
'******************************************************************************\n',
|
||||
);
|
||||
console.log(message.join('\n'));
|
||||
console.log(
|
||||
'\n******************************************************************************'
|
||||
'\n******************************************************************************',
|
||||
);
|
||||
|
||||
// Domain name
|
||||
@@ -332,7 +332,7 @@ async function initiateOnboarding() {
|
||||
default: os.cpus().length,
|
||||
message: 'How many CPUs do you have?',
|
||||
validate: (value) => {
|
||||
const parsed = parseInt(value, 10);
|
||||
const parsed = Number.parseInt(value, 10);
|
||||
|
||||
if (Number.isNaN(parsed)) {
|
||||
return 'Please enter a valid number';
|
||||
@@ -377,7 +377,7 @@ async function initiateOnboarding() {
|
||||
REDIS_URL: envs.REDIS_URL || 'redis://op-kv:6379',
|
||||
DATABASE_URL:
|
||||
envs.DATABASE_URL ||
|
||||
`postgresql://postgres:postgres@op-db:5432/postgres?schema=public`,
|
||||
'postgresql://postgres:postgres@op-db:5432/postgres?schema=public',
|
||||
DOMAIN_NAME: domainNameResponse.domainName,
|
||||
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY:
|
||||
clerkResponse.NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY || '',
|
||||
@@ -388,7 +388,7 @@ async function initiateOnboarding() {
|
||||
console.log('Updating docker-compose.yml file...\n');
|
||||
fs.copyFileSync(
|
||||
path.resolve(__dirname, 'docker-compose.template.yml'),
|
||||
path.resolve(__dirname, 'docker-compose.yml')
|
||||
path.resolve(__dirname, 'docker-compose.yml'),
|
||||
);
|
||||
|
||||
if (envs.CLICKHOUSE_URL) {
|
||||
@@ -434,7 +434,7 @@ async function initiateOnboarding() {
|
||||
`Start OpenPanel with "./start" inside the self-hosting directory`,
|
||||
'',
|
||||
'',
|
||||
].join('\n')
|
||||
].join('\n'),
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user