mirror of
https://github.com/pockethost/pockethost.git
synced 2025-06-06 06:06:45 +00:00
enh(multi): Add public instance URL calculators and refactor HTTP protocol detection
This commit is contained in:
parent
12f029a294
commit
b7277cf885
6
.changeset/1719706211493.md
Normal file
6
.changeset/1719706211493.md
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
'@pockethost/plugin-launcher-spawn': minor
|
||||
'pockethost': minor
|
||||
---
|
||||
|
||||
Add public instance URL calculators and refactor HTTP protocol detection
|
@ -21,10 +21,9 @@ import {
|
||||
} from 'pockethost'
|
||||
import {
|
||||
APEX_DOMAIN,
|
||||
INSTANCE_DATA_DIR,
|
||||
HTTP_PROTOCOL,
|
||||
PORT,
|
||||
exitHook,
|
||||
tryFetch,
|
||||
PUBLIC_INSTANCE_URL,
|
||||
} from 'pockethost/core'
|
||||
import { PLUGIN_NAME, settings } from './constants'
|
||||
import { DbService } from './db'
|
||||
@ -92,15 +91,14 @@ export const plugin: PocketHostPlugin = async ({}) => {
|
||||
|
||||
/** Display some informational alerts to help the user get started. */
|
||||
onAfterServerStartAction(async () => {
|
||||
const protocol = PORT() === 443 ? 'https' : 'http'
|
||||
const protocol = HTTP_PROTOCOL()
|
||||
{
|
||||
const url = new URL(`${protocol}://*.${APEX_DOMAIN()}`)
|
||||
const url = new URL(`${protocol}//*.${APEX_DOMAIN()}`)
|
||||
url.port = `${PORT() === 80 || PORT() == 443 ? '' : PORT()}`
|
||||
info(`Listening for requests on ${url}`)
|
||||
}
|
||||
{
|
||||
const url = new URL(`${protocol}://hello.${APEX_DOMAIN()}`)
|
||||
url.port = `${PORT() === 80 || PORT() == 443 ? '' : PORT()}`
|
||||
const url = PUBLIC_INSTANCE_URL({ subdomain: 'hello' })
|
||||
info(`Try visiting ${url}`)
|
||||
}
|
||||
})
|
||||
|
@ -57,7 +57,9 @@ export const DATA_DIR = (...paths: string[]) =>
|
||||
export const NODE_ENV = () => process.env.NODE_ENV
|
||||
export const INSTANCE_DATA_DIR = (id: InstanceId, ...paths: string[]) =>
|
||||
join(DATA_DIR(), id, ...paths)
|
||||
|
||||
if (DEBUG()) {
|
||||
logSettings(settings)
|
||||
export const HTTP_PROTOCOL = () => (PORT() === 443 ? 'https:' : 'http:')
|
||||
export const PUBLIC_INSTANCE_URL = ({ subdomain }: Partial<InstanceFields>) => {
|
||||
const url = new URL(`${HTTP_PROTOCOL()}//${subdomain}.${APEX_DOMAIN()}`)
|
||||
url.port = `${PORT() === 80 || PORT() == 443 ? '' : PORT()}`
|
||||
return url
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user