enh(multi): Add public instance URL calculators and refactor HTTP protocol detection

This commit is contained in:
Ben Allfree 2024-06-29 17:10:11 -07:00
parent 12f029a294
commit b7277cf885
3 changed files with 16 additions and 10 deletions

View File

@ -0,0 +1,6 @@
---
'@pockethost/plugin-launcher-spawn': minor
'pockethost': minor
---
Add public instance URL calculators and refactor HTTP protocol detection

View File

@ -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}`)
}
})

View File

@ -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
}