@networkpro/web 1.25.3 → 1.25.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.template +1 -1
- package/CHANGELOG.md +56 -1
- package/package.json +2 -2
- package/src/hooks.server.js +14 -11
- package/src/lib/stores/posthog.js +12 -4
- package/src/lib/utils/env.js +21 -6
- package/static/b173de6c44c144c1b186841b88d51c67.txt +1 -0
- package/static/sitemap.xml +5 -5
- package/svelte.config.js +1 -0
- package/vite.config.js +2 -1
package/.env.template
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
# Rename to `.env` (or `.env.local`) and customize as needed
|
|
6
6
|
|
|
7
7
|
# Custom environment mode for scripts and tooling
|
|
8
|
-
# One of: dev, test, ci, preview,
|
|
8
|
+
# One of: dev, test, ci, preview, production
|
|
9
9
|
ENV_MODE=dev
|
|
10
10
|
|
|
11
11
|
# Optional: API keys or tokens for local dev (never commit real values)
|
package/CHANGELOG.md
CHANGED
|
@@ -22,6 +22,59 @@ This project attempts to follow [Keep a Changelog](https://keepachangelog.com/en
|
|
|
22
22
|
|
|
23
23
|
---
|
|
24
24
|
|
|
25
|
+
## [1.25.5] - 2025-11-03
|
|
26
|
+
|
|
27
|
+
### Added
|
|
28
|
+
|
|
29
|
+
- Introduced `static/b173de6c44c144c1b186841b88d51c67.txt` for use with [IndexNow](https://www.indexnow.org) and Bing Webmaster Tools.
|
|
30
|
+
|
|
31
|
+
### Changed
|
|
32
|
+
|
|
33
|
+
- Bumped project version to `v1.25.5`.
|
|
34
|
+
|
|
35
|
+
### Fixed
|
|
36
|
+
|
|
37
|
+
- Corrected the URLs for the HTML versions of the licenses in `static/sitemap.xml`.
|
|
38
|
+
|
|
39
|
+
---
|
|
40
|
+
|
|
41
|
+
## [1.25.4] - 2025-11-03
|
|
42
|
+
|
|
43
|
+
### Added
|
|
44
|
+
|
|
45
|
+
- `detectEnvironment()` now returns:
|
|
46
|
+
- `isDebug` boolean (true if `isDev` or `isTest`)
|
|
47
|
+
- `isLocalhost` (optional, in browser contexts)
|
|
48
|
+
- Support for `PUBLIC_POSTHOG_PROJECT_KEY` using `import.meta.env`
|
|
49
|
+
- Dynamic PostHog initialization (`initPostHog`) now uses env-based key injection
|
|
50
|
+
- vite.config.js:
|
|
51
|
+
- `envPrefix: ['PUBLIC_']` added to expose public vars to client
|
|
52
|
+
- Console banner for `ENV_MODE`, `PUBLIC_ENV_MODE`, and audit-mode warning
|
|
53
|
+
- CSP debug logs gated behind `isDebug` and server-only context
|
|
54
|
+
- `.env.production` support via `--mode=production` guidance
|
|
55
|
+
- Conditional `minify` flag for `lightningcssPlugin` based on `mode` (`production` or `audit`)
|
|
56
|
+
|
|
57
|
+
### Changed
|
|
58
|
+
|
|
59
|
+
- Environment detection (`env.js`) now respects hostname overrides and normalizes fallback logic for SSR/client consistency
|
|
60
|
+
- Logs in `hooks.server.js` and PostHog analytics client are now gated by `isDebug` to avoid unnecessary noise in production
|
|
61
|
+
- Better logging structure for PostHog initialization, including full `import.meta.env` dump in debug mode
|
|
62
|
+
- Bumped project version to `v1.25.4`
|
|
63
|
+
|
|
64
|
+
### Fixed
|
|
65
|
+
|
|
66
|
+
- Broken or undefined env var behavior due to missing `envPrefix` in `vite.config.js`
|
|
67
|
+
- Client-only `import.meta.env.PUBLIC_*` variables incorrectly resolving as `undefined` in production builds
|
|
68
|
+
- CSP not reflecting audit context due to host-based detection mismatch
|
|
69
|
+
|
|
70
|
+
### Developer Notes
|
|
71
|
+
|
|
72
|
+
- `.env.production` is **now required** for full environment variable injection during `npm run build --mode=production` or Vercel deployments.
|
|
73
|
+
- Without it, `PUBLIC_` variables (e.g. `PUBLIC_POSTHOG_PROJECT_KEY`) may resolve as undefined in the client bundle.
|
|
74
|
+
- Local builds can still fall back to `.env` or `.env.development` by default.
|
|
75
|
+
|
|
76
|
+
---
|
|
77
|
+
|
|
25
78
|
## [1.25.3] - 2025-11-03
|
|
26
79
|
|
|
27
80
|
### Changed
|
|
@@ -1649,7 +1702,9 @@ This enables analytics filtering and CSP hardening for the audit environment.
|
|
|
1649
1702
|
|
|
1650
1703
|
<!-- Link references -->
|
|
1651
1704
|
|
|
1652
|
-
[Unreleased]: https://github.com/netwk-pro/netwk-pro.github.io/compare/v1.25.
|
|
1705
|
+
[Unreleased]: https://github.com/netwk-pro/netwk-pro.github.io/compare/v1.25.5...HEAD
|
|
1706
|
+
[1.25.5]: https://github.com/netwk-pro/netwk-pro.github.io/releases/tag/v1.25.5
|
|
1707
|
+
[1.25.4]: https://github.com/netwk-pro/netwk-pro.github.io/releases/tag/v1.25.4
|
|
1653
1708
|
[1.25.3]: https://github.com/netwk-pro/netwk-pro.github.io/releases/tag/v1.25.3
|
|
1654
1709
|
[1.25.2]: https://github.com/netwk-pro/netwk-pro.github.io/releases/tag/v1.25.2
|
|
1655
1710
|
[1.25.1]: https://github.com/netwk-pro/netwk-pro.github.io/releases/tag/v1.25.1
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@networkpro/web",
|
|
3
3
|
"private": false,
|
|
4
|
-
"version": "1.25.
|
|
4
|
+
"version": "1.25.5",
|
|
5
5
|
"description": "Locking Down Networks, Unlocking Confidence™ | Security, Networking, Privacy — Network Pro Strategies",
|
|
6
6
|
"keywords": [
|
|
7
7
|
"advisory",
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
"dev:audit": "vite --mode audit",
|
|
39
39
|
"start": "npm run dev",
|
|
40
40
|
"dev:vercel": "vercel dev",
|
|
41
|
-
"build": "vite build",
|
|
41
|
+
"build": "vite build --mode production",
|
|
42
42
|
"build:audit": "vite build --mode audit",
|
|
43
43
|
"build:vercel": "vercel build",
|
|
44
44
|
"preview": "vite preview",
|
package/src/hooks.server.js
CHANGED
|
@@ -16,16 +16,19 @@ export async function handle({ event, resolve }) {
|
|
|
16
16
|
const response = await resolve(event);
|
|
17
17
|
|
|
18
18
|
const env = detectEnvironment(event.url.hostname);
|
|
19
|
-
const { isAudit, isTest, isProd, mode, effective } = env;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
const { isAudit, isDebug, isTest, isProd, mode, effective } = env;
|
|
20
|
+
|
|
21
|
+
// Show logs in dev only
|
|
22
|
+
if (isDebug) {
|
|
23
|
+
console.log('[CSP Debug ENV]', {
|
|
24
|
+
mode,
|
|
25
|
+
effective,
|
|
26
|
+
hostname: event.url.hostname,
|
|
27
|
+
isAudit,
|
|
28
|
+
isTest,
|
|
29
|
+
isProd,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
29
32
|
|
|
30
33
|
// Determine report URI
|
|
31
34
|
const reportUri =
|
|
@@ -49,7 +52,7 @@ export async function handle({ event, resolve }) {
|
|
|
49
52
|
];
|
|
50
53
|
|
|
51
54
|
// 🧪 Looser CSP for local/CI test environments
|
|
52
|
-
if (
|
|
55
|
+
if (isDebug) {
|
|
53
56
|
cspDirectives[1] =
|
|
54
57
|
"script-src 'self' 'unsafe-inline' 'unsafe-eval' http://localhost:* ws://localhost:*;";
|
|
55
58
|
cspDirectives[2] = "style-src 'self' 'unsafe-inline' http://localhost:*;";
|
|
@@ -45,13 +45,13 @@ let ph = null;
|
|
|
45
45
|
export async function initPostHog() {
|
|
46
46
|
if (initialized || typeof window === 'undefined') return;
|
|
47
47
|
|
|
48
|
-
const { isAudit, isDev, isTest, mode, effective } =
|
|
48
|
+
const { isAudit, isDebug, isDev, isTest, mode, effective } =
|
|
49
|
+
detectEnvironment();
|
|
49
50
|
|
|
50
51
|
// 🌐 Hybrid hostname + environment guard
|
|
51
52
|
const host = window.location.hostname;
|
|
52
53
|
const isAuditHost = /(^|\.)audit\.netwk\.pro$/i.test(host);
|
|
53
54
|
const effectiveAudit = isAudit || isAuditHost;
|
|
54
|
-
const isDebug = isDev || isTest;
|
|
55
55
|
|
|
56
56
|
// 🧭 Log environment context before any conditional logic
|
|
57
57
|
if (isDebug) {
|
|
@@ -95,9 +95,17 @@ export async function initPostHog() {
|
|
|
95
95
|
const posthogModule = await import('posthog-js');
|
|
96
96
|
ph = posthogModule.default;
|
|
97
97
|
|
|
98
|
+
// ✅ Load public key from env
|
|
99
|
+
const key = import.meta.env.PUBLIC_POSTHOG_PROJECT_KEY;
|
|
100
|
+
//console.log('✅ Key in runtime:', key);
|
|
101
|
+
|
|
102
|
+
if (!key) {
|
|
103
|
+
console.warn('[PostHog] ⚠️ PUBLIC_POSTHOG_PROJECT_KEY is not set.');
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
|
|
98
107
|
// ✅ Initialize PostHog
|
|
99
|
-
|
|
100
|
-
ph.init('phc_Qshfo6AXzh4pS7aPigfqyeo4qj1qlyh7gDuHDeVMSR0', {
|
|
108
|
+
ph.init(key, {
|
|
101
109
|
api_host: '/relay-MSR0/',
|
|
102
110
|
ui_host: 'https://us.posthog.com',
|
|
103
111
|
autocapture: true,
|
package/src/lib/utils/env.js
CHANGED
|
@@ -33,6 +33,8 @@ This file is part of Network Pro.
|
|
|
33
33
|
* @property {boolean} isAudit
|
|
34
34
|
* @property {boolean} isCI
|
|
35
35
|
* @property {boolean} isTest
|
|
36
|
+
* @property {boolean} isDebug - True in dev or test mode (but not prod/audit)
|
|
37
|
+
* @property {boolean} isLocalhost - True if running on localhost (client context only)
|
|
36
38
|
*/
|
|
37
39
|
|
|
38
40
|
/**
|
|
@@ -51,7 +53,7 @@ export const BUILD_ENV_MODE =
|
|
|
51
53
|
* @returns {EnvironmentInfo}
|
|
52
54
|
*/
|
|
53
55
|
export function detectEnvironment(hostOverride) {
|
|
54
|
-
const mode = BUILD_ENV_MODE;
|
|
56
|
+
const mode = (BUILD_ENV_MODE || '').toLowerCase();
|
|
55
57
|
|
|
56
58
|
// Determine host based on execution context
|
|
57
59
|
const host =
|
|
@@ -59,22 +61,35 @@ export function detectEnvironment(hostOverride) {
|
|
|
59
61
|
(typeof window !== 'undefined' ? window.location.hostname : '');
|
|
60
62
|
|
|
61
63
|
const hostIsAudit = /(^|\.)audit\.netwk\.pro$/i.test(host);
|
|
64
|
+
const isLocalhost = /^localhost$|^127\.0\.0\.1$/.test(host);
|
|
62
65
|
|
|
63
66
|
const isDev = ['development', 'dev'].includes(mode);
|
|
64
67
|
const isProd = ['production', 'prod'].includes(mode);
|
|
65
68
|
const isAudit = mode === 'audit' || hostIsAudit;
|
|
66
69
|
const isCI = mode === 'ci';
|
|
67
70
|
const isTest = mode === 'test';
|
|
71
|
+
const isDebug = isDev || isTest;
|
|
68
72
|
|
|
69
73
|
const effective = hostIsAudit && !isAudit ? 'audit(host)' : mode;
|
|
70
74
|
|
|
71
|
-
if (typeof window === 'undefined') {
|
|
72
|
-
console.log('[
|
|
73
|
-
console.log('[
|
|
75
|
+
if (typeof window === 'undefined' && isDebug) {
|
|
76
|
+
console.log('🧭 [env] Server-side build mode:', mode);
|
|
77
|
+
console.log('🧭 [env] Hostname:', host || '(none)');
|
|
78
|
+
console.log('🧭 [env] Raw env:', import.meta.env);
|
|
74
79
|
if (hostIsAudit && mode !== 'audit') {
|
|
75
|
-
console.log('[
|
|
80
|
+
console.log('[env] Host suggests audit, overriding mode.');
|
|
76
81
|
}
|
|
77
82
|
}
|
|
78
83
|
|
|
79
|
-
return {
|
|
84
|
+
return {
|
|
85
|
+
mode,
|
|
86
|
+
effective,
|
|
87
|
+
isDev,
|
|
88
|
+
isProd,
|
|
89
|
+
isAudit,
|
|
90
|
+
isCI,
|
|
91
|
+
isTest,
|
|
92
|
+
isDebug,
|
|
93
|
+
isLocalhost,
|
|
94
|
+
};
|
|
80
95
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
b173de6c44c144c1b186841b88d51c67
|
package/static/sitemap.xml
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
-
<!-- Sitemap last updated 2025-
|
|
2
|
+
<!-- Sitemap last updated 2025-11-03 -->
|
|
3
3
|
|
|
4
4
|
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
|
|
5
5
|
|
|
@@ -125,9 +125,9 @@
|
|
|
125
125
|
|
|
126
126
|
<url>
|
|
127
127
|
|
|
128
|
-
<loc>https://netwk.pro/bin/CC-BY-4.0.html</loc>
|
|
128
|
+
<loc>https://netwk.pro/bin/license/CC-BY-4.0.html</loc>
|
|
129
129
|
|
|
130
|
-
<lastmod>2025-
|
|
130
|
+
<lastmod>2025-11-03</lastmod>
|
|
131
131
|
|
|
132
132
|
<changefreq>yearly</changefreq>
|
|
133
133
|
|
|
@@ -137,9 +137,9 @@
|
|
|
137
137
|
|
|
138
138
|
<url>
|
|
139
139
|
|
|
140
|
-
<loc>https://netwk.pro/bin/COPYING.html</loc>
|
|
140
|
+
<loc>https://netwk.pro/bin/license/COPYING.html</loc>
|
|
141
141
|
|
|
142
|
-
<lastmod>2025-
|
|
142
|
+
<lastmod>2025-11-03</lastmod>
|
|
143
143
|
|
|
144
144
|
<changefreq>yearly</changefreq>
|
|
145
145
|
|
package/svelte.config.js
CHANGED
|
@@ -9,6 +9,7 @@ This file is part of Network Pro.
|
|
|
9
9
|
import adapter from '@sveltejs/adapter-vercel'; // Vercel adapter for deployment
|
|
10
10
|
import { vitePreprocess } from '@sveltejs/vite-plugin-svelte'; // Vite preprocessor for Svelte
|
|
11
11
|
|
|
12
|
+
/** @type {import('@sveltejs/kit').Config} */
|
|
12
13
|
const config = {
|
|
13
14
|
// Only vitePreprocess with PostCSS
|
|
14
15
|
preprocess: vitePreprocess({ postcss: true }),
|
package/vite.config.js
CHANGED
|
@@ -48,6 +48,7 @@ export default defineConfig(({ mode }) => {
|
|
|
48
48
|
// -----------------------------------------------------------------------
|
|
49
49
|
|
|
50
50
|
return {
|
|
51
|
+
envPrefix: ['PUBLIC_'],
|
|
51
52
|
plugins: [
|
|
52
53
|
tsconfigPaths(),
|
|
53
54
|
devtoolsJson({
|
|
@@ -57,7 +58,7 @@ export default defineConfig(({ mode }) => {
|
|
|
57
58
|
}),
|
|
58
59
|
sveltekit(),
|
|
59
60
|
lightningcssPlugin({
|
|
60
|
-
minify:
|
|
61
|
+
minify: ['production', 'audit'].includes(mode),
|
|
61
62
|
pruneUnusedFontFaceRules: true,
|
|
62
63
|
pruneUnusedKeyframes: true,
|
|
63
64
|
removeUnusedFontFaces: true,
|