-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathservice.go
153 lines (136 loc) · 4.3 KB
/
service.go
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
// Copyright © 2024 Attestant Limited.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package client
import (
"context"
"github.com/attestantio/go-starknet-client/api"
"github.com/attestantio/go-starknet-client/spec"
"github.com/attestantio/go-starknet-client/types"
)
// Service is the service providing a connection to a Starknet node.
type Service interface {
// Name returns the name of the node implementation.
Name() string
// Address returns the address of the node.
Address() string
}
// BlockHashAndNumberProvider is the interface for providing block hashes and numbers.
type BlockHashAndNumberProvider interface {
// BlockHashAndNumber returns the hash and number of the latest block as understood by the node.
BlockHashAndNumber(ctx context.Context,
opts *api.BlockHashAndNumberOpts,
) (
*api.Response[*api.BlockHashAndNumber],
error,
)
}
// BlockNumberProvider is the interface for providing block numbers.
type BlockNumberProvider interface {
// BlockNumber returns the number of the latest block as understood by the node.
BlockNumber(ctx context.Context,
opts *api.BlockNumberOpts,
) (
*api.Response[uint32],
error,
)
}
// BlockProvider is the interface for providing blocks.
type BlockProvider interface {
// Block returns the block as per the given parameters.
Block(ctx context.Context,
opts *api.BlockOpts,
) (
*api.Response[*spec.Block],
error,
)
}
// CallProvider is the interface for making calls to the client.
type CallProvider interface {
// Call makes a call to the client.
Call(ctx context.Context,
opts *api.CallOpts,
) (
*api.Response[[]types.FieldElement],
error,
)
}
// ChainIDProvider is the interface for providing the chain ID.
type ChainIDProvider interface {
// ChainID returns the chain ID.
ChainID(ctx context.Context, opts *api.ChainIDOpts) (*api.Response[types.Data], error)
}
// EstimateFeeProvider is the interface for estimating transaction fees.
type EstimateFeeProvider interface {
// EstimateFee estimates the fee for a transaction.
EstimateFee(ctx context.Context,
opts *api.EstimateFeeOpts,
) (
*api.Response[[]api.FeeEstimate],
error,
)
}
// EventsProvider is the interface for providing events.
type EventsProvider interface {
// Events returns the events matching the filter.
Events(ctx context.Context, opts *api.EventsOpts) (*api.Response[[]*spec.TransactionEvent], error)
}
// NonceProvider is the interface for providing contract nonces.
type NonceProvider interface {
// Nonce returns the nonce of the given contract at the given block.
Nonce(ctx context.Context,
opts *api.NonceOpts,
) (
*api.Response[uint32],
error,
)
}
// ProtocolVersionProvider is the interface for providing the protocol version of the node.
type ProtocolVersionProvider interface {
// ProtocolVersion returns the protocol version of the node.
ProtocolVersion(ctx context.Context,
opts *api.ProtocolVersionOpts,
) (
*api.Response[uint32],
error,
)
}
// SpecVersionProvider is the interface for providing specifiation version information.
type SpecVersionProvider interface {
// SpecVersion returns the version of the specification followed by the node.
SpecVersion(ctx context.Context,
opts *api.SpecVersionOpts,
) (
*api.Response[string],
error,
)
}
// SyncingProvider is the interface for providing syncing information.
type SyncingProvider interface {
// Syncing obtains information about the sync state of the node.
Syncing(ctx context.Context,
opts *api.SyncingOpts,
) (
*api.Response[*api.SyncState],
error,
)
}
// TransactionSubmitter is the interface for submitting transactions to the client.
type TransactionSubmitter interface {
// SubmitTransaction submits a transaction to the client.
SubmitTransaction(ctx context.Context,
opts *api.SubmitTransactionOpts,
) (
*api.Response[*api.SubmitTransactionResponse],
error,
)
}