πŸ’š

Health Check

Is the API running? Hit one of these.

Environment Local
Auth Not logged in
SignalR Disconnected
Response will appear here.
πŸ“‘

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.

Disconnected
β€”
πŸ“‘

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.

Response will appear here.

Apple IAP config diagnostics (Admin only). Calls GET /api/Credits/debug/apple-config.

Response will appear here.
πŸ”

Welcome

Sign in to access the tester dashboard.

New here?

Step 1 sends OTP to email. Enter it in Step 2, then set password in Step 3.

Step 1
Step 2
Step 3
Already have an account?
Step 1
Step 2
Step 3
Remembered your password?
Google

Or paste a Google ID token:

Apple

Paste Firebase ID token after Apple sign-in via Firebase Auth.

Firebase

Paste a Firebase ID token from your app (e.g. user.getIdToken()).

Prefer email/password?
πŸ“š

Docs

Module-wise documentation viewer (Markdown).

Select a module and document to view it here.
πŸ‘€

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.

Uses Google Places – type to see top 10 suggestions, then click to select.
You can also paste lat/long and click β€œReverse geocode” to fill location.
Recommended: use Direct-to-Azure upload. Legacy modes are kept for backward compatibility testing.

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.

Current tile video ID in URL is treated as 5th video for /validate batch settle to 30.
After preset, click "Validate video" on any tile in My Feed / Unrated list.
Progress: β€”/5 | Lifetime ratings: β€” | Credit balance: β€”

Home map search

Calls GET /api/map/search?query=.... It searches video metadata fields and returns matching videos with map coordinates.

(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.

Progress: β€”/5 | Pending for milestone: β€” | Lifetime ratings: β€” | Credit balance: β€”

Selecting a candidate auto-fills Video ID.
(Candidate list with owner details will appear here.)
Response 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.

Response will appear here.
πŸ””

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.

🧠

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.

(Load videos to start selection.)
πŸ’³

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.

Select Option
Click "Get packages" to load bundles.
If a saved card is selected, payment will use it without entering card details again.

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.

Choose a package to load its Id and fields for update. Leave empty to create a new package.

Reported videos moderation

Admin-only moderation queue with 3 categories: Pending, Removed, Allowed.

(Video reports will appear here.)
πŸ‘₯

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).