mirror of
https://github.com/goharbor/harbor.git
synced 2024-11-27 12:46:03 +01:00
Merge pull request #553 from ywk253100/rep_del
Replicate repository deletion by calling API of Harbor to log the operation
This commit is contained in:
commit
22304c1012
@ -16,10 +16,17 @@
|
|||||||
package replication
|
package replication
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
|
||||||
"github.com/vmware/harbor/models"
|
"github.com/vmware/harbor/models"
|
||||||
"github.com/vmware/harbor/utils/log"
|
"github.com/vmware/harbor/utils/log"
|
||||||
"github.com/vmware/harbor/utils/registry"
|
//"github.com/vmware/harbor/utils/registry"
|
||||||
"github.com/vmware/harbor/utils/registry/auth"
|
//"github.com/vmware/harbor/utils/registry/auth"
|
||||||
|
"crypto/tls"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -27,6 +34,10 @@ const (
|
|||||||
StateDelete = "delete"
|
StateDelete = "delete"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
errNotFound = errors.New("Not Found")
|
||||||
|
)
|
||||||
|
|
||||||
// Deleter deletes repository or tags
|
// Deleter deletes repository or tags
|
||||||
type Deleter struct {
|
type Deleter struct {
|
||||||
repository string // prject_name/repo_name
|
repository string // prject_name/repo_name
|
||||||
@ -38,7 +49,7 @@ type Deleter struct {
|
|||||||
|
|
||||||
insecure bool
|
insecure bool
|
||||||
|
|
||||||
dstClient *registry.Repository
|
//dstClient *registry.Repository
|
||||||
|
|
||||||
logger *log.Logger
|
logger *log.Logger
|
||||||
}
|
}
|
||||||
@ -76,37 +87,115 @@ func (d *Deleter) Enter() (string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (d *Deleter) enter() (string, error) {
|
func (d *Deleter) enter() (string, error) {
|
||||||
dstCred := auth.NewBasicAuthCredential(d.dstUsr, d.dstPwd)
|
url := strings.TrimRight(d.dstURL, "/") + "/api/repositories/"
|
||||||
dstClient, err := newRepositoryClient(d.dstURL, d.insecure, dstCred,
|
|
||||||
d.repository, "repository", d.repository, "pull", "push", "*")
|
|
||||||
if err != nil {
|
|
||||||
d.logger.Errorf("an error occurred while creating destination repository client: %v", err)
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
d.dstClient = dstClient
|
|
||||||
|
|
||||||
|
// delete repository
|
||||||
if len(d.tags) == 0 {
|
if len(d.tags) == 0 {
|
||||||
tags, err := d.dstClient.ListTag()
|
u := url + "?repo_name=" + d.repository
|
||||||
if err != nil {
|
if err := del(u, d.dstUsr, d.dstPwd, d.insecure); err != nil {
|
||||||
d.logger.Errorf("an error occurred while listing tags of repository %s on %s with user %s: %v", d.repository, d.dstURL, d.dstUsr, err)
|
if err == errNotFound {
|
||||||
|
d.logger.Warningf("repository %s does not exist on %s", d.repository, d.dstURL)
|
||||||
|
return models.JobFinished, nil
|
||||||
|
}
|
||||||
|
d.logger.Errorf("an error occurred while deleting repository %s on %s with user %s: %v", d.repository, d.dstURL, d.dstUsr, err)
|
||||||
return "", err
|
return "", err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
d.tags = append(d.tags, tags...)
|
d.logger.Infof("repository %s on %s has been deleted", d.repository, d.dstURL)
|
||||||
|
|
||||||
|
return models.JobFinished, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
d.logger.Infof("tags %v will be deleted", d.tags)
|
// delele tags
|
||||||
|
|
||||||
for _, tag := range d.tags {
|
for _, tag := range d.tags {
|
||||||
|
u := url + "?repo_name=" + d.repository + "&tag=" + tag
|
||||||
|
if err := del(u, d.dstUsr, d.dstPwd, d.insecure); err != nil {
|
||||||
|
if err == errNotFound {
|
||||||
|
d.logger.Warningf("repository %s does not exist on %s", d.repository, d.dstURL)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if err := d.dstClient.DeleteTag(tag); err != nil {
|
|
||||||
d.logger.Errorf("an error occurred while deleting repository %s:%s on %s with user %s: %v", d.repository, tag, d.dstURL, d.dstUsr, err)
|
d.logger.Errorf("an error occurred while deleting repository %s:%s on %s with user %s: %v", d.repository, tag, d.dstURL, d.dstUsr, err)
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
d.logger.Infof("repository %s:%s on %s has been deleted", d.repository, tag, d.dstURL)
|
d.logger.Infof("repository %s:%s on %s has been deleted", d.repository, tag, d.dstURL)
|
||||||
}
|
}
|
||||||
|
|
||||||
return models.JobFinished, nil
|
return models.JobFinished, nil
|
||||||
|
|
||||||
|
/*
|
||||||
|
// the follow codes can be used for non-harbor repository deletion
|
||||||
|
dstCred := auth.NewBasicAuthCredential(d.dstUsr, d.dstPwd)
|
||||||
|
dstClient, err := newRepositoryClient(d.dstURL, d.insecure, dstCred,
|
||||||
|
d.repository, "repository", d.repository, "pull", "push", "*")
|
||||||
|
if err != nil {
|
||||||
|
d.logger.Errorf("an error occurred while creating destination repository client: %v", err)
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
d.dstClient = dstClient
|
||||||
|
|
||||||
|
if len(d.tags) == 0 {
|
||||||
|
tags, err := d.dstClient.ListTag()
|
||||||
|
if err != nil {
|
||||||
|
d.logger.Errorf("an error occurred while listing tags of repository %s on %s with user %s: %v", d.repository, d.dstURL, d.dstUsr, err)
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
d.tags = append(d.tags, tags...)
|
||||||
|
}
|
||||||
|
|
||||||
|
d.logger.Infof("tags %v will be deleted", d.tags)
|
||||||
|
|
||||||
|
for _, tag := range d.tags {
|
||||||
|
|
||||||
|
if err := d.dstClient.DeleteTag(tag); err != nil {
|
||||||
|
d.logger.Errorf("an error occurred while deleting repository %s:%s on %s with user %s: %v", d.repository, tag, d.dstURL, d.dstUsr, err)
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
d.logger.Infof("repository %s:%s on %s has been deleted", d.repository, tag, d.dstURL)
|
||||||
|
}
|
||||||
|
|
||||||
|
return models.JobFinished, nil
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
func del(url, username, password string, insecure bool) error {
|
||||||
|
req, err := http.NewRequest("DELETE", url, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
req.SetBasicAuth(username, password)
|
||||||
|
|
||||||
|
client := &http.Client{
|
||||||
|
Transport: &http.Transport{
|
||||||
|
TLSClientConfig: &tls.Config{
|
||||||
|
InsecureSkipVerify: insecure,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
resp, err := client.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
if resp.StatusCode == http.StatusOK {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if resp.StatusCode == http.StatusNotFound {
|
||||||
|
return errNotFound
|
||||||
|
}
|
||||||
|
|
||||||
|
b, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return fmt.Errorf("%d %s", resp.StatusCode, string(b))
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user