M1
d278ab0458
fix: use credentials:include for cross-origin API requests
2026-03-18 09:44:50 +04:00
M1
9fb90d9ea8
fix: point dashboard API calls to api.pingql.com
2026-03-18 09:39:07 +04:00
M1
3a9cd62cdd
fix: increase tos top padding to pt-28
2026-03-18 09:26:18 +04:00
M1
1325512c6d
fix: reduce tos page padding and section spacing
2026-03-18 04:04:47 +04:00
M1
7a6a1fdd10
build: rebuild css with pt-40 and pt-2 for tos page
2026-03-18 04:02:47 +04:00
M1
7e3c651db7
fix: define brand color via @theme for tailwind v4 compat
2026-03-18 03:25:34 +04:00
M1
5c91cbc522
refactor: convert all static HTML to EJS with cssHash cache-busting, remove stale html files
2026-03-17 09:54:44 +04:00
M1
6342ec907f
fix: tailwind v4 @source directives, rebuild CSS (8.9KB → 33KB)
2026-03-17 09:42:24 +04:00
M1
a995fe3c94
feat: replace Tailwind CDN with self-hosted pre-built CSS
2026-03-17 09:32:34 +04:00
M1
3638ce3dd2
chore: check -> ping
2026-03-17 09:28:45 +04:00
M1
081d3ad6e2
chore: simplify global network card copy
2026-03-17 09:27:50 +04:00
M1
6cf11dadde
feat: replace response time card with global monitoring network
2026-03-17 09:26:49 +04:00
M1
486c94f4ff
chore: strengthen security section on privacy page
2026-03-17 08:42:01 +04:00
M1
6965a114f0
chore: lifetime -> with strikethrough
2026-03-17 08:36:25 +04:00
M1
ca686403d9
chore: drop XEC ticker
2026-03-17 08:31:53 +04:00
M1
3fa6c5f1f6
chore: add eCash/XEC to accepted crypto
2026-03-17 08:31:08 +04:00
M1
7d67312a1b
feat: replace SSRF card with crypto payments feature card
2026-03-17 08:30:23 +04:00
M1
a5d321f198
chore: drop Stripe from privacy page, add crypto payments mention
2026-03-17 08:26:58 +04:00
M1
62b67aaa7c
feat: privacy page at /privacy, drop query language nav link
2026-03-17 08:22:17 +04:00
M1
5dd514aa94
feat: update landing features to reflect current product
2026-03-17 08:17:15 +04:00
M1
24bf97ae7d
chore: pro interval 2.5s -> 1s
2026-03-17 08:15:06 +04:00
M1
0e6c27eca9
chore: pro plan -> /mo
2026-03-17 08:13:53 +04:00
M1
e925e9b0ed
feat: add lifetime plan at to pricing section
2026-03-17 08:09:35 +04:00
M1
819a979f28
chore: pro plan priced at /mo
2026-03-17 08:02:56 +04:00
M1
08e5039d81
chore: free plan 5 monitors / 20s interval
2026-03-17 08:02:04 +04:00
M1
98c0cc35b2
chore: pro plan interval 5s -> 2.5s
2026-03-17 07:58:42 +04:00
M1
34fd66f784
feat: pricing page — 10 monitors/30s free, unlimited/5s pro coming soon; enforce 30s min interval
2026-03-17 07:55:07 +04:00
M1
66b368453d
refactor: single account-level SSE stream instead of per-monitor connections
2026-03-17 07:06:09 +04:00
M1
b80f4673b2
fix: use standard UUID v4 for keys instead of custom 256-bit hex format
2026-03-17 06:26:52 +04:00
M1
bbd5df8c46
fix: 8 groups of 8 chars, not 16 groups of 4
2026-03-17 06:26:14 +04:00
M1
43a1abc2ed
fix: format keys as XXXX-XXXX-...-XXXX (8 groups), normalize before hashing
...
Keys are now human-readable grouped hex instead of raw 64-char blobs.
resolveKey() strips dashes before sha256/bcrypt so both formats work.
All key creation paths (register, reset-key, sub-keys) hash the
normalized form. Login placeholder and maxlength updated to match.
2026-03-17 06:25:19 +04:00
M1
b8ac4e7b1f
fix: redirect loop on stale cookie, login broken for 64-char keys, stale docs
...
- /dashboard now validates key before redirecting to /home — bad/old keys
clear the cookie and show login instead of looping
- Login form: remove old 4-group auto-formatter, fix maxlength 19→64,
fix min length validation 19→10, update placeholder
- New key display: break-all so 64-char hex wraps properly
- docs.html: update example key format and description
2026-03-17 06:22:16 +04:00
M1
2f7273604b
refactor: full SSR dashboard, minimal SSE DOM patches, poll-based refresh
2026-03-16 21:14:45 +04:00
M1
ef56b47b09
feat: cookie-based auth, SSR dashboard, JS-optional login
2026-03-16 17:25:59 +04:00
M1
31d1fa7b04
fix: SSE via fetch for auth headers, remove query param auth, add heartbeat every 10s
2026-03-16 16:17:33 +04:00
M1
6d48a83560
feat: SSE live ping stream for monitors
2026-03-16 16:14:23 +04:00
M1
1e95149456
feat: live-updating timestamps via data-ts attribute
2026-03-16 16:10:04 +04:00
M1
87c924d8d0
fix: app.js deferred in head (fixes requireAuth undefined), extract app.css
2026-03-16 15:16:59 +04:00
M1
389c88e124
ux: move new monitor button to content area next to heading
2026-03-16 15:09:15 +04:00
M1
ce155cd338
feat: settings page — email, key rotation, sub-keys
2026-03-16 15:05:39 +04:00
M1
eb3ef7745f
fix: emails used for recovery only, not notifications (notifications coming later)
2026-03-16 14:59:17 +04:00
M1
4e7fdfa07c
fix: tighten hero bottom padding
2026-03-16 14:54:56 +04:00
M1
2627ad756f
fix: align hero comment with actual query
2026-03-16 14:50:45 +04:00
M1
e12e5e682c
copy: hero example uses $.db.status to show JSON inspection, shorter comment
2026-03-16 14:49:59 +04:00
M1
bf02243708
fix: replace $json latency with $responseTime in hero example
2026-03-16 14:48:23 +04:00
M1
6f7127aded
copy: use real field names in hero code comment
2026-03-16 14:46:47 +04:00
M1
5613fb9cf4
fix: reduce gap between header and hero
2026-03-16 14:44:53 +04:00
M1
6f5f51e390
copy: update API section tagline
2026-03-16 14:41:56 +04:00
M1
729529b7fa
fix: checked_at field name in dashboard UI + landing copy
2026-03-16 14:37:44 +04:00
M1
f4283a0915
feat: sticky header with nav links on landing page
2026-03-16 14:21:24 +04:00