-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathExchange.sol
548 lines (488 loc) · 21.3 KB
/
Exchange.sol
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
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;
import {Cosmos} from "./CosmosTypes.sol";
import {ExchangeTypes} from "./ExchangeTypes.sol";
interface IExchangeModule {
/****************************************************************************
* AUTHZ *
****************************************************************************/
/// @dev Approves a list of Cosmos messages.
/// @param grantee The account address which will have an authorization to spend the origin funds.
/// @param methods The message type URLs of the methods to approve.
/// @param spendLimit The spend limit for the methods.
/// @return approved Boolean value to indicate if the approval was successful.
function approve(
address grantee,
ExchangeTypes.MsgType[] calldata methods,
Cosmos.Coin[] calldata spendLimit
) external returns (bool approved);
/// @dev Revokes a list of Cosmos messages.
/// @param grantee The contract address which will have its allowances revoked.
/// @param methods The message type URLs of the methods to revoke.
/// @return revoked Boolean value to indicate if the revocation was successful.
function revoke(
address grantee,
ExchangeTypes.MsgType[] calldata methods
) external returns (bool revoked);
/// @dev Checks if there is a valid grant from granter to grantee for specified
/// message type
/// @param grantee The contract address which has the Authorization.
/// @param granter The account address that grants an Authorization.
/// @param method The message type URL of the methods for which the approval should be queried.
/// @return allowed Boolean value to indicatie if the grant exists and is not expired
function allowance(
address grantee,
address granter,
ExchangeTypes.MsgType method
) external view returns (bool allowed);
/****************************************************************************
* ACCOUNT QUERIES *
****************************************************************************/
/// @dev Queries a subaccount's deposits for a given denomination
/// @param subaccountID The ID of the subaccount
/// @param denom The coin denomination
/// @return availableBalance The available balance of the deposit
/// @return totalBalance The total balance of the deposit
function subaccountDeposit (
string calldata subaccountID,
string calldata denom
) external view returns (uint256 availableBalance, uint256 totalBalance);
/// @dev Queries all the deposits of a subaccount
/// @param subaccountID The ID of the subaccount if trader and subaccountNonce are empty
/// @param trader The address of the subaccount owner
/// @param subaccountNonce The nonce of the subaccount
/// @return deposits The array of deposits
function subaccountDeposits(
string calldata subaccountID,
string calldata trader,
uint32 subaccountNonce
) external view returns (SubaccountDepositData[] calldata deposits);
/// @dev SubaccountDepositData contains the information about a deposit.
struct SubaccountDepositData {
string denom;
uint256 availableBalance;
uint256 totalBalance;
}
/// @dev Queries all the derivative positions of a subaccount
/// @param subaccountID The ID of the subaccount
/// @return positions The array of positions
function subaccountPositions(
string calldata subaccountID
) external view returns (DerivativePosition[] calldata positions);
/// @dev DerivativePosition records the conditions under which the trader has
/// entered into the a derivative contract.
/// note derivative orders represent intent, while positions represent
/// possession.
struct DerivativePosition {
string subaccountID;
string marketID;
bool isLong;
uint256 quantity;
uint256 entryPrice;
uint256 margin;
uint256 cumulativeFundingEntry;
}
/****************************************************************************
* ACCOUNT TRANSACTIONS *
****************************************************************************/
/// @dev Transfers coins from the sender's bank balance into the subaccount's
/// exchange deposit. This will increase both the AvailableBalance and the
/// TotalBalance of the subaccount's deposit by the provided amount.
/// @param sender The address of the sender, where the funds will come from
/// @param subaccountID (optional) The ID of the subaccount to deposit funds
/// into. If empty, the coins will be deposited into the sender's default
/// subaccount
/// @param denom The denomination of the coin to deposit
/// @param amount The amount of coins to deposit
/// @return success Whether the transaction was successful or not
function deposit(
address sender,
string calldata subaccountID,
string calldata denom,
uint256 amount
) external returns (bool success);
/// @dev Withdraws from a subaccount's deposit to the sender's bank balance.
/// This will decrement the subaccount's AvailableBalance and TotalBalance by
/// the specified amount. Note that amount must be less than or equal to the
/// deposit's AvailableBalance.
/// @param sender The address of the sender, where coins will be sent to
/// @param subaccountID The ID of the subaccount to withdraw funds from.
/// Note the ownership of the subaccount by sender will be verified.
/// @param denom The denomination of coins to withdraw
/// @param amount The amount of coins to withdraw
/// @return success Whether the transaction was successful or not
function withdraw(
address sender,
string calldata subaccountID,
string calldata denom,
uint256 amount
) external returns (bool success);
/// @dev Transfers funds between two subaccounts owned by the sender
/// @param sender The address of the sender
/// @param sourceSubaccountID The ID of the originating subaccount
/// @param destinationSubaccountID The ID of the destination subaccount
/// @param denom The denomination of coins to transfer
/// @param amount The amount of coins to transfer
/// @return success Whether the transaction was a success or not
function subaccountTransfer(
address sender,
string calldata sourceSubaccountID,
string calldata destinationSubaccountID,
string calldata denom,
uint256 amount
) external returns (bool success);
/// @dev Transfers funds from one of the sender's subaccounts to an external
/// subaccount, not necessarily owned by the sender
/// @param sender The address of the sender
/// @param sourceSubaccountID The ID of the originating subaccount
/// @param destinationSubaccountID The ID of the destination subaccount
/// @param denom The denomination of coins to transfer
/// @param amount The amount of coins to transfer
/// @return success Whether the transaction was a success or not
function externalTransfer(
address sender,
string calldata sourceSubaccountID,
string calldata destinationSubaccountID,
string calldata denom,
uint256 amount
) external returns (bool success);
/// @dev allows for the atomic cancellation and creation of spot and derivative
/// limit orders, along with a new order cancellation mode. Upon execution,
/// order cancellations (if any) occur first, followed by order creations
// (if any).
/// @param sender The address of the sender
/// @param request cf. BatchUpdateOrdersRequest
/// @return response cf. BatchUpdateOrdersResponse
function batchUpdateOrders(
address sender,
BatchUpdateOrdersRequest calldata request
) external returns (BatchUpdateOrdersResponse calldata response);
/// @dev BatchUpdateOrdersRequest encapsulates the parameters of batchUpdateOrders
struct BatchUpdateOrdersRequest {
/// the sender's subaccount ID
string subaccountID;
/// the list of spot market IDs for which the sender wants to cancel all open orders
string[] spotMarketIDsToCancelAll;
/// the specific spot orders the sender wants to cancel
OrderData[] spotOrdersToCancel;
/// the spot orders the sender wants to create
SpotOrder[] spotOrdersToCreate;
/// the list of derivative market IDs for which the sender wants to cancel all open orders
string[] derivativeMarketIDsToCancelAll;
/// the specific derivative orders the sender wants to cancel
OrderData[] derivativeOrdersToCancel;
/// the derivative orders the sender wants to create
DerivativeOrder[] derivativeOrdersToCreate;
}
/// @dev BatchUpdateOrdersResponse encapsulates the return values of batchUpdateOrders
struct BatchUpdateOrdersResponse {
/// reflects the success of spot order cancellations
bool[] spotCancelSuccess;
/// hashes of created spot orders
string[] spotOrderHashes;
/// cids of created spot orders
string[] createdSpotOrdersCids;
/// cids of failed spot orders
string[] failedSpotOrdersCids;
/// reflects the success of derivative order cancellations
bool[] derivativeCancelSuccess;
/// hashes of created derivative orders
string[] derivativeOrderHashes;
/// cids of created derivative orders
string[] createdDerivativeOrdersCids;
/// cids of failed derivative orders
string[] failedDerivativeOrdersCids;
}
/****************************************************************************
* DERIVATIVE MARKETS QUERIES *
****************************************************************************/
/// @dev retrieves a trader's derivative orders by market ID, subaccount ID,
/// and order hashes
/// @param request cf. DerivativeOrdersRequest
/// @return orders the trader's derivative orders
function derivativeOrdersByHashes(
DerivativeOrdersRequest calldata request
) external returns (TrimmedDerivativeLimitOrder[] calldata orders);
/// @dev encapsulates the parameters for derivativeOrdersByHashes
struct DerivativeOrdersRequest {
/// the ID of the market in which to look
string marketID;
/// the ID of the subaccount that created the orders
string subaccountID;
/// the hashes of orders to look for
string[] orderHashes;
}
/// @dev trimmed representation of a derivative limit order
struct TrimmedDerivativeLimitOrder {
uint256 price;
uint256 quantity;
uint256 margin;
/// the amount of the quantity remaining fillable
uint256 fillable;
bool isBuy;
string orderHash;
string cid;
}
/****************************************************************************
* DERIVATIVE MARKETS TRANSACTIONS *
****************************************************************************/
/// @dev encapsulates fields required to create a derivative order (market or limit)
struct DerivativeOrder {
/// the unique ID of the market
string marketID;
/// subaccount that placed the order
string subaccountID;
/// address that will receive fees for the order
string feeRecipient;
/// price of the order
uint256 price;
/// quantity of the order
uint256 quantity;
/// order identifier
string cid;
/// order type ("buy", "sell", "buyPostOnly", or "sellPostOnly")
string orderType;
/// the margin used by the limit order
uint256 margin;
/// the trigger price used by stop/take orders
uint256 triggerPrice;
}
/// @dev encapsulates the return values of createDerivativeLimitOrder
struct CreateDerivativeLimitOrderResponse {
string orderHash;
string cid;
}
/// @dev encapsulates the return values of batchCreateDerivativeLimitOrders
struct BatchCreateDerivativeLimitOrdersResponse {
// hashes of created derivative limit orders
string[] orderHashes;
// cids of created orders
string[] createdOrdersCids;
// cids of failed orders
string[] failedOrdersCids;
}
/// @dev encapsulates the return values of createDerivativeMarketOrderResponse
struct CreateDerivativeMarketOrderResponse {
string orderHash;
string cid;
uint256 quantity;
uint256 price;
uint256 fee;
uint256 payout;
uint256 deltaExecutionQuantity;
uint256 deltaExecutionMargin;
uint256 deltaExecutionPrice;
bool deltaIsLong;
}
/// @dev encapsulates data used to identify an order to cancel
struct OrderData {
string marketID;
string subaccountID;
string orderHash;
int32 orderMask;
string cid;
}
/// @dev orderMask values
///
/// OrderMask_UNUSED OrderMask = 0
/// OrderMask_ANY OrderMask = 1
/// OrderMask_REGULAR OrderMask = 2
/// OrderMask_CONDITIONAL OrderMask = 4
/// OrderMask_BUY_OR_HIGHER OrderMask = 8
/// OrderMask_SELL_OR_LOWER OrderMask = 16
/// OrderMask_MARKET OrderMask = 32
/// OrderMask_LIMIT OrderMask = 64
/// @dev create a derivative limit order
/// @param sender The address of the sender
/// @param order The derivative order to create (cf. DerivativeOrder)
/// @return response cf CreateDerivativeLimitOrderResponse
function createDerivativeLimitOrder(
address sender,
DerivativeOrder calldata order
) external returns (CreateDerivativeLimitOrderResponse calldata response);
/// @dev create a batch of derivative limit orders
/// @param sender The address of the sender
/// @param orders The orders to create
/// @return response cf. BatchCreateDerivativeLimitOrdersResponse
function batchCreateDerivativeLimitOrders(
address sender,
DerivativeOrder[] calldata orders
) external returns (BatchCreateDerivativeLimitOrdersResponse calldata response);
/// @dev create a derivative market order
/// @param sender The address of the sender
/// @param order The order to create
/// @return response cf. CreateDerivativeMarketOrderResponse
function createDerivativeMarketOrder(
address sender,
DerivativeOrder calldata order
) external returns (CreateDerivativeMarketOrderResponse calldata response);
/// @dev cancel a derivative order
/// @param marketID The market the order is in
/// @param subaccountID The subaccount that placed the order
/// @param orderHash The order hash
/// @param orderMask The order mask (use default 0 if you don't know what this is)
/// @param cid The identifier of the order
/// @return success Whether the order was successfully cancelled
function cancelDerivativeOrder(
address sender,
string calldata marketID,
string calldata subaccountID,
string calldata orderHash,
int32 orderMask,
string calldata cid
) external returns (bool success);
/// @dev cancel a batch of derivative orders
/// @param sender The address of the sender
/// @param data The data of the orders to cancel
/// @return success Whether each cancellation succeeded
function batchCancelDerivativeOrders(
address sender,
OrderData[] calldata data
) external returns (bool[] calldata success);
/// @dev increase the margin of a position
/// @param sender The address of the sender
/// @param sourceSubaccountID The subaccount to send balance from
/// @param destinationSubaccountID The subaccount that owns the position
/// @param marketID The market where position is in
/// @param amount The amount by which to increase the position margin
/// @return success Whether the operation succeeded or not
function increasePositionMargin(
address sender,
string calldata sourceSubaccountID,
string calldata destinationSubaccountID,
string calldata marketID,
uint256 amount
) external returns (bool success);
/// @dev defines a request to decrease the margin of a position
/// @param sender The address of the sender
/// @param sourceSubaccountID The subaccount that owns the position
/// @param destinationSubaccountID The subaccount to send balance to
/// @param marketID The market where position is in
/// @param amount The amount by which to decrease the position margin
/// @return success Whether the operation succeeded or not
function decreasePositionMargin(
address sender,
string calldata sourceSubaccountID,
string calldata destinationSubaccountID,
string calldata marketID,
uint256 amount
) external returns (bool success);
/****************************************************************************
* SPOT MARKETS QUERIES *
****************************************************************************/
/// @dev retrieves a trader's spot orders by market ID, subaccount ID,
/// and order hashes
/// @param request cf. SpotOrdersRequest
/// @return orders the trader's spot orders
function spotOrdersByHashes(
SpotOrdersRequest calldata request
) external returns (TrimmedSpotLimitOrder[] calldata orders);
/// @dev encapsulates the parameters for spotOrdersByHashes
struct SpotOrdersRequest {
/// the ID of the market in which to look
string marketID;
/// the ID of the subaccount that placed the orders
string subaccountID;
/// the hashes of orders to look for
string[] orderHashes;
}
/// @dev trimmed representation of a spot limit order
struct TrimmedSpotLimitOrder {
uint256 price;
uint256 quantity;
/// the amount of the quantity remaining fillable
uint256 fillable;
bool isBuy;
string orderHash;
string cid;
}
/****************************************************************************
* SPOT MARKETS TRANSACTIONS *
****************************************************************************/
/// @dev encapsulates fields required to create a spot order (market or limit)
struct SpotOrder {
/// the unique ID of the market
string marketID;
/// subaccount that creates the order
string subaccountID;
/// address that will receive fees for the order
string feeRecipient;
/// price of the order
uint256 price;
/// quantity of the order
uint256 quantity;
/// order identifier
string cid;
/// order type ( "buy", "sell", "buyPostOnly", or "sellPostOnly")
string orderType;
/// the trigger price used by stop/take orders
uint256 triggerPrice;
}
/// @dev encapsulates the return values of createSpotLimitOrder
struct CreateSpotLimitOrderResponse {
string orderHash;
string cid;
}
/// @dev encapsulates the return values of batchCreateSpotLimitOrders
struct BatchCreateSpotLimitOrdersResponse {
/// hashes of created spot orders
string[] orderHashes;
/// cids of created spot orders
string[] createdOrdersCids;
/// cids of failed spot orders
string[] failedOrdersCids;
}
/// @dev encapsulates the return values of createSpotMarketOrder
struct CreateSpotMarketOrderResponse {
string orderHash;
string cid;
uint256 quantity;
uint256 price;
uint256 fee;
}
/// @dev create a spot limit order
/// @param sender The address of the sender
/// @param order The spot order to create (cf. SpotOrder)
/// @return response cf. CreateSpotLimitOrderResponse
function createSpotLimitOrder(
address sender,
SpotOrder calldata order
) external returns (CreateSpotLimitOrderResponse calldata response);
/// @dev create a batch of spot limit orders
/// @param sender The address of the sender
/// @param orders The orders to create
/// @return response cf. BatchCreateSpotOrdersResponse
function batchCreateSpotLimitOrders(
address sender,
SpotOrder[] calldata orders
) external returns (BatchCreateSpotLimitOrdersResponse calldata response);
/// @dev create a spot market order
/// @param sender The address of the sender
/// @param order The order to create
/// @return response cf. batchCreateSpotMarketOrderResponse
function createSpotMarketOrder(
address sender,
SpotOrder calldata order
) external returns (CreateSpotMarketOrderResponse calldata response);
/// @dev cancel a spot order
/// @param marketID The market the order is in
/// @param subaccountID The subaccount that created the order
/// @param orderHash The order hash
/// @param cid The identifier of the order
/// @return success Whether the order was successfully cancelled
function cancelSpotOrder(
address sender,
string calldata marketID,
string calldata subaccountID,
string calldata orderHash,
string calldata cid
) external returns (bool success);
/// @dev cancel a batch of spot orders
/// @param sender The address of the sender
/// @param data The data of the orders to cancel
/// @return success Whether each cancellation succeeded
function batchCancelSpotOrders(
address sender,
OrderData[] calldata data
) external returns (bool[] calldata success);
}