mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 20:24:21 +01:00
* Rename asp > server * Rename pool > round * Consolidate naming for pubkey/prvkey vars and types * Fix * Fix * Fix wasm * Rename congestionTree > vtxoTree * Fix wasm * Rename payment > request * Rename congestionTree > vtxoTree after syncing with master * Fix Send API in SDK * Fix wasm * Fix wasm * Fixes * Fixes after review * Fix * Fix naming * Fix * Fix e2e tests
175 lines
4.9 KiB
Go
175 lines
4.9 KiB
Go
package handlers
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"google.golang.org/protobuf/types/known/durationpb"
|
|
"google.golang.org/protobuf/types/known/timestamppb"
|
|
|
|
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
|
|
arkService application.Service
|
|
|
|
noteUriPrefix string
|
|
}
|
|
|
|
func NewAdminHandler(
|
|
adminService application.AdminService, arkService application.Service, noteUriPrefix string,
|
|
) arkv1.AdminServiceServer {
|
|
return &adminHandler{adminService, arkService, noteUriPrefix}
|
|
}
|
|
|
|
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
|
|
}
|
|
|
|
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
|
|
}
|
|
|
|
func (a *adminHandler) CreateNote(ctx context.Context, req *arkv1.CreateNoteRequest) (*arkv1.CreateNoteResponse, error) {
|
|
amount := req.GetAmount()
|
|
quantity := req.GetQuantity()
|
|
if quantity == 0 {
|
|
quantity = 1
|
|
}
|
|
|
|
if amount == 0 {
|
|
return nil, status.Error(codes.InvalidArgument, "amount must be greater than 0")
|
|
}
|
|
|
|
notes, err := a.adminService.CreateNotes(ctx, amount, int(quantity))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if len(a.noteUriPrefix) > 0 {
|
|
notesWithURI := make([]string, 0, len(notes))
|
|
for _, note := range notes {
|
|
notesWithURI = append(notesWithURI, fmt.Sprintf("%s://%s", a.noteUriPrefix, note))
|
|
}
|
|
|
|
return &arkv1.CreateNoteResponse{Notes: notesWithURI}, nil
|
|
}
|
|
|
|
return &arkv1.CreateNoteResponse{Notes: notes}, nil
|
|
}
|
|
|
|
func (a *adminHandler) GetMarketHourConfig(
|
|
ctx context.Context,
|
|
request *arkv1.GetMarketHourConfigRequest,
|
|
) (*arkv1.GetMarketHourConfigResponse, error) {
|
|
config, err := a.arkService.GetMarketHourConfig(ctx)
|
|
if err != nil {
|
|
return nil, status.Error(codes.Internal, err.Error())
|
|
}
|
|
|
|
return &arkv1.GetMarketHourConfigResponse{
|
|
Config: &arkv1.MarketHourConfig{
|
|
StartTime: timestamppb.New(config.StartTime),
|
|
EndTime: timestamppb.New(config.EndTime),
|
|
Period: durationpb.New(config.Period),
|
|
RoundInterval: durationpb.New(config.RoundInterval),
|
|
},
|
|
}, nil
|
|
}
|
|
|
|
func (a *adminHandler) UpdateMarketHourConfig(
|
|
ctx context.Context,
|
|
req *arkv1.UpdateMarketHourConfigRequest,
|
|
) (*arkv1.UpdateMarketHourConfigResponse, error) {
|
|
if err := a.arkService.UpdateMarketHourConfig(
|
|
ctx,
|
|
req.GetConfig().GetStartTime().AsTime(),
|
|
req.GetConfig().GetEndTime().AsTime(),
|
|
req.GetConfig().GetPeriod().AsDuration(),
|
|
req.GetConfig().GetRoundInterval().AsDuration(),
|
|
); err != nil {
|
|
return nil, status.Error(codes.Internal, err.Error())
|
|
}
|
|
|
|
return &arkv1.UpdateMarketHourConfigResponse{}, nil
|
|
}
|
|
|
|
// convert sats to string BTC
|
|
func convertSatoshis(sats uint64) string {
|
|
btc := float64(sats) * 1e-8
|
|
return fmt.Sprintf("%.8f", btc)
|
|
}
|