Optimizing code based on the comments
This commit is contained in:
parent
876d19b6d6
commit
12c0b43e42
5 changed files with 11 additions and 43 deletions
|
@ -1,6 +0,0 @@
|
||||||
---
|
|
||||||
'astro': minor
|
|
||||||
'@astrojs/node': minor
|
|
||||||
---
|
|
||||||
|
|
||||||
supporting a network address access a website when an user set host = true in Node environment
|
|
|
@ -1,5 +1,5 @@
|
||||||
import os from 'os'
|
import os from 'os'
|
||||||
interface ReturnValOpt {
|
interface NetworkAddressOpt {
|
||||||
local: string[]
|
local: string[]
|
||||||
network: string[]
|
network: string[]
|
||||||
}
|
}
|
||||||
|
@ -11,9 +11,10 @@ const wildcardHosts = new Set([
|
||||||
])
|
])
|
||||||
type Protocol = 'http' | 'https'
|
type Protocol = 'http' | 'https'
|
||||||
|
|
||||||
export function getNetworkAddress(protocol: Protocol = 'http', hostname: string, port:number, base?:string) {
|
// this code from vite https://github.com/vitejs/vite/blob/d09bbd093a4b893e78f0bbff5b17c7cf7821f403/packages/vite/src/node/utils.ts#L892-L914
|
||||||
|
export function getNetworkAddress(protocol: Protocol = 'http', hostname: string | undefined, port:number, base?:string) {
|
||||||
|
|
||||||
const returnVal:ReturnValOpt = {
|
const NetworkAddress:NetworkAddressOpt = {
|
||||||
local: [],
|
local: [],
|
||||||
network: []
|
network: []
|
||||||
}
|
}
|
||||||
|
@ -36,12 +37,12 @@ export function getNetworkAddress(protocol: Protocol = 'http', hostname: string,
|
||||||
}
|
}
|
||||||
const url = `${protocol}://${host}:${port}${base ? base : ''}`
|
const url = `${protocol}://${host}:${port}${base ? base : ''}`
|
||||||
if (detail.address.includes('127.0.0.1')) {
|
if (detail.address.includes('127.0.0.1')) {
|
||||||
returnVal.local.push(url)
|
NetworkAddress.local.push(url)
|
||||||
} else {
|
} else {
|
||||||
returnVal.network.push(url)
|
NetworkAddress.network.push(url)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
return returnVal
|
return NetworkAddress
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -74,16 +74,11 @@ const preview: CreatePreviewServer = async function ({
|
||||||
if(host === undefined ){
|
if(host === undefined ){
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.log(
|
console.log(
|
||||||
`Preview server listening on
|
`Preview server listening on \n local: ${address.local[0]} \t\n network: ${address.network[0]}
|
||||||
\t
|
|
||||||
local: ${address.local[0]}
|
|
||||||
\t
|
|
||||||
network: ${address.network[0]}
|
|
||||||
` );
|
` );
|
||||||
}else{
|
}else{
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.log(`Preview server listening on \t
|
console.log(`Preview server listening on ${address.local[0]}`);
|
||||||
${address.local[0]}`);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -61,16 +61,11 @@ export default function startServer(app: NodeApp, options: Options) {
|
||||||
if(host === undefined ){
|
if(host === undefined ){
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.log(
|
console.log(
|
||||||
`Preview server listening on
|
`Preview server listening on \n local: ${address.local[0]} \t\n network: ${address.network[0]}
|
||||||
\t
|
|
||||||
local: ${address.local[0]}
|
|
||||||
\t
|
|
||||||
network: ${address.network[0]}
|
|
||||||
` );
|
` );
|
||||||
}else{
|
}else{
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.log(`Preview server listening on \t
|
console.log(`Preview server listening on ${address.local[0]}`);
|
||||||
${address.local[0]}`);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import { expect } from 'chai';
|
import { expect } from 'chai';
|
||||||
import { getNetworkAddress } from '../dist/get-network-address.js'
|
|
||||||
import { fetch } from 'undici';
|
import { fetch } from 'undici';
|
||||||
|
|
||||||
describe('URL protocol', () => {
|
describe('URL protocol', () => {
|
||||||
|
@ -18,22 +17,6 @@ describe('URL protocol', () => {
|
||||||
await fixture.build();
|
await fixture.build();
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('test preview when host is true', async () => {
|
|
||||||
let devPreview;
|
|
||||||
|
|
||||||
before(async () => {
|
|
||||||
devPreview = await fixture.preview();
|
|
||||||
|
|
||||||
});
|
|
||||||
after(async () => {
|
|
||||||
await devPreview.stop();
|
|
||||||
});
|
|
||||||
it('test host is true ', async () => {
|
|
||||||
const address = getNetworkAddress('http', undefined, 3000)
|
|
||||||
const res = await fetch(address.network[0])
|
|
||||||
expect(res.status).to.equal(200);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
it('return http when non-secure', async () => {
|
it('return http when non-secure', async () => {
|
||||||
const { handler } = await import('./fixtures/url-protocol/dist/server/entry.mjs');
|
const { handler } = await import('./fixtures/url-protocol/dist/server/entry.mjs');
|
||||||
let { req, res, text } = createRequestAndResponse({
|
let { req, res, text } = createRequestAndResponse({
|
||||||
|
|
Loading…
Reference in a new issue