Health Check
Is the API running? Hit one of these.
SignalR (Video Hub)
Connect to the real-time Video hub. Youβll see events when videos are uploaded, location groups updated, or videos deleted. Login required.
Hub URL: /hubs/videos. Connect with your current token, then upload or delete a video in the Videos section to see events here.
β
Infra trace (SignalR Β· Redis Β· Service Bus)
Hub events in a sortable log. Development API only: inspect live-stream Redis keys and recent Service Bus publishes from this app (see Redis / Service Bus tabs).
Uses the same hub connection as Realtime. Connect once (either tab), then delete or upload a video to see VideoDeleted vs other events.
| Time | Kind | Event / line | Summary | Payload |
|---|
Health: GET /api/infra/runtime-health. Live stream Redis snapshot (Development): GET /api/infra/live-stream-redis/{sessionId} β session hash, viewers, activity, stream:meta, counters.
β
Recent messages published by this API (Development): GET /api/infra/live-stream-servicebus-recent?sessionId=β¦. Worker consumption β Azure Portal or Workers console.
β
Live monitor (Development API): GET /api/infra/live-monitor β active streams, Redis viewers (global), join/leave on this API node. Connect SignalR for real-time LiveStreamViewerCountUpdated. Multi-instance: open Test-UI against each pod URL.
Active live streams
| Session | Channel | DB viewers | Redis viewers | Redis user ids |
|---|
Join / leave on this API node
| Time | Action | User | Stream | Source | Count |
|---|
Last health summary
Live Stream Testing
Host and audience tokens, go-live, RTC preview, event-linked streams, request live, and report testing.
Normal user β What happens with Live & Report? (tap to collapse)
Without Report: Host Go Live β followers notify. Request live β receiver gets SignalR RequestLive (+ bell). Receiver Start = accept β requesters get βis now liveβ.
Report (live): 1 report β stream auto-stops for moderation, then admin can Approve or Reject.
Admin is not in normal go-live β only after reports (see Admin tab).
Login required. Flow: Event (optional) β Host token β Start β Join/End. Two accounts for request live: target must Connect hub (Realtime tab) for RequestLive.
Active live streams
All currently live sessions from GET /api/videos/my-videos/grouped-by-location. Connect Realtime β SignalR for instant viewer join/leave updates.
Live activity log (join / leave / SignalR)
Follow & go-live requests
source on go-live request.
(Pending requests JSON appears here.)
Event + live stream
The API attaches your stream to an event when coordinates match: ~30 m of a venue in Redis events:geo, or inside the geofence polygon when available.
Leave Event ID empty to let the backend pick the nearest match. Fill Event ID to force that event β you must still be within its area or you get a validation error.
eventId when a link was created. That value is summarized here for quick testing.
1) Token
2) Start stream
2.5) RTC publish/playback (Laptop cam)
3) Join / End
3b) Report live stream (viewer)
Join as viewer (another account), paste Live stream ID above (ls_β¦). Reports via unified POST /api/videos/{id}/report (same reasons as videos). 1st distinct report: reporter-only banner; 2nd distinct report (default threshold): stream auto-stops for moderation.
4) Feed check
(Grouped feed result will appear here.)
Sentry Test
Trigger a test exception to verify Sentry is capturing errors.
This calls GET /api/SentryTest/throw which throws an exception. You should see a 500 response here and the error in your Sentry dashboard.
Apple IAP config diagnostics (Admin only). Calls GET /api/Credits/debug/apple-config.
Day-wise Logs
List backend rolling logs, view latest lines, and download by day.
Reads all files from backend Logs folder. View opens full file content and download saves full file.
(Select a log file to view.)
Welcome
Sign in to access the tester dashboard.
Step 1 sends OTP to email. Enter it in Step 2, then set password in Step 3.
Docs
Module-wise documentation viewer (Markdown).
Profile
Get or update your profile: name, email (read-only), gender, dashcam type, profile picture. Login required.
Change password
Set a new password (requires current password). Login required.
Videos
Test video upload modes: Direct-to-Azure (recommended) and Legacy API modes. Login required.
Chunked upload: use Direct-to-Azure (recommended) or Legacy API-proxied chunks (older POC). Thumbnail is optional on complete for these chunked flows.
Load my videos = everyone's videos. My Feed = only your videos (with views, shares, average rating). Use Play (MP4) to play immediately; Play (HLS) appears after background encoding (refresh after 1β2 min). Validation uses 1/2/5 tiers, and in rating-batch mode you send 4 previous IDs while current URL video is the 5th.
Home map search
Calls GET /api/map/search?query=.... It returns both metadata search matches and Google location-based matches, including isGoogleLocationResult and fallback lat/lng when no nearby video is found.
(Map search results will appear here.)
ML manual bearer token (optional)
If provided, this token is used for GET /api/videos/nearby and POST /api/webhooks/video-analysis. If empty, UI uses your login token.
Nearby analysis lookup
Calls GET /api/videos/nearby with latitude, longitude, timestamp, radius and time_range to verify ML analysis records.
(Nearby analysis results will appear here.)
AI/ML callback webhook tester
Calls POST /api/webhooks/video-analysis with required Authorization: Bearer and X-Job-ID header.
Rate Testing
Rate-focused testing for milestone progress, owner visibility, and full validation payloads.
Use this tab to test rating flow quickly without scrolling the full Videos section.
(Candidate list with owner details will appear here.)
Valid Videos Rate
Only valid videos (not expired, not deleted) that you can rate. Rate directly from tile and verify confidence score update.
This uses GET /api/videos/videos-left-to-rate and shows confidence score, average rating, and per-user rating entries for each tile.
Notifications (v1)
Register device token, list notifications, unread count, mark read, and send admin test push.
1) Register Device
Calls POST /api/v1/devices. Login required.
2) List Notifications
Calls GET /api/v1/notifications. Use filters as needed.
(Notifications list will appear here.)
3) Mark as Read
4) Test Push (Admin)
Calls POST /api/v1/notifications/test-push. Admin JWT required.
5) Admin Simulation Helpers
Admin-only helper actions to quickly test the 2 enabled admin auto-notification flows.
6) Request Live β test bench (all results on this page)
Single window: log in as target β Use my user ID β Connect hub β Run full test. Two windows: target connects hub in window A; sender uses target Guid in window B.
Logged-in user: β
(Presence and send responses appear here.)
(Connect hub as the target user; events show here when delivery works.)
AI/ML Reprocess
Select videos and submit to AI/ML through backend so ML job id is persisted on video.
Loads your videos from backend and calls backend endpoint POST /api/videos/{id}/ml/submit for selected videos.
Credits & Buy Credits
View balance, packages, and create a Stripe payment intent to buy credits. Login required for overview and purchase.
Select a package and create a payment intent. Use the returned clientSecret with Stripe.js (or test with Stripe test card 4242 4242 4242 4242). After payment, webhook adds credits.
Verify IAP purchase (Apple / Google)
Login required. This calls POST /api/credits/verify-purchase.
Transaction history (last 30 days).
Admin β Credits
For Admin users only. Manage base price per credit and credit packages.
You must be logged in as an Admin (UserRole.Admin) for these calls to succeed.
Base price per credit
Packages
(Packages will appear here.)
Create or update a package below, then click the corresponding button.
Admin β What can report review do? (tap to expand)
Video: Allow = content OK. Remove = take down (+ optional block user).
Live: 1 report auto-ends stream β admin reviews. Approve = short playback (~48h). Reject = remove. Force stop = end while still live.
List: GET /api/admin/reported-content (video + live).
Reported content (video + live)
Click any tile β POST /api/admin/video-reports/by-ids (uses session/video GUID; report id optional for live).
All: β | Pending: β | Allowed: β | Removed: β
Admin - Users
For Admin users only. List users sorted by active first and newest created.
Calls /api/admin/users with paging and includeRelated options.
(Users will appear here.)
Refresh Token
Get new tokens (uses saved refresh token).
Logout
Sign out (uses current token).
Ticketmaster Events World Map
Load normalized events from /api/events/search, plot by lat/long, view details, and inspect venue polygon + center point.
All available events first, then filter by real data
The map auto-loads available events, keeps the view smooth, and shows clean event points for every lat/long.
Or paste a Google ID token:
Paste Firebase ID token after Apple sign-in via Firebase Auth.
Paste a Firebase ID token from your app (e.g.
user.getIdToken()).