forked from ajna-finance/subgraph
-
Notifications
You must be signed in to change notification settings - Fork 2
/
schema.graphql
990 lines (901 loc) · 33.6 KB
/
schema.graphql
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
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
# this supports both ERC20 and ERC721 tokens, as union types aren't currently supported
type Token @entity {
# token address
id: Bytes!
# token symbol
symbol: String!
# token name
name: String!
# token decimals
decimals: Int
# indicates whether the token is ERC20 or ERC721
tokenType: String! # ERC20 or ERC721
# number of pools including this token
poolCount: BigInt!
# list of pools including this token
pools: [Pool!]!
# total supply of the token
totalSupply: BigInt
# transactions across all pools that include this token
txCount: BigInt!
}
# # # # # # # # #
# Pool ENTITIES #
# # # # # # # # #
type PoolFactory @entity {
# factory address
id: Bytes!
# indicates type of collateral (ERC20 or ERC721)
poolType: String!
# number of pools deployed by the factory
poolCount: BigInt!
# list of pools deployed by the factory
pools: [Pool!]!
# total number of transactions sent to the factory
txCount: BigInt!
}
type Pool @entity {
# pool address
id: Bytes!
# block pool was created at
createdAtBlockNumber: BigInt!
# creation timestamp
createdAtTimestamp: BigInt!
# address of the pool's collateral token
collateralToken: Token!
# address of the pool's quote token
quoteToken: Token!
# amount of deposit in the pool
poolSize: BigDecimal!
# debt in T0 terms, useful when the caller knows the pending inflator
t0debt: BigDecimal!
# pool inflator snapshot
inflator: BigDecimal!
# interest rate paid by borrowers, excluding fees
borrowRate: BigDecimal!
# interest rate awarded to lenders, excluding fees
lendRate: BigDecimal!
# origination fee paid by borrower on newly drawn debt
borrowFeeRate: BigDecimal!
# fee charged to lenders depositing below the highest threshold price
depositFeeRate: BigDecimal!
# total collateral pledged to the pool
pledgedCollateral: BigDecimal!
# total interest earned by all lenders in the pool
totalInterestEarned: BigDecimal!
# total number of transactions sent to the pool
txCount: BigInt!
# type of pool: "Fungible", Collection", "Subset"
poolType: String!
# LOANS INFORMATION
loansCount: BigInt! # total number of loans in the pool
maxBorrower: Bytes! # address of the borrower with the highest TP in the pool
# normalized total amount of tokens flashloaned from the pool
quoteTokenFlashloaned: BigDecimal!
collateralFlashloaned: BigDecimal!
# PRICES INFORMATION
hpb: BigDecimal! # current highest price bucket
hpbIndex: Int! # current highest price bucket index
htp: BigDecimal! # current highest threshold price
htpIndex: Int! # current highest threshold price index
lup: BigDecimal! # current lowest utilized price
lupIndex: Int! # current lowest utilized price index
# RESERVES INFORMATION
# current reserves contractQuoteBalance + poolDebt - pool.depositSize()
reserves: BigDecimal!
# current pool claimable reserves
claimableReserves: BigDecimal!
# remaining claimable reserves not yet taken
claimableReservesRemaining: BigDecimal!
# current burn epoch
burnEpoch: BigInt!
# total ajna burned in the pool
totalAjnaBurned: BigDecimal!
# list of all reserve auctions for this pool
reserveAuctions: [ReserveAuction!]!
# UTILIZATION INFORMATION
# current pool minimum debt amount for a new borrow
minDebtAmount: BigDecimal!
# current pool utilization across all borrowers
actualUtilization: BigDecimal!
# current pool target utilization rate
targetUtilization: BigDecimal!
# LIQUIDATION INFORMATION
# liquidation bond currently escrowed in the pool
totalBondEscrowed: BigDecimal!
# list of active liquidation auctions in the pool, sorted by kick time
liquidationAuctions: [LiquidationAuction!]!
# normalized contract balances, used for TVL
quoteTokenBalance: BigDecimal!
collateralBalance: BigDecimal!
# ERC721 POOL INFORMATION
# pool subsetHash
subsetHash: Bytes!
# list of tokenIds pledged by the borrower
tokenIdsPledged: [BigInt!]!
# list of tokenIds available to lenders
bucketTokenIds: [BigInt!]!
# list of tokenIds allowed by a subset pool
tokenIdsAllowed: [BigInt!]!
}
type Bucket @entity {
# bucket id: $poolAddress + '#' + $bucketIndex
id: Bytes!
# bucket index
bucketIndex: Int!
# bucket price
bucketPrice: BigDecimal!
# current exchange rate of the bucket
exchangeRate: BigDecimal!
# pool address
poolAddress: String!
# pool in which the bucket belongs
pool: Pool!
# total collateral available in the bucket
collateral: BigDecimal!
# total quote tokens deposited in the bucket, inclusive of interest
deposit: BigDecimal!
# total LP for all lenders in the bucket
lpb: BigDecimal!
# list of lends associated with the bucket
lends: [Lend!]!
# list of PositionLends associated with the bucket
positionLends: [PositionLend!]!
}
# lend occurs per bucket in a pool
type Lend @entity {
# Lend id: $bucketId + '|' + $accountId
id: Bytes!
# bucket to which a lend was made
bucket: Bucket!
# index of the bucket, for querying
bucketIndex: Int!
# pool address
poolAddress: String!
# address of the lender
lender: Bytes!
# pool pointer
pool: Pool!
# amount of LPB lender has in the bucket
lpb: BigDecimal!
# quote equivalent value of the lend's LPB in the bucket (regardless of available deposit in bucket)
lpbValueInQuote: BigDecimal!
# time at which the lend was made
depositTime: BigInt!
}
# each borrower has only one loan with a pool
type Loan @entity {
# Loan id: $poolAddress + '|' + $borrowerId
id: Bytes!
# pool address
poolAddress: String!
# borrower address
borrower: Bytes!
# pool pointer
pool: Pool!
# boolean indicating whether the loan is in liquidations
inLiquidation: Boolean!
# most recent liquidation, whether active or inactive
liquidationAuction: LiquidationAuction
# collateral tokens deposited in a pool by the borrower
collateralPledged: BigDecimal!
# borrower's threshold price
thresholdPrice: BigDecimal!
# list of tokenIds pledged by the borrower
tokenIdsPledged: [BigInt!]!
# debt in T0 terms, useful when the caller knows the pending inflator
t0debt: BigDecimal!
# borrowers t0 neutral price
t0Np: BigDecimal!
}
type Account @entity {
# address of the account
id: Bytes!
# list of pools in which an account is present
pools: [Pool!]!
# kicks executed by the account
kicks: [Kick!]!
# buckets in a pool to which the account has lent quote
lends: [Lend!]!
# loans which the account has taken from pools
loans: [Loan!]!
# liquidation auctions settled
settles: [Settle!]!
# liquidation auctions taken
takes: [Take!]!
# reserve auctions which the account has interacted in
reserveAuctions: [ReserveAuction!]!
# ecosystem coordination proposals created
proposalsCreated: [Proposal!]!
# ecosystem coordination proposals passed and funded
proposalsExecuted: [Proposal!]!
# account to which this account is delegating votes
delegatedTo: Account
# accounts from which votes are delegated
delegatedFrom: [Account!]!
# delegation rewards claimed across all distribution periods
rewardsClaimed: BigDecimal!
# voting state for each distribution period
distributionPeriodVotes: [DistributionPeriodVote!]!
# amount of tokens delegated to this account
tokensDelegated: BigDecimal!
# positions associated with the account
positions: [Position!]!
# total number of transactions sent by the account
txCount: BigInt!
}
type LiquidationAuction @entity {
id: Bytes! # $poolAddress + '|' + $loanId + '|' + blockNumber
pool: Pool! # pool in which the liquidation occurred
borrower: Bytes! # address of the borrower being liquidated
lastTakePrice: BigDecimal! # price of auction upon most recent take
collateral: BigDecimal! # initial collateral up for auction
collateralRemaining: BigDecimal! # collateral which has not been taken
debt: BigDecimal! # initial debt to be covered by the auction
debtRemaining: BigDecimal! # debt which has not been covered
loan: Loan! # loan being liquidated
kicker: Bytes! # address of the kicker
kick: Kick! # kick which triggered the liquidation
kickTime: BigInt! # block timestamp at which the kick was executed
takes: [Take!]! # list of takes which occured using outside liquidity
bucketTakes: [BucketTake!]! # list of takes which involved the pool's book
settles: [Settle!]! # list of possibly-intermediate settles performed on the auction
settle: AuctionSettle # final settlement of the auction
settleTime: BigInt # block timestamp at which the liquidation was settled
settled: Boolean! # boolean indicating whether the auction has been settled
bondSize: BigDecimal! # bond provided by kicker to initate auction
bondFactor: BigDecimal! # bond factor determining the reward or penalty for the kicker
neutralPrice: BigDecimal! # price at which kicker will have their bond returned without penalty or reward
referencePrice: BigDecimal! # max(HTP, NP) used in auction price curve
thresholdPrice: BigDecimal! # Threshold price stamped on the liquidation at time of kick
}
# tracks the reserve auction process across multiple takes in a single auction
# used as start and take events are emitted as ReserveAuction
type ReserveAuction @entity {
id: Bytes! # $poolAddress + '|' + $burnEpoch
pool: Pool! # Pool in which the reserve auction occurred
claimableReservesRemaining: BigDecimal! # uint256 claimable reserves remaining at start or at latest take
lastTakePrice: BigDecimal! # uint256 price of auction upon most recent take, denominated in AJNA
burnEpoch: BigInt! # uint256 burn epoch at which the reserve auction was started
kick: ReserveAuctionKick! # kick information
takes: [ReserveAuctionTake!]! # list of reserve auction takes that occured during this auction process
ajnaBurned: BigDecimal! # total amount of ajna burned across all takes in the reserve auction
}
# LP transferors approved by a lender for a pool, updated upon Approve/RevokeLpTransferors
type LPTransferorList @entity {
id: Bytes! # $poolAddress + '|' + $lender
pool: Pool! # pool in which these transferors have been approved
lender: Bytes! # address of the lender who has approved transferors
transferors: [Bytes!]! # addresses of approved transferors
}
# represents a LP allowance for a single bucket
type LPAllowance @entity {
id: Bytes! # LPAllowanceList.id + '|' + $index
index: Int! # bucket index where an allowance has been granted
amount: BigDecimal! # size of the allowance (measured in LP)
}
# updated upon Increase/Decrease/RevokeLPAllowance
type LPAllowanceList @entity {
id: Bytes! # $poolAddress + '|' + $lender + '|' + $spender
pool: Pool! # pool in which LP allowances have been granted
lender: Bytes! # address of the lender who has granted an allowance
spender: Bytes! # address who has been granted an allowance
allowances: [LPAllowance!]! # list of LP allowances
}
# # # # # # # # # # #
# ERC20 Pool Events #
# # # # # # # # # # #
type AddCollateral @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool to which collateral was added
bucket: Bucket! # Bucket to which collateral was added
actor: Bytes! # address
index: Int! # uint256
amount: BigDecimal! # uint256
lpAwarded: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type AddQuoteToken @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool to which quote was added
bucket: Bucket! # Bucket to which quote was added
lender: Bytes! # address
index: Int! # uint256
amount: BigDecimal! # uint256
lpAwarded: BigDecimal! # uint256
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# emitted when auction has been removed from the liquidation queue
type AuctionSettle @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool whose debt was settled
loan: Loan! # Loan which was settled
borrower: Bytes! # address
collateral: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type BondWithdrawn @entity(immutable: true) {
id: Bytes!
kicker: Bytes! # address
reciever: Bytes! # address
amount: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type BucketBankruptcy @entity(immutable: true) {
id: Bytes!
bucket: Bucket! # Bucket which was bankrupted
index: Int! # uint256
pool: Pool! # Pool whose bucket was bankrupted
lpForfeited: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type BucketTake @entity(immutable: true) {
id: Bytes!
borrower: Bytes! # address
taker: Bytes! # address of the taker
liquidationAuction: LiquidationAuction! # liquidation auction in which the take is occuring
loan: Loan! # loan which was taken
pool: Pool! # pool in which the take is occuring
index: Int! # uint256
auctionPrice: BigDecimal! # price of auction when taken
amount: BigDecimal! # uint256
collateral: BigDecimal! # uint256
bondChange: BigDecimal! # uint256
isReward: Boolean! # bool
lpAwarded: BucketTakeLPAwarded!
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type BucketTakeLPAwarded @entity(immutable: true) {
id: Bytes!
taker: Bytes! # address
pool: Pool! # Pool in which the take occurred
kicker: Bytes! # address
lpAwardedTaker: BigDecimal! # uint256
lpAwardedKicker: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type DrawDebt @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool debt was drawn from
borrower: Bytes! # address
amountBorrowed: BigDecimal! # uint256
collateralPledged: BigDecimal! # uint256
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type Flashloan @entity(immutable: true) {
id: Bytes!
pool: Pool!
borrower: Bytes! # address
amount: BigDecimal! # uint256
}
type Kick @entity {
id: Bytes!
kicker: Bytes! # address of the kicker
pool: Pool! # Pool in which a kick occurred
loan: Loan! # Loan which was kicked
locked: BigDecimal! # amount of quote from the bond locked in the kick (updated on take) TODO: rename bondLocked
claimable: BigDecimal! # amount of quote from the bond claimable by the kicker (updated on settle) TODO: rename bondClaimable?
liquidationAuction: LiquidationAuction! # Liquidation auction which was initiated
borrower: Bytes! # address of the borrower being liquidated
debt: BigDecimal! # amount of debt to be covered
collateral: BigDecimal! # amount of collateral available to liquidate
bond: BigDecimal! # liquidation bond paid by kicker
startingPrice: BigDecimal! # initial price of auction
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type LoanStamped @entity(immutable: true) {
id: Bytes!
pool: Pool!
borrower: Bytes! # address
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type MoveQuoteToken @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool in which quote tokens were moved
lender: Bytes! # address
from: Bucket! # bucket quote token was moved from
to: Bucket! # bucket quote token was moved to
amount: BigDecimal! # uint256
lpRedeemedFrom: BigDecimal! # uint256
lpAwardedTo: BigDecimal! # uint256
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type RemoveCollateral @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool where collateral was removed
bucket: Bucket! # Bucket where collateral was removed
claimer: Bytes! # address
index: Int! # uint256
amount: BigDecimal! # uint256
lpRedeemed: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type RemoveQuoteToken @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool where deposit was removed
bucket: Bucket! # Bucket where deposit was removed
lender: Bytes! # address
index: Int! # uint256
amount: BigDecimal! # uint256
lpRedeemed: BigDecimal! # uint256
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type RepayDebt @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool debt was repaid to
borrower: Bytes! # address
quoteRepaid: BigDecimal! # uint256
collateralPulled: BigDecimal! # uint256
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# starts a claimable reserve auction
type ReserveAuctionKick @entity(immutable: true) {
id: Bytes! # transaction.hash + transaction.from
kicker: Bytes # address of the taker, null if emitted as start of event
reserveAuction: ReserveAuction! # reserve auction in which the take is occuring
pool: Pool! # pool in which the auction was kicked
claimableReserves: BigDecimal! # uint256 initial amount of claimable reserves in the auction
startingPrice: BigDecimal! # uint256 initial auction price
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# indicates AJNA was burned in a claimable reserve auction
type ReserveAuctionTake @entity(immutable: true) {
id: Bytes! # transaction.hash + transaction.from
taker: Bytes # address of the taker, null if emitted as start of event
reserveAuction: ReserveAuction! # reserve auction in which the take is occuring
pool: Pool! # pool in which the take is occuring
claimableReservesRemaining: BigDecimal! # uint256 remaining amount of claimable reserves in the auction
auctionPrice: BigDecimal! # uint256 cost of purchasing one quote token, denominated in AJNA
quotePurchased: BigDecimal! # amount of quote token purchased by taker in this take
ajnaBurned: BigDecimal! # amount of AJNA burned by taker in this take
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# indicates rate was reset on an underutilized pool with high interest rate
type ResetInterestRate @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool whose interest rate was reset
oldBorrowRate: BigDecimal! # uint256
newBorrowRate: BigDecimal! # uint256
oldLendRate: BigDecimal! # uint256
newLendRate: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# emitted for each settle TX; one to many required before auction is settled
type Settle @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool whose debt was settled
liquidationAuction: LiquidationAuction! # Liquidation auction which was settled
loan: Loan! # Loan which was settled
borrower: Bytes! # address
settledDebt: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type Take @entity(immutable: true) {
id: Bytes!
taker: Bytes! # address of the taker
pool: Pool! # Pool in which the take occurred
borrower: Bytes! # address of the borrower being liquidated
liquidationAuction: LiquidationAuction! # Liquidation auction which was taken
loan: Loan! # Loan which was taken
auctionPrice: BigDecimal! # price of auction when taken
amount: BigDecimal! # uint256
collateral: BigDecimal! # uint256
bondChange: BigDecimal! # uint256
isReward: Boolean! # bool
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type TransferLP @entity(immutable: true) {
id: Bytes!
owner: Bytes! # address
newOwner: Bytes! # address
indexes: [Int!]! # uint256[]
lp: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type UpdateInterestRate @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool whose interest rate was updated
# interest rates
oldBorrowRate: BigDecimal! # uint256
newBorrowRate: BigDecimal! # uint256
oldLendRate: BigDecimal! # uint256
newLendRate: BigDecimal! # uint256
# fees
borrowFeeRate: BigDecimal! # uint256
depositFeeRate: BigDecimal! # uint256
# event
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type Approval @entity(immutable: true) {
id: Bytes!
owner: Bytes! # address
approved: Bytes! # address
tokenId: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type ApprovalForAll @entity(immutable: true) {
id: Bytes!
owner: Bytes! # address
operator: Bytes! # address
approved: Boolean! # bool
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type MoveLiquidity @entity(immutable: true) {
id: Bytes!
lender: Bytes! # address
tokenId: BigInt! # uint256
pool: Pool!
fromIndex: Int! # uint256
toIndex: Int! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# PositionManager ERC-721 transfer event
type Transfer @entity(immutable: true) {
id: Bytes!
token: Token! # token which was transferred
pool: Pool!
from: Bytes! # address
to: Bytes! # address
tokenId: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type PoolCreated @entity(immutable: true) {
id: Bytes!
pool: Pool! # pool which was created
poolType: String! # ERC20 or ERC721
factory: PoolFactory! # address of factory contract used to create pool
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# # # # # # # # # # #
# ERC721 POOL EVENTS #
# # # # # # # # # # #
type AddCollateralNFT @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool to which collateral was added
bucket: Bucket! # Bucket to which collateral was added
actor: Bytes! # address
index: BigInt! # bucket index to which collateral was added
tokenIds: [BigInt!]! # uint256[] list of tokenIds added as collateral
lpAwarded: BigDecimal! # lp awarded for adding collateral
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type AuctionNFTSettle @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool whose debt was settled
loan: Loan! # Loan which was settled
borrower: Bytes! # address
collateral: BigDecimal! # uint256
lp: BigDecimal! # uint256
index: Int! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type DrawDebtNFT @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool from which quote was withdrawn
borrower: Bytes! # address
amountBorrowed: BigDecimal! # uint256
tokenIdsPledged: [BigInt!]! # uint256[]
lup: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type MergeOrRemoveCollateralNFT @entity(immutable: true) {
id: Bytes!
pool: Pool! # Pool in which NFT collateral was merged or removed
actor: Bytes! # address
collateralMerged: BigDecimal! # uint256
toIndexLps: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# # # # # # # # # # # # # # #
# POSITION MANAGER ENTITIES #
# # # # # # # # # # # # # # #
type Position @entity {
id: Bytes! # byte encoded tokenId
tokenId: BigInt # tokenId
indexes: [PositionLend!]! # list of PositionLends which constitute a position
owner: Bytes! # address of the position owner
pool: Pool! # pool that the position is associated with
token: Token! # pointer to LPToken entity
tokenURI: String! # tokenURI of the positionNFT
}
# created to handle the seperate lpb positions for each bucket index
type PositionLend @entity {
id: Bytes! # $positionId + '|' + $bucketIndex
bucket: Bucket! # pointer to associated Bucket entity
bucketIndex: Int! # index of the bucket with lpb
depositTime: BigInt! # time at which the position was deposited
lpb: BigDecimal! # amount of LPB position has in the bucket
lpbValueInQuote: BigDecimal! # quote equivalent value of LPB in the bucket
tokenId: BigInt! # tokenId of the position
}
# # # # # # # # # # # # # #
# POSITION MANAGER EVENTS #
# # # # # # # # # # # # # #
type Burn @entity(immutable: true) {
id: Bytes!
lender: Bytes! # address
tokenId: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type MemorializePosition @entity(immutable: true) {
id: Bytes!
pool: Pool!
lender: Bytes! # address
tokenId: BigInt! # uint256
indexes: [Int!]! # uint256[]
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type Mint @entity(immutable: true) {
id: Bytes!
lender: Bytes! # address
pool: Pool!
tokenId: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type RedeemPosition @entity(immutable: true) {
id: Bytes!
pool: Pool!
lender: Bytes! # address
tokenId: BigInt! # uint256
indexes: [Int!]! # uint256[]
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# # # # # # # # # # # #
# GRANT FUND ENTITIES #
# # # # # # # # # # # #
type GrantFund @entity {
id: Bytes! # address of the grant fund
treasury: BigDecimal! # Total ajna tokens in the grant fund treasure
distributionPeriods: [DistributionPeriod!]! # List of distribution periods
totalDelegationRewardsClaimed: BigDecimal! # Total delegation rewards claimed across all distribution periods
}
type DistributionPeriod @entity {
id: Bytes! # distribution period id converted to Bytes from uint
distributionId: BigInt! # identifies the distribution period
startBlock: BigInt! # block number the distribution period starts
endBlock: BigInt! # block number the distribution period ends
topSlate: FundedSlate # The current top FundedSlate
slatesSubmitted: [FundedSlate!]! # FundedSlate[] slates submitted in the distribution period
fundsAvailable: BigDecimal! # Total ajna tokens available for distribution in the distribution period
delegationRewardsClaimed: BigDecimal! # Total delegation rewards claimed in the distribution period
fundingVotePowerUsed: BigDecimal! # Total funding vote power used
screeningVotesCast: BigDecimal! # number of screening votes cast
votes: [DistributionPeriodVote!]! # Voter info for the distribution period
proposals: [Proposal!]! # List of proposals submitted in the distribution period
totalTokensDistributed: BigDecimal! # Total ajna tokens distributed to executed proposals in a distribution period
}
type Proposal @entity {
id: Bytes! # proposal id converted to Bytes from uint
proposalId: BigInt! # proposal id stored in original uint format
description: String! # proposal description hashed as part of proposalId
distribution: DistributionPeriod # distributionPeriod in which the proposal was submitted if Standard, null otherwise
executed: Boolean! # bool
screeningVotesReceived: BigDecimal! # uint256
fundingVotesReceived: BigDecimal! # uint256
fundingVotesNegative: BigDecimal! # uint256
fundingVotesPositive: BigDecimal! # uint256
totalTokensRequested: BigDecimal! # uint256
params: [ProposalParams!]! # ProposalParams
}
type ProposalParams @entity {
id: Bytes! # $proposalId + '|' + $paramIndex
target: Bytes! # address
value: BigInt! # uint256
calldata: Bytes! # bytes
recipient: Bytes! # address
tokensRequested: BigDecimal! # uint256
}
type DistributionPeriodVote @entity {
id: Bytes! # $accountId + '|'' + $distributionId
voter: Account! # the account of the voter whose vote state in this distribution is being tracked
distribution: DistributionPeriod! # the distribution period associated with this entity
initialFundingStageVotingPowerRecordedPostVote: BigDecimal! # Voters initial funding stage voting power. Only recorded if the voter cast a screeningVote in this distribution period.
remainingFundingStageVotingPowerRecordedPostVote: BigDecimal! # Voters remaining funding stage voting power.
initialScreeningStageVotingPowerRecordedPostVote: BigDecimal! # Voters initial screening stage voting power. Only recorded if the voter cast a screeningVote in this distribution period.
remainingScreeningStageVotingPowerRecordedPostVote: BigDecimal! # Voters remaining screening stage voting power.
screeningVotes: [ScreeningVote!]! # ScreeningVote[] Array of ScreeningVotes cast.
fundingVotes: [FundingVote!]! # FundingVote[] Array of FundingVotes cast.
}
# 1-1 with Proposal. Multiple screeningVotes on the same proposal write to a single entity
type ScreeningVote @entity {
id: Bytes! # $proposalId + 'screening' + $account.id + $distributionId
distribution: DistributionPeriod! # distribution period the vote was cast in
voter: Account! # actor who cast votes
proposal: Proposal! # proposal being voted on
totalVotesCast: BigDecimal! # total screening votes cast by a single voter on a proposal
votesCast: [VoteCast!]! # array of voteCast entities created for each screeningVote on this proposal
}
# 1-1 with Proposal. Multiple fundingVotes on the same proposal write to a single entity
type FundingVote @entity {
id: Bytes! # $proposalId + 'funding' + $account.id + $distributionId
distribution: DistributionPeriod! # distribution period the vote was cast in
voter: Account! # actor who cast votes
proposal: Proposal! # proposal being voted on
totalVotesCast: BigDecimal! # uint256 total unsquared votes cast on the proposal
votingPowerUsed: BigDecimal! # uint256 # cost of the incremental funding vote to the voter's voting power
votesCast: [VoteCast!]! # array of voteCast entities created for each fundingVote on this proposal
}
type FundedSlate @entity {
id: Bytes! # bytes32 hash of slate proposalIds
distribution: DistributionPeriod! # distribution period the vote was cast in
proposals: [Proposal!]! # uint256[] list of proposalIds
totalTokensRequested: BigDecimal! # total number of tokens requested by all proposals in the slate
totalFundingVotesReceived: BigDecimal! # net funding votes received by all proposals in the slate
updateBlock: BigInt! # block number the slate was updated
}
# # # # # # # # # # #
# GRANT FUND EVENTS #
# # # # # # # # # # #
type DelegateRewardClaimed @entity(immutable: true) {
id: Bytes!
delegateeAddress_: Bytes! # address
distribution: DistributionPeriod! # distribution period the rewards were claimed in
rewardClaimed_: BigInt! # uint256 TODO: remove trailing underscore
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type FundTreasury @entity(immutable: true) {
id: Bytes!
amount: BigInt! # uint256
treasuryBalance: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type FundedSlateUpdated @entity(immutable: true) {
id: Bytes!
distributionId_: BigInt! # uint256
fundedSlateHash_: Bytes! # bytes32
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type ProposalCreated @entity(immutable: true) {
id: Bytes!
proposal: Proposal!
proposer: Bytes! # address
targets: [Bytes!]! # address[]
values: [BigDecimal!]! # uint256[]
signatures: [String!]! # string[]
calldatas: [Bytes!]! # bytes[]
startBlock: BigInt! # uint256
endBlock: BigInt! # uint256
description: String! # string
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type ProposalExecuted @entity(immutable: true) {
id: Bytes!
proposalId: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type DistributionPeriodStarted @entity(immutable: true) {
id: Bytes!
distribution: DistributionPeriod! # The newly started distribution period
startBlock: BigInt! # uint256
endBlock: BigInt! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type VoteCast @entity(immutable: true) {
id: Bytes!
voter: Bytes! # address # TODO: should be Account
proposalId: BigInt! # uint256
support: Int! # uint8
weight: BigDecimal! # uint256
reason: String! # string
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# # # # # # # # # # #
# AJNA TOKEN EVENTS #
# # # # # # # # # # #
type DelegateChanged @entity(immutable: true) {
id: Bytes!
delegator: Bytes! # address
fromDelegate: Bytes! # address
toDelegate: Bytes! # address
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
type DelegateVotesChanged @entity(immutable: true) {
id: Bytes!
delegate: Bytes! # address
previousBalance: BigDecimal! # uint256
newBalance: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}
# # # # # # # # # # # #
# BURN WRAPPER EVENTS #
# # # # # # # # # # # #
type BurnWrap @entity(immutable: true) {
id: Bytes!
wrapper: Bytes! # address
account: Account # null if does not already exist
amount: BigDecimal! # uint256
blockNumber: BigInt!
blockTimestamp: BigInt!
transactionHash: Bytes!
}