-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathschema.graphql
64 lines (55 loc) · 2.75 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
type User @entity {
id: ID! # ethereum account
filledOrdersMaker: [FilledOrder!] @derivedFrom(field: "maker") # TODO: there are maker taker duplicates , do we need to deal with this? probably not
filledOrdersTaker: [FilledOrder!] @derivedFrom(field: "taker")
filledOrdersFeeRecipient: [FilledOrder!] @derivedFrom(field: "feeRecipient")
cancelled: [CancelledOrder!] @derivedFrom(field: "maker")
validatorsApproved: [Bytes!] # event SignatureValidationApproval - allows me to give any other address the ability to sign for me # TODO: why are these all null?
}
# note, V2 means the field is only in the V2 contract, and the same for V1
# makerAssetFilledAmountV2 and makerTokenAddrV1 are similar, but V2 is updated to support ERC721, and that is why the change exists
# note the events that are used to fill these are named differently, so mappings need to reflect this
type FilledOrder @entity {
maker: Bytes!
feeRecipient: Bytes! # it is likely to be the relayer, but the relayer could also change their address that recievies fees
taker: Bytes!
makerFeePaid: BigInt! # I think this goes to relayer, in general
takerFeePaid: BigInt! # I think this goes to relayer, in general
id: ID! # orderHash (unqiue because of the salt)
makerAssetFilledAmount: BigInt!
takerAssetFilledAmount: BigInt!
makerAssetDataV2: Bytes # a special hash of ERC20 / ERC721 + the address. basically just the addr, and if it is ERC721 it also has the token id # TODO: change to human readable (coin & token id)
takerAssetDataV2: Bytes # a special hash of ERC20 / ERC721 + the address. basically just the addr, and if it is ERC721 it also has the token id
senderV2: Bytes # is this the relayer, or m or t, or 3rd party? figure out when query
tokensV1: Bytes
makerTokenAddrV1: Bytes
takerTokenAddrV1: Bytes
}
type CancelledOrder @entity {
maker: Bytes! # some reason this cancels on null
feeRecipient: Bytes!
id: ID! # orderHash
makerAssetDataV2: Bytes
takerAssetDataV2: Bytes
senderV2: Bytes
makerTokenAddrV1: Bytes
takerTokenAddrV1: Bytes
makerTokenAmountV1: BigInt
takerTokenAmountV1: BigInt
tokensV1: Bytes
}
# event AssetProxyRegister
## TODO: REMOVE - there is little point to tracking the two events this emits
#type ApprovedProxy @entity {
# id: ID! # id field
# assetProxyAddress: Bytes!
# caller: Bytes
# target: Bytes
#}
# THERE IS NO ID FOR THIS, it isnt needed. It will cancelOrders, and a cancel order event will be released as a result
# you could actually hash maker and sender together, and note their order epoch that is cancelled up to, if that is desirable . But I don't see the point now
#type CancelledUpToOrders {
# maker: Bytes!
# sender: Bytes!
# orderEpoch: BigInt!
#}