Merge pull request #866 from harshavardhana/proxy-request-rebalance-storagestats
Implement a new Donut service on server sidemaster
commit
9d61b2d6db
@ -0,0 +1,67 @@ |
||||
/* |
||||
* Minio Cloud Storage, (C) 2015 Minio, Inc. |
||||
* |
||||
* 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 main |
||||
|
||||
import ( |
||||
"net/http" |
||||
"runtime" |
||||
) |
||||
|
||||
type donutRPCService struct{} |
||||
|
||||
func (s *donutRPCService) ListNodes(r *http.Request, arg *DonutArg, rep *ListNodesRep) error { |
||||
rep.Nodes = []struct { |
||||
Hostname string `json:"hostname"` |
||||
Address string `json:"address"` |
||||
ID string `json:"id"` |
||||
}{ |
||||
{ |
||||
Hostname: "localhost", |
||||
Address: "192.168.1.102:9000", |
||||
ID: "6F27CB16-493D-40FA-B035-2A2E5646066A", |
||||
}, |
||||
} |
||||
return nil |
||||
} |
||||
|
||||
// Usage bytes
|
||||
const ( |
||||
PB = 1024 * 1024 * 1024 * 1024 |
||||
TB = 1024 * 1024 * 1024 * 1024 |
||||
GB = 1024 * 1024 * 1024 |
||||
) |
||||
|
||||
func (s *donutRPCService) StorageStats(r *http.Request, arg *DonutArg, rep *StorageStatsRep) error { |
||||
rep.Buckets = []BucketStats{{"bucket1", 4 * TB}, {"bucket2", 120 * TB}, {"bucket3", 45 * TB}} |
||||
return nil |
||||
} |
||||
|
||||
func (s *donutRPCService) RebalanceStats(r *http.Request, arg *DonutArg, rep *RebalanceStatsRep) error { |
||||
rep.State = make(map[string]string) |
||||
rep.State["bucket1/obj1"] = "inProgress" |
||||
rep.State["bucket2/obj2"] = "finished" |
||||
rep.State["bucket3/obj3"] = "errored" |
||||
rep.State["bucket4/obj4"] = "unknownState" |
||||
return nil |
||||
} |
||||
|
||||
func (s *donutRPCService) Version(r *http.Request, arg *ServerArg, rep *DonutVersionRep) error { |
||||
rep.Version = "0.1.0" |
||||
rep.Architecture = runtime.GOARCH |
||||
rep.OperatingSystem = runtime.GOOS |
||||
return nil |
||||
} |
Loading…
Reference in new issue