Navigation
View as Markdown

Risks

A risk is Rupt's read on what an evaluation looks like (this smells like account takeover, this looks like a fake account), scored per category and graded by severity. A risk never dictates the verdict on its own. It's a summary, and your policies decide what to do with it.

How a risk is scored

Risks are built from the ground up:

  • Signals are the raw measurements Rupt collects from the user's environment.
  • Checks turn those signals into specific facts: is this IP a VPN, has this user moved impossibly far since last seen.
  • A risk takes the checks that predict it, weights each by how much it counts, and adds them up.

That weighted total is the score, and each risk maps its score to one of four severities: low, medium, high, or maximum.

The cutoffs aren't shared across risks. Each risk sets its own, because the same check can carry very different weight depending on what you're detecting: a score one risk treats as high might still be medium for another. Severity also depends on how the checks combine, not just how many fire: for account sharing, concurrent sessions and impossible travel together rank far higher than either alone, while a modest device count on its own stays low.

The severities roll up into a risk_summary on the evaluation. Read it in your own logic, or write a policy over the checks behind a risk. Matching a policy directly on a risk severity is coming soon.

Standard risks

Rupt ships with a standard set of risks out of the box, and the list grows as the fraud landscape shifts. You don't configure anything to get them. Most are scored for your policies to act on directly; a few Rupt only records for visibility.

Acted on by policies

Each of these is scored so your policies can match it directly, weighting every check by how strongly it predicts the risk.

Recorded for visibility

Rupt scores these on every evaluation but doesn't act on them by default. They surface in the dashboard so you can keep an eye on them.

  • bot: automated, non-human traffic. See Bots.
  • tampering: the client environment has been modified to lie about itself.
  • anti_fingerprinting: the user is running tooling built to defeat fingerprinting, like Tor Browser, Brave farbling, or Firefox RFP.
  • incognito: the session is in private browsing mode.
  • replay_attack: a captured evaluation is being replayed instead of run fresh.

Custom risks (coming soon)

Soon you'll be able to define your own risks in the dashboard. Since a risk is just a weighted set of checks, and checks are derived from signals, you'll pick the checks that matter, set how much each one counts, and choose the score thresholds that map to severity, the same machinery Rupt's built-in risks run on. That lets you target whatever's specific to your business: fraudulent listings, low-intent leads, payout abuse, and the like.

This is coming very soon.

Where risks fit

Risks summarize. Policies decide. The verdict acts.