2020-12-26 01:16:43 +00:00
|
|
|
// Copyright (C) 2020 Storj Labs, Inc.
|
|
|
|
// See LICENSE for copying information.
|
|
|
|
|
|
|
|
syntax = "proto3";
|
|
|
|
option go_package = "storj.io/storj/private/multinodepb";
|
|
|
|
|
|
|
|
package multinode;
|
|
|
|
|
|
|
|
import "gogo.proto";
|
|
|
|
import "google/protobuf/timestamp.proto";
|
|
|
|
|
|
|
|
message RequestHeader {
|
|
|
|
bytes api_key = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
service Storage {
|
|
|
|
rpc DiskSpace(DiskSpaceRequest) returns (DiskSpaceResponse);
|
2021-06-03 12:52:28 +01:00
|
|
|
rpc Usage(StorageUsageRequest) returns (StorageUsageResponse);
|
|
|
|
rpc UsageSatellite(StorageUsageSatelliteRequest) returns (StorageUsageSatelliteResponse);
|
2020-12-26 01:16:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message DiskSpaceRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DiskSpaceResponse {
|
|
|
|
int64 allocated = 1;
|
|
|
|
int64 used_pieces = 2;
|
|
|
|
int64 used_trash = 3;
|
|
|
|
int64 free = 4;
|
|
|
|
int64 available = 5;
|
|
|
|
int64 overused = 6;
|
|
|
|
}
|
|
|
|
|
2021-06-03 12:52:28 +01:00
|
|
|
message StorageUsage {
|
|
|
|
double at_rest_total = 1;
|
|
|
|
google.protobuf.Timestamp interval_start = 2 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
}
|
|
|
|
|
|
|
|
message StorageUsageRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
google.protobuf.Timestamp from = 2 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
google.protobuf.Timestamp to = 3 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
}
|
|
|
|
|
|
|
|
message StorageUsageResponse {
|
|
|
|
repeated StorageUsage storage_usage = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message StorageUsageSatelliteRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
google.protobuf.Timestamp from = 3 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
google.protobuf.Timestamp to = 4 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
}
|
|
|
|
|
|
|
|
message StorageUsageSatelliteResponse {
|
|
|
|
repeated StorageUsage storage_usage = 1;
|
|
|
|
}
|
|
|
|
|
2020-12-26 01:16:43 +00:00
|
|
|
service Bandwidth {
|
|
|
|
rpc MonthSummary(BandwidthMonthSummaryRequest) returns (BandwidthMonthSummaryResponse);
|
|
|
|
}
|
|
|
|
|
|
|
|
message BandwidthMonthSummaryRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message BandwidthMonthSummaryResponse {
|
|
|
|
int64 used = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
service Node {
|
|
|
|
rpc Version(VersionRequest) returns (VersionResponse);
|
|
|
|
rpc LastContact(LastContactRequest) returns (LastContactResponse);
|
2021-01-05 07:59:22 +00:00
|
|
|
rpc Reputation(ReputationRequest) returns (ReputationResponse);
|
2021-01-07 23:26:31 +00:00
|
|
|
rpc TrustedSatellites(TrustedSatellitesRequest) returns (TrustedSatellitesResponse);
|
2021-06-01 08:29:46 +01:00
|
|
|
rpc Operator(OperatorRequest) returns (OperatorResponse);
|
2020-12-26 01:16:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message VersionRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message VersionResponse {
|
|
|
|
string version = 1; // must be semver formatted
|
|
|
|
}
|
|
|
|
|
|
|
|
message LastContactRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message LastContactResponse {
|
|
|
|
google.protobuf.Timestamp last_contact = 1 [(gogoproto.stdtime) = true, (gogoproto.nullable) = false];
|
|
|
|
}
|
2021-01-05 07:59:22 +00:00
|
|
|
|
|
|
|
message ReputationRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
}
|
|
|
|
|
|
|
|
message ReputationResponse {
|
|
|
|
message Online {
|
|
|
|
double score = 1;
|
|
|
|
}
|
|
|
|
message Audit {
|
|
|
|
double score = 1;
|
|
|
|
double suspension_score = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
Online online = 1;
|
|
|
|
Audit audit = 2;
|
|
|
|
}
|
2021-01-07 23:26:31 +00:00
|
|
|
|
|
|
|
message TrustedSatellitesRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message TrustedSatellitesResponse {
|
|
|
|
message NodeURL {
|
|
|
|
bytes node_id = 1 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
string address = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
repeated NodeURL trusted_satellites = 1;
|
|
|
|
}
|
2021-01-07 19:17:46 +00:00
|
|
|
|
2021-06-01 08:29:46 +01:00
|
|
|
message OperatorRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
message OperatorResponse {
|
|
|
|
string email = 1;
|
|
|
|
string wallet = 2;
|
|
|
|
repeated string wallet_features = 3;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
service Payouts {
|
|
|
|
rpc Summary(SummaryRequest) returns (SummaryResponse);
|
|
|
|
rpc SummaryPeriod(SummaryPeriodRequest) returns (SummaryPeriodResponse);
|
|
|
|
rpc SummarySatellite(SummarySatelliteRequest) returns (SummarySatelliteResponse);
|
|
|
|
rpc SummarySatellitePeriod(SummarySatellitePeriodRequest) returns (SummarySatellitePeriodResponse);
|
2021-01-07 19:17:46 +00:00
|
|
|
rpc Earned(EarnedRequest) returns (EarnedResponse);
|
2021-05-25 17:48:45 +01:00
|
|
|
rpc EarnedSatellite(EarnedSatelliteRequest) returns (EarnedSatelliteResponse);
|
2021-05-05 18:10:58 +01:00
|
|
|
rpc EstimatedPayoutSatellite(EstimatedPayoutSatelliteRequest) returns (EstimatedPayoutSatelliteResponse);
|
2021-05-25 17:48:45 +01:00
|
|
|
rpc EstimatedPayout(EstimatedPayoutRequest) returns (EstimatedPayoutResponse);
|
2021-05-14 23:03:38 +01:00
|
|
|
rpc Undistributed(UndistributedRequest) returns (UndistributedResponse);
|
2021-05-25 17:48:45 +01:00
|
|
|
rpc PaystubSatellite(PaystubSatelliteRequest) returns (PaystubSatelliteResponse);
|
2021-05-25 13:02:20 +01:00
|
|
|
rpc Paystub(PaystubRequest) returns (PaystubResponse);
|
2021-05-25 17:48:45 +01:00
|
|
|
rpc PaystubPeriod(PaystubPeriodRequest) returns (PaystubPeriodResponse);
|
|
|
|
rpc PaystubSatellitePeriod(PaystubSatellitePeriodRequest) returns (PaystubSatellitePeriodResponse);
|
2021-04-22 19:50:42 +01:00
|
|
|
rpc HeldAmountHistory(HeldAmountHistoryRequest) returns (HeldAmountHistoryResponse);
|
2021-05-05 18:10:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
message EstimatedPayoutSatelliteRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
}
|
2021-05-05 21:01:16 +01:00
|
|
|
|
2021-05-05 18:10:58 +01:00
|
|
|
message EstimatedPayoutSatelliteResponse {
|
|
|
|
int64 estimated_earnings = 1;
|
|
|
|
}
|
2021-05-05 21:01:16 +01:00
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message EstimatedPayoutRequest {
|
2021-05-05 18:10:58 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
2021-05-05 21:01:16 +01:00
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message EstimatedPayoutResponse {
|
2021-05-05 18:10:58 +01:00
|
|
|
int64 estimated_earnings = 1;
|
2021-01-07 19:17:46 +00:00
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummaryRequest {
|
2021-05-05 18:34:10 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummaryResponse {
|
2021-05-05 18:34:10 +01:00
|
|
|
PayoutInfo payout_info = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummaryPeriodRequest {
|
2021-05-05 18:34:10 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
string period = 2;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummaryPeriodResponse {
|
2021-05-05 18:34:10 +01:00
|
|
|
PayoutInfo payout_info = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummarySatelliteRequest {
|
2021-05-05 21:01:16 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummarySatelliteResponse {
|
2021-05-05 21:01:16 +01:00
|
|
|
PayoutInfo payout_info = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummarySatellitePeriodRequest {
|
2021-05-05 21:01:16 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
string period = 3;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message SummarySatellitePeriodResponse {
|
2021-05-05 21:01:16 +01:00
|
|
|
PayoutInfo payout_info = 1;
|
|
|
|
}
|
|
|
|
|
2021-01-07 19:17:46 +00:00
|
|
|
message EarnedRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message EarnedResponse {
|
|
|
|
int64 total = 1;
|
|
|
|
}
|
2021-02-04 15:44:31 +00:00
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message EarnedSatelliteRequest {
|
2021-02-04 15:44:31 +00:00
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
2021-05-05 18:34:10 +01:00
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message EarnedSatelliteResponse {
|
2021-02-04 15:44:31 +00:00
|
|
|
repeated EarnedSatellite earned_satellite = 1;
|
|
|
|
}
|
2021-05-05 18:34:10 +01:00
|
|
|
|
2021-02-04 15:44:31 +00:00
|
|
|
message EarnedSatellite {
|
|
|
|
int64 total = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
}
|
2021-05-05 18:34:10 +01:00
|
|
|
|
2021-05-14 23:03:38 +01:00
|
|
|
message UndistributedRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message UndistributedResponse {
|
|
|
|
int64 total = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubSatelliteRequest {
|
2021-05-25 13:02:20 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
}
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubSatelliteResponse {
|
2021-05-25 13:02:20 +01:00
|
|
|
Paystub paystub = 1;
|
|
|
|
}
|
|
|
|
message PaystubRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
message PaystubResponse {
|
|
|
|
Paystub paystub = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubPeriodRequest {
|
2021-05-24 21:40:31 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
string period = 2;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubPeriodResponse {
|
2021-05-24 21:40:31 +01:00
|
|
|
Paystub paystub = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubSatellitePeriodRequest {
|
2021-05-24 21:40:31 +01:00
|
|
|
RequestHeader header = 1;
|
|
|
|
bytes satellite_id = 2 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
string period = 3;
|
|
|
|
}
|
|
|
|
|
2021-05-25 17:48:45 +01:00
|
|
|
message PaystubSatellitePeriodResponse {
|
2021-05-24 21:40:31 +01:00
|
|
|
Paystub paystub = 1;
|
|
|
|
}
|
|
|
|
|
2021-05-05 18:34:10 +01:00
|
|
|
message PayoutInfo {
|
|
|
|
int64 held = 1;
|
|
|
|
int64 paid = 2;
|
|
|
|
}
|
2021-05-25 13:02:20 +01:00
|
|
|
|
|
|
|
message Paystub {
|
2021-06-01 16:02:50 +01:00
|
|
|
double usage_at_rest = 1;
|
|
|
|
int64 usage_get = 2;
|
|
|
|
int64 usage_get_repair = 3;
|
|
|
|
int64 usage_get_audit = 4;
|
|
|
|
int64 comp_at_rest = 5;
|
|
|
|
int64 comp_get = 6;
|
|
|
|
int64 comp_get_repair = 7;
|
|
|
|
int64 comp_get_audit = 8;
|
|
|
|
int64 held = 9;
|
|
|
|
int64 paid = 10;
|
|
|
|
int64 distributed = 11;
|
|
|
|
int64 disposed = 12;
|
2021-05-25 13:02:20 +01:00
|
|
|
}
|
2021-04-22 19:50:42 +01:00
|
|
|
|
|
|
|
message HeldAmountHistoryRequest {
|
|
|
|
RequestHeader header = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message HeldAmountHistoryResponse {
|
|
|
|
message HeldAmount {
|
|
|
|
string period = 1;
|
|
|
|
int64 amount = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message HeldAmountHistory {
|
|
|
|
bytes satellite_id = 1 [(gogoproto.customtype) = "NodeID", (gogoproto.nullable) = false];
|
|
|
|
repeated HeldAmount held_amounts = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
repeated HeldAmountHistory history = 1;
|
|
|
|
}
|