Full analytics platform with MaxMind GeoLite2 IP-to-location resolution, cross-module dashboard (docs, video, photo), user drill-down, volunteer self-service stats, and ANALYTICS_ADMIN role with feature flag controls. - ANALYTICS_ADMIN role + ANALYTICS_ROLES group across backend and frontend - GeoIP service (MaxMind GeoLite2, lazy-loaded, graceful degradation) - Geo fields (country, region, city, lat/lng) on DocsPageView, VideoView, PhotoView - IP resolved to geo before SHA-256 hashing (privacy-preserving) - Unified analytics module: overview, geo, content, user engagement endpoints - 4 admin dashboard pages: Overview, Geography (Leaflet map), Content, Users - Volunteer MyAnalyticsPage for self-service activity stats - Settings UI: enableAnalytics, analyticsGeoEnabled, trackAuthenticatedUsers, retentionDays - Scheduled cleanup job respecting configurable retention period - config.sh: Analytics + MaxMind prompt in configure_features() - Control panel: enableAnalytics flag, template, discovery, wizard, detail page - Docker: geoip volume mount, MaxMind env vars, entrypoint auto-download - Nginx: X-Forwarded-For fix ($proxy_add_x_forwarded_for) for real client IP - Express trust proxy set to 2 for Pangolin/Newt tunnel chain - CORS updated for docs origin (cmlite.org + docs.cmlite.org) - Lander page: added docs-analytics tracking snippet - Prisma migration: 20260402100000_add_analytics_system Bunker Admin
40 lines
1.4 KiB
SQL
40 lines
1.4 KiB
SQL
-- AlterEnum
|
|
ALTER TYPE "UserRole" ADD VALUE 'ANALYTICS_ADMIN';
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "docs_page_views" ADD COLUMN "city" VARCHAR(100),
|
|
ADD COLUMN "country" VARCHAR(2),
|
|
ADD COLUMN "ip_address_hash" VARCHAR(64),
|
|
ADD COLUMN "latitude" DOUBLE PRECISION,
|
|
ADD COLUMN "longitude" DOUBLE PRECISION,
|
|
ADD COLUMN "region" VARCHAR(100);
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "photo_views" ADD COLUMN "city" VARCHAR(100),
|
|
ADD COLUMN "country" VARCHAR(2),
|
|
ADD COLUMN "latitude" DOUBLE PRECISION,
|
|
ADD COLUMN "longitude" DOUBLE PRECISION,
|
|
ADD COLUMN "region" VARCHAR(100);
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "site_settings" ADD COLUMN "analytics_geo_enabled" BOOLEAN NOT NULL DEFAULT true,
|
|
ADD COLUMN "analytics_retention_days" INTEGER NOT NULL DEFAULT 90,
|
|
ADD COLUMN "enable_analytics" BOOLEAN NOT NULL DEFAULT false,
|
|
ADD COLUMN "track_authenticated_users" BOOLEAN NOT NULL DEFAULT true;
|
|
|
|
-- AlterTable
|
|
ALTER TABLE "video_views" ADD COLUMN "city" VARCHAR(100),
|
|
ADD COLUMN "country" VARCHAR(2),
|
|
ADD COLUMN "latitude" DOUBLE PRECISION,
|
|
ADD COLUMN "longitude" DOUBLE PRECISION,
|
|
ADD COLUMN "region" VARCHAR(100);
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "docs_page_views_country_createdAt_idx" ON "docs_page_views"("country", "createdAt");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "idx_photo_views_country_date" ON "photo_views"("country", "viewed_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "idx_video_views_country_created" ON "video_views"("country", "created_at");
|