-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathbacktests.ts
226 lines (197 loc) · 7.41 KB
/
backtests.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { APIResource } from '../../../resource';
import * as Core from '../../../core';
export class Backtests extends APIResource {
/**
* Initiates a request to asynchronously generate a backtest for an authorization
* rule. During backtesting, both the active version (if one exists) and the draft
* version of the Authorization Rule are evaluated by replaying historical
* transaction data against the rule's conditions. This process allows customers to
* simulate and understand the effects of proposed rule changes before deployment.
* The generated backtest report provides detailed results showing whether the
* draft version of the Auth Rule would have approved or declined historical
* transactions which were processed during the backtest period. These reports help
* evaluate how changes to rule configurations might affect overall transaction
* approval rates.
*
* The generated backtest report will be delivered asynchronously through a webhook
* with `event_type` = `auth_rules.backtest_report.created`. See the docs on
* setting up [webhook subscriptions](https://docs.lithic.com/docs/events-api). It
* is also possible to request backtest reports on-demand through the
* `/v2/auth_rules/{auth_rule_token}/backtests/{auth_rule_backtest_token}`
* endpoint.
*
* Lithic currently supports backtesting for `CONDITIONAL_BLOCK` rules. Backtesting
* for `VELOCITY_LIMIT` rules is generally not supported. In specific cases (i.e.
* where Lithic has pre-calculated the requested velocity metrics for historical
* transactions), a backtest may be feasible. However, such cases are uncommon and
* customers should not anticipate support for velocity backtests under most
* configurations. If a historical transaction does not feature the required inputs
* to evaluate the rule, then it will not be included in the final backtest report.
*/
create(
authRuleToken: string,
body: BacktestCreateParams,
options?: Core.RequestOptions,
): Core.APIPromise<BacktestCreateResponse> {
return this._client.post(`/v2/auth_rules/${authRuleToken}/backtests`, { body, ...options });
}
/**
* Returns the backtest results of an authorization rule (if available).
*
* Backtesting is an asynchronous process that requires time to complete. If a
* customer retrieves the backtest results using this endpoint before the report is
* fully generated, the response will return null for `results.current_version` and
* `results.draft_version`. Customers are advised to wait for the backtest creation
* process to complete (as indicated by the webhook event
* auth_rules.backtest_report.created) before retrieving results from this
* endpoint.
*
* Backtesting is an asynchronous process, while the backtest is being processed,
* results will not be available which will cause `results.current_version` and
* `results.draft_version` objects to contain `null`. The entries in `results` will
* also always represent the configuration of the rule at the time requests are
* made to this endpoint. For example, the results for `current_version` in the
* served backtest report will be consistent with which version of the rule is
* currently activated in the Auth Stream, regardless of which version of the rule
* was active in the Auth Stream at the time a backtest is requested.
*/
retrieve(
authRuleToken: string,
authRuleBacktestToken: string,
options?: Core.RequestOptions,
): Core.APIPromise<BacktestResults> {
return this._client.get(`/v2/auth_rules/${authRuleToken}/backtests/${authRuleBacktestToken}`, options);
}
}
export interface BacktestResults {
/**
* Auth Rule Backtest Token
*/
backtest_token: string;
results: BacktestResults.Results;
simulation_parameters: BacktestResults.SimulationParameters;
}
export namespace BacktestResults {
export interface Results {
current_version?: Results.CurrentVersion | null;
draft_version?: Results.DraftVersion | null;
}
export namespace Results {
export interface CurrentVersion {
/**
* The total number of historical transactions approved by this rule during the
* backtest period, or the number of transactions that would have been approved if
* the rule was evaluated in shadow mode.
*/
approved?: number;
/**
* The total number of historical transactions declined by this rule during the
* backtest period, or the number of transactions that would have been declined if
* the rule was evaluated in shadow mode.
*/
declined?: number;
/**
* Example authorization request events that would have been approved or declined.
*/
examples?: Array<CurrentVersion.Example>;
/**
* The version of the rule, this is incremented whenever the rule's parameters
* change.
*/
version?: number;
}
export namespace CurrentVersion {
export interface Example {
/**
* Whether the rule would have approved the authorization request.
*/
approved?: boolean;
/**
* The authorization request event token.
*/
event_token?: string;
/**
* The timestamp of the authorization request event.
*/
timestamp?: string;
}
}
export interface DraftVersion {
/**
* The total number of historical transactions approved by this rule during the
* backtest period, or the number of transactions that would have been approved if
* the rule was evaluated in shadow mode.
*/
approved?: number;
/**
* The total number of historical transactions declined by this rule during the
* backtest period, or the number of transactions that would have been declined if
* the rule was evaluated in shadow mode.
*/
declined?: number;
/**
* Example authorization request events that would have been approved or declined.
*/
examples?: Array<DraftVersion.Example>;
/**
* The version of the rule, this is incremented whenever the rule's parameters
* change.
*/
version?: number;
}
export namespace DraftVersion {
export interface Example {
/**
* Whether the rule would have approved the authorization request.
*/
approved?: boolean;
/**
* The authorization request event token.
*/
event_token?: string;
/**
* The timestamp of the authorization request event.
*/
timestamp?: string;
}
}
}
export interface SimulationParameters {
/**
* Auth Rule Token
*/
auth_rule_token?: string;
/**
* The end time of the simulation.
*/
end?: string;
/**
* The start time of the simulation.
*/
start?: string;
}
}
export interface BacktestCreateResponse {
/**
* Auth Rule Backtest Token
*/
backtest_token?: string;
}
export interface BacktestCreateParams {
/**
* The end time of the backtest.
*/
end?: string;
/**
* The start time of the backtest.
*/
start?: string;
}
export declare namespace Backtests {
export {
type BacktestResults as BacktestResults,
type BacktestCreateResponse as BacktestCreateResponse,
type BacktestCreateParams as BacktestCreateParams,
};
}