Implement list uploads heal admin API (#3885)
parent
6509589adb
commit
051f9bb5c6
@ -0,0 +1,74 @@ |
|||||||
|
// +build ignore
|
||||||
|
|
||||||
|
package main |
||||||
|
|
||||||
|
/* |
||||||
|
* Minio Cloud Storage, (C) 2017 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. |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
import ( |
||||||
|
"fmt" |
||||||
|
"log" |
||||||
|
|
||||||
|
"github.com/minio/minio/pkg/madmin" |
||||||
|
) |
||||||
|
|
||||||
|
func main() { |
||||||
|
|
||||||
|
// Note: YOUR-ACCESSKEYID, YOUR-SECRETACCESSKEY are
|
||||||
|
// dummy values, please replace them with original values.
|
||||||
|
|
||||||
|
// API requests are secure (HTTPS) if secure=true and insecure (HTTPS) otherwise.
|
||||||
|
// New returns an Minio Admin client object.
|
||||||
|
madmClnt, err := madmin.New("your-minio.example.com:9000", "YOUR-ACCESSKEYID", "YOUR-SECRETACCESSKEY", true) |
||||||
|
if err != nil { |
||||||
|
log.Fatalln(err) |
||||||
|
} |
||||||
|
|
||||||
|
bucket := "mybucket" |
||||||
|
prefix := "myprefix" |
||||||
|
|
||||||
|
// Create a done channel to control 'ListUploadsHeal' go routine.
|
||||||
|
doneCh := make(chan struct{}) |
||||||
|
// Indicate to our routine to exit cleanly upon return.
|
||||||
|
defer close(doneCh) |
||||||
|
|
||||||
|
// Set true if recursive listing is needed.
|
||||||
|
isRecursive := true |
||||||
|
// List objects that need healing for a given bucket and
|
||||||
|
// prefix.
|
||||||
|
healUploadsCh, err := madmClnt.ListUploadsHeal(bucket, prefix, isRecursive, doneCh) |
||||||
|
if err != nil { |
||||||
|
log.Fatalln("Failed to get list of uploads to be healed: ", err) |
||||||
|
} |
||||||
|
|
||||||
|
for upload := range healUploadsCh { |
||||||
|
if upload.Err != nil { |
||||||
|
log.Println("upload listing error: ", upload.Err) |
||||||
|
} |
||||||
|
|
||||||
|
if upload.HealUploadInfo != nil { |
||||||
|
switch healInfo := *upload.HealUploadInfo; healInfo.Status { |
||||||
|
case madmin.CanHeal: |
||||||
|
fmt.Println(upload.Key, " can be healed.") |
||||||
|
case madmin.QuorumUnavailable: |
||||||
|
fmt.Println(upload.Key, " can't be healed until quorum is available.") |
||||||
|
case madmin.Corrupted: |
||||||
|
fmt.Println(upload.Key, " can't be healed, not enough information.") |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue