Merge pull request #4250 from filecoin-project/asr/vesting-params-api
Add some new endpoints for querying Msig info
This commit is contained in:
commit
b14632b750
@ -418,6 +418,9 @@ type FullNode interface {
|
|||||||
|
|
||||||
// MsigGetAvailableBalance returns the portion of a multisig's balance that can be withdrawn or spent
|
// MsigGetAvailableBalance returns the portion of a multisig's balance that can be withdrawn or spent
|
||||||
MsigGetAvailableBalance(context.Context, address.Address, types.TipSetKey) (types.BigInt, error)
|
MsigGetAvailableBalance(context.Context, address.Address, types.TipSetKey) (types.BigInt, error)
|
||||||
|
// MsigGetLockedBalance returns the locked balance of an msig at a vien epoch.
|
||||||
|
// The return may be greater than the multisig actor's actual balance.
|
||||||
|
MsigGetVestingSchedule(context.Context, address.Address, types.TipSetKey) (MsigVesting, error)
|
||||||
// MsigGetVested returns the amount of FIL that vested in a multisig in a certain period.
|
// MsigGetVested returns the amount of FIL that vested in a multisig in a certain period.
|
||||||
// It takes the following params: <multisig address>, <start epoch>, <end epoch>
|
// It takes the following params: <multisig address>, <start epoch>, <end epoch>
|
||||||
MsigGetVested(context.Context, address.Address, types.TipSetKey, types.TipSetKey) (types.BigInt, error)
|
MsigGetVested(context.Context, address.Address, types.TipSetKey, types.TipSetKey) (types.BigInt, error)
|
||||||
@ -871,3 +874,15 @@ type Fault struct {
|
|||||||
Miner address.Address
|
Miner address.Address
|
||||||
Epoch abi.ChainEpoch
|
Epoch abi.ChainEpoch
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var EmptyVesting = MsigVesting{
|
||||||
|
InitialBalance: types.EmptyInt,
|
||||||
|
StartEpoch: -1,
|
||||||
|
UnlockDuration: -1,
|
||||||
|
}
|
||||||
|
|
||||||
|
type MsigVesting struct {
|
||||||
|
InitialBalance abi.TokenAmount
|
||||||
|
StartEpoch abi.ChainEpoch
|
||||||
|
UnlockDuration abi.ChainEpoch
|
||||||
|
}
|
||||||
|
@ -212,6 +212,7 @@ type FullNodeStruct struct {
|
|||||||
StateNetworkVersion func(context.Context, types.TipSetKey) (stnetwork.Version, error) `perm:"read"`
|
StateNetworkVersion func(context.Context, types.TipSetKey) (stnetwork.Version, error) `perm:"read"`
|
||||||
|
|
||||||
MsigGetAvailableBalance func(context.Context, address.Address, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
MsigGetAvailableBalance func(context.Context, address.Address, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
||||||
|
MsigGetVestingSchedule func(context.Context, address.Address, types.TipSetKey) (api.MsigVesting, error) `perm:"read"`
|
||||||
MsigGetVested func(context.Context, address.Address, types.TipSetKey, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
MsigGetVested func(context.Context, address.Address, types.TipSetKey, types.TipSetKey) (types.BigInt, error) `perm:"read"`
|
||||||
MsigCreate func(context.Context, uint64, []address.Address, abi.ChainEpoch, types.BigInt, address.Address, types.BigInt) (cid.Cid, error) `perm:"sign"`
|
MsigCreate func(context.Context, uint64, []address.Address, abi.ChainEpoch, types.BigInt, address.Address, types.BigInt) (cid.Cid, error) `perm:"sign"`
|
||||||
MsigPropose func(context.Context, address.Address, address.Address, types.BigInt, address.Address, uint64, []byte) (cid.Cid, error) `perm:"sign"`
|
MsigPropose func(context.Context, address.Address, address.Address, types.BigInt, address.Address, uint64, []byte) (cid.Cid, error) `perm:"sign"`
|
||||||
@ -933,6 +934,10 @@ func (c *FullNodeStruct) MsigGetAvailableBalance(ctx context.Context, a address.
|
|||||||
return c.Internal.MsigGetAvailableBalance(ctx, a, tsk)
|
return c.Internal.MsigGetAvailableBalance(ctx, a, tsk)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *FullNodeStruct) MsigGetVestingSchedule(ctx context.Context, a address.Address, tsk types.TipSetKey) (api.MsigVesting, error) {
|
||||||
|
return c.Internal.MsigGetVestingSchedule(ctx, a, tsk)
|
||||||
|
}
|
||||||
|
|
||||||
func (c *FullNodeStruct) MsigGetVested(ctx context.Context, a address.Address, sTsk types.TipSetKey, eTsk types.TipSetKey) (types.BigInt, error) {
|
func (c *FullNodeStruct) MsigGetVested(ctx context.Context, a address.Address, sTsk types.TipSetKey, eTsk types.TipSetKey) (types.BigInt, error) {
|
||||||
return c.Internal.MsigGetVested(ctx, a, sTsk, eTsk)
|
return c.Internal.MsigGetVested(ctx, a, sTsk, eTsk)
|
||||||
}
|
}
|
||||||
|
@ -87,6 +87,7 @@
|
|||||||
* [MsigCreate](#MsigCreate)
|
* [MsigCreate](#MsigCreate)
|
||||||
* [MsigGetAvailableBalance](#MsigGetAvailableBalance)
|
* [MsigGetAvailableBalance](#MsigGetAvailableBalance)
|
||||||
* [MsigGetVested](#MsigGetVested)
|
* [MsigGetVested](#MsigGetVested)
|
||||||
|
* [MsigGetVestingSchedule](#MsigGetVestingSchedule)
|
||||||
* [MsigPropose](#MsigPropose)
|
* [MsigPropose](#MsigPropose)
|
||||||
* [MsigSwapApprove](#MsigSwapApprove)
|
* [MsigSwapApprove](#MsigSwapApprove)
|
||||||
* [MsigSwapCancel](#MsigSwapCancel)
|
* [MsigSwapCancel](#MsigSwapCancel)
|
||||||
@ -2143,6 +2144,37 @@ Inputs:
|
|||||||
|
|
||||||
Response: `"0"`
|
Response: `"0"`
|
||||||
|
|
||||||
|
### MsigGetVestingSchedule
|
||||||
|
MsigGetLockedBalance returns the locked balance of an msig at a vien epoch.
|
||||||
|
The return may be greater than the multisig actor's actual balance.
|
||||||
|
|
||||||
|
|
||||||
|
Perms: read
|
||||||
|
|
||||||
|
Inputs:
|
||||||
|
```json
|
||||||
|
[
|
||||||
|
"f01234",
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"/": "bafy2bzacea3wsdh6y3a36tb3skempjoxqpuyompjbmfeyf34fi3uy6uue42v4"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"/": "bafy2bzacebp3shtrn43k7g3unredz7fxn4gj533d3o43tqn2p2ipxxhrvchve"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
Response:
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"InitialBalance": "0",
|
||||||
|
"StartEpoch": 10101,
|
||||||
|
"UnlockDuration": 10101
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
### MsigPropose
|
### MsigPropose
|
||||||
MsigPropose proposes a multisig message
|
MsigPropose proposes a multisig message
|
||||||
It takes the following params: <multisig address>, <recipient address>, <value to transfer>,
|
It takes the following params: <multisig address>, <recipient address>, <value to transfer>,
|
||||||
|
@ -820,6 +820,44 @@ func (a *StateAPI) MsigGetAvailableBalance(ctx context.Context, addr address.Add
|
|||||||
return types.BigSub(act.Balance, locked), nil
|
return types.BigSub(act.Balance, locked), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (a *StateAPI) MsigGetVestingSchedule(ctx context.Context, addr address.Address, tsk types.TipSetKey) (api.MsigVesting, error) {
|
||||||
|
ts, err := a.Chain.GetTipSetFromKey(tsk)
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("loading tipset %s: %w", tsk, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
act, err := a.StateManager.LoadActor(ctx, addr, ts)
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("failed to load multisig actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
msas, err := multisig.Load(a.Chain.Store(ctx), act)
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("failed to load multisig actor state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ib, err := msas.InitialBalance()
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("failed to load multisig initial balance: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
se, err := msas.StartEpoch()
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("failed to load multisig start epoch: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ud, err := msas.UnlockDuration()
|
||||||
|
if err != nil {
|
||||||
|
return api.EmptyVesting, xerrors.Errorf("failed to load multisig unlock duration: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return api.MsigVesting{
|
||||||
|
InitialBalance: ib,
|
||||||
|
StartEpoch: se,
|
||||||
|
UnlockDuration: ud,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (a *StateAPI) MsigGetVested(ctx context.Context, addr address.Address, start types.TipSetKey, end types.TipSetKey) (types.BigInt, error) {
|
func (a *StateAPI) MsigGetVested(ctx context.Context, addr address.Address, start types.TipSetKey, end types.TipSetKey) (types.BigInt, error) {
|
||||||
startTs, err := a.Chain.GetTipSetFromKey(start)
|
startTs, err := a.Chain.GetTipSetFromKey(start)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user