mirror of
https://github.com/goharbor/harbor.git
synced 2024-12-24 01:27:49 +01:00
Merge pull request #428 from ywk253100/dev
1.order jobs by create time desc 2.open job log in browser 3.update s…
This commit is contained in:
commit
62d8614be9
@ -117,11 +117,8 @@ func (ra *RepJobAPI) GetLog() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if resp.StatusCode == http.StatusOK {
|
if resp.StatusCode == http.StatusOK {
|
||||||
for key, values := range resp.Header {
|
ra.Ctx.ResponseWriter.Header().Set(http.CanonicalHeaderKey("Content-Length"), resp.Header.Get(http.CanonicalHeaderKey("Content-Length")))
|
||||||
for _, value := range values {
|
ra.Ctx.ResponseWriter.Header().Set(http.CanonicalHeaderKey("Content-Type"), "text/plain")
|
||||||
ra.Ctx.ResponseWriter.Header().Set(key, value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, err = io.Copy(ra.Ctx.ResponseWriter, resp.Body); err != nil {
|
if _, err = io.Copy(ra.Ctx.ResponseWriter, resp.Body); err != nil {
|
||||||
log.Errorf("failed to write log to response; %v", err)
|
log.Errorf("failed to write log to response; %v", err)
|
||||||
|
@ -17,6 +17,7 @@ package dao
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@ -253,8 +254,16 @@ func UpdateRepPolicyEnablement(id int64, enabled int) error {
|
|||||||
o := GetOrmer()
|
o := GetOrmer()
|
||||||
p := models.RepPolicy{
|
p := models.RepPolicy{
|
||||||
ID: id,
|
ID: id,
|
||||||
Enabled: enabled}
|
Enabled: enabled,
|
||||||
_, err := o.Update(&p, "Enabled")
|
}
|
||||||
|
|
||||||
|
var err error
|
||||||
|
if enabled == 1 {
|
||||||
|
p.StartTime = time.Now()
|
||||||
|
_, err = o.Update(&p, "Enabled", "StartTime")
|
||||||
|
} else {
|
||||||
|
_, err = o.Update(&p, "Enabled")
|
||||||
|
}
|
||||||
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -315,7 +324,7 @@ func FilterRepJobs(policyID int64, repository, status string) ([]*models.RepJob,
|
|||||||
if len(status) != 0 {
|
if len(status) != 0 {
|
||||||
qs = qs.Filter("Status__icontains", status)
|
qs = qs.Filter("Status__icontains", status)
|
||||||
}
|
}
|
||||||
qs = qs.OrderBy("CreationTime")
|
qs = qs.OrderBy("-CreationTime")
|
||||||
|
|
||||||
var jobs []*models.RepJob
|
var jobs []*models.RepJob
|
||||||
_, err := qs.All(&jobs)
|
_, err := qs.All(&jobs)
|
||||||
|
@ -68,6 +68,7 @@ type BaseHandler struct {
|
|||||||
dstClient *registry.Repository
|
dstClient *registry.Repository
|
||||||
|
|
||||||
manifest distribution.Manifest // manifest of tags[0]
|
manifest distribution.Manifest // manifest of tags[0]
|
||||||
|
digest string //digest of tags[0]'s manifest
|
||||||
blobs []string // blobs need to be transferred for tags[0]
|
blobs []string // blobs need to be transferred for tags[0]
|
||||||
|
|
||||||
blobsExistence map[string]bool //key: digest of blob, value: existence
|
blobsExistence map[string]bool //key: digest of blob, value: existence
|
||||||
@ -329,6 +330,7 @@ func (m *ManifestPuller) Enter() (string, error) {
|
|||||||
m.logger.Errorf("an error occurred while pulling manifest of %s:%s from %s: %v", name, tag, m.srcURL, err)
|
m.logger.Errorf("an error occurred while pulling manifest of %s:%s from %s: %v", name, tag, m.srcURL, err)
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
m.digest = digest
|
||||||
m.logger.Infof("manifest of %s:%s pulled successfully from %s: %s", name, tag, m.srcURL, digest)
|
m.logger.Infof("manifest of %s:%s pulled successfully from %s: %s", name, tag, m.srcURL, digest)
|
||||||
|
|
||||||
if strings.Contains(mediaType, "application/json") {
|
if strings.Contains(mediaType, "application/json") {
|
||||||
@ -426,6 +428,19 @@ func (m *ManifestPusher) Enter() (string, error) {
|
|||||||
m.logger.Infof("manifest of %s:%s does not exist on source registry %s, cancel manifest pushing", name, tag, m.srcURL)
|
m.logger.Infof("manifest of %s:%s does not exist on source registry %s, cancel manifest pushing", name, tag, m.srcURL)
|
||||||
} else {
|
} else {
|
||||||
m.logger.Infof("manifest of %s:%s exists on source registry %s, continue manifest pushing", name, tag, m.srcURL)
|
m.logger.Infof("manifest of %s:%s exists on source registry %s, continue manifest pushing", name, tag, m.srcURL)
|
||||||
|
|
||||||
|
_, manifestExist, err := m.dstClient.ManifestExist(m.digest)
|
||||||
|
if manifestExist {
|
||||||
|
m.logger.Infof("manifest of %s:%s exists on destination registry %s, skip manifest pushing", name, tag, m.dstURL)
|
||||||
|
|
||||||
|
m.tags = m.tags[1:]
|
||||||
|
m.manifest = nil
|
||||||
|
m.digest = ""
|
||||||
|
m.blobs = nil
|
||||||
|
|
||||||
|
return StatePullManifest, nil
|
||||||
|
}
|
||||||
|
|
||||||
mediaType, data, err := m.manifest.Payload()
|
mediaType, data, err := m.manifest.Payload()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
m.logger.Errorf("an error occurred while getting payload of manifest for %s:%s : %v", name, tag, err)
|
m.logger.Errorf("an error occurred while getting payload of manifest for %s:%s : %v", name, tag, err)
|
||||||
@ -441,6 +456,7 @@ func (m *ManifestPusher) Enter() (string, error) {
|
|||||||
|
|
||||||
m.tags = m.tags[1:]
|
m.tags = m.tags[1:]
|
||||||
m.manifest = nil
|
m.manifest = nil
|
||||||
|
m.digest = ""
|
||||||
m.blobs = nil
|
m.blobs = nil
|
||||||
|
|
||||||
return StatePullManifest, nil
|
return StatePullManifest, nil
|
||||||
|
Loading…
Reference in New Issue
Block a user