mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 12:14:21 +01:00
* api-spec: move the api-spec to root and init go.mod * go mod tidy * move buf files in the root as well * gh action for api-spec changes only * gh action for api-spec on push and pr * introduce go.work and remove all replaces * solve dependencies and force btcd/btcec@v2.3.3 * go work sync * force btcd/btcec@v2.3.3 * go mod tidy
107 lines
3.0 KiB
Go
107 lines
3.0 KiB
Go
package handlers
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
arkv1 "github.com/ark-network/ark/api-spec/protobuf/gen/ark/v1"
|
|
"github.com/ark-network/ark/server/internal/core/application"
|
|
"google.golang.org/grpc/codes"
|
|
"google.golang.org/grpc/status"
|
|
)
|
|
|
|
type adminHandler struct {
|
|
adminService application.AdminService
|
|
aspService application.Service
|
|
}
|
|
|
|
func NewAdminHandler(
|
|
adminService application.AdminService, aspService application.Service,
|
|
) arkv1.AdminServiceServer {
|
|
return &adminHandler{adminService, aspService}
|
|
}
|
|
|
|
func (a *adminHandler) GetRoundDetails(ctx context.Context, req *arkv1.GetRoundDetailsRequest) (*arkv1.GetRoundDetailsResponse, error) {
|
|
id := req.GetRoundId()
|
|
if len(id) == 0 {
|
|
return nil, status.Error(codes.InvalidArgument, "missing round id")
|
|
}
|
|
|
|
details, err := a.adminService.GetRoundDetails(ctx, id)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &arkv1.GetRoundDetailsResponse{
|
|
RoundId: details.RoundId,
|
|
Txid: details.TxId,
|
|
ForfeitedAmount: convertSatoshis(details.ForfeitedAmount),
|
|
TotalVtxosAmount: convertSatoshis(details.TotalVtxosAmount),
|
|
TotalExitAmount: convertSatoshis(details.TotalExitAmount),
|
|
FeesAmount: convertSatoshis(details.FeesAmount),
|
|
InputsVtxos: details.InputsVtxos,
|
|
OutputsVtxos: details.OutputsVtxos,
|
|
ExitAddresses: details.ExitAddresses,
|
|
}, nil
|
|
}
|
|
|
|
// GetRounds implements arkv1.AdminServiceServer.
|
|
func (a *adminHandler) GetRounds(ctx context.Context, req *arkv1.GetRoundsRequest) (*arkv1.GetRoundsResponse, error) {
|
|
startAfter := req.GetAfter()
|
|
startBefore := req.GetBefore()
|
|
|
|
if startAfter < 0 {
|
|
return nil, status.Error(codes.InvalidArgument, "invalid after (must be >= 0)")
|
|
}
|
|
|
|
if startBefore < 0 {
|
|
return nil, status.Error(codes.InvalidArgument, "invalid before (must be >= 0)")
|
|
}
|
|
|
|
if startAfter >= startBefore {
|
|
return nil, status.Error(codes.InvalidArgument, "invalid range")
|
|
}
|
|
|
|
rounds, err := a.adminService.GetRounds(ctx, startAfter, startBefore)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &arkv1.GetRoundsResponse{Rounds: rounds}, nil
|
|
}
|
|
|
|
func (a *adminHandler) GetScheduledSweep(ctx context.Context, _ *arkv1.GetScheduledSweepRequest) (*arkv1.GetScheduledSweepResponse, error) {
|
|
scheduledSweeps, err := a.adminService.GetScheduledSweeps(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sweeps := make([]*arkv1.ScheduledSweep, 0)
|
|
|
|
for _, sweep := range scheduledSweeps {
|
|
outputs := make([]*arkv1.SweepableOutput, 0)
|
|
|
|
for _, output := range sweep.SweepableOutputs {
|
|
outputs = append(outputs, &arkv1.SweepableOutput{
|
|
Txid: output.TxId,
|
|
Vout: output.Vout,
|
|
ScheduledAt: output.ScheduledAt,
|
|
Amount: convertSatoshis(output.Amount),
|
|
})
|
|
}
|
|
|
|
sweeps = append(sweeps, &arkv1.ScheduledSweep{
|
|
RoundId: sweep.RoundId,
|
|
Outputs: outputs,
|
|
})
|
|
}
|
|
|
|
return &arkv1.GetScheduledSweepResponse{Sweeps: sweeps}, nil
|
|
}
|
|
|
|
// convert sats to string BTC
|
|
func convertSatoshis(sats uint64) string {
|
|
btc := float64(sats) * 1e-8
|
|
return fmt.Sprintf("%.8f", btc)
|
|
}
|