harbor-2.3.0使用部分接口(正在完善中...)

projects

api/v2.0/projects

列出已有harbor已有项目及信息

package main

import (
  "fmt"
  "net/http"
  "io/ioutil"
)

func main() {

  url := "http://harbor.cfuture.shop/api/v2.0/projects"
  method := "GET"

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, nil)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("Cookie", "_gorilla_csrf=MTY1NTgwOTY2OXxJalpFUkhjd05WQXZUVGRaY1doWlREaERiMEp3V2pGemRUZHhkbE55WWswM1YxQXJZVFI2VURnMmJsVTlJZ289fP6uA3oEHIs4r6JzUDTdQqwbGaQ1PghYcky8rtGXIrV7; sid=c5499826f0b1d51ae150cc68460ff5d3") //请求的header头需要添加cookie返回的headers中才会有X-Harbor-Csrf-Token
  //req.Header.Add("Authorization", "Basic *********") 请求中添加Authorization才会获取到私有项目,否则只会返回公开项目
  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := ioutil.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}

请求的header头需要添加cookie返回的headers中才会有X-Harbor-Csrf-Token(这个在后面会用到)

api/v2.0/projects

创建harbor项目,下面为创建一个名称为test3的无存储限制的公开项目。

package main

import (
  "fmt"
  "strings"
  "net/http"
  "io/ioutil"
)

func main() {

  url := "http://harbor.cfuture.shop/api/v2.0/projects"
  method := "POST"

  payload := strings.NewReader(`{
    "project_name":"test3",
    "metadata":{"public":"true"},
    "storage_limit":-1,
    "registry_id":null
}`)

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, payload)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("X-Harbor-CSRF-Token", "v8C2Z6TSkxgsgiM2i6R64JCvcDElkGwW/T43Pul6e0YvYn1be9SF0PSWaLfX8tv2WG4s3Pv/dhAeNUKmNfEBHA==")
  req.Header.Add("Authorization", "Basic *********")
  req.Header.Add("Content-Type", "application/json")
  req.Header.Add("Cookie", "_gorilla_csrf=MTY1NTgwOTY2OXxJalpFUkhjd05WQXZUVGRaY1doWlREaERiMEp3V2pGemRUZHhkbE55WWswM1YxQXJZVFI2VURnMmJsVTlJZ289fP6uA3oEHIs4r6JzUDTdQqwbGaQ1PghYcky8rtGXIrV7; sid=c5499826f0b1d51ae150cc68460ff5d3")

  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := ioutil.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}

retentions

GET api/v2.0/retentions/1

获取项目已有策略

package main

import (
  "fmt"
  "net/http"
  "io/ioutil"
)

func main() {

  url := "http://harbor.cfuture.shop/api/v2.0/retentions/1"
  method := "GET"

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, nil)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("Authorization", "Basic *******")
  req.Header.Add("Cookie", "_gorilla_csrf=MTY1NTgwOTY2OXxJalpFUkhjd05WQXZUVGRaY1doWlREaERiMEp3V2pGemRUZHhkbE55WWswM1YxQXJZVFI2VURnMmJsVTlJZ289fP6uA3oEHIs4r6JzUDTdQqwbGaQ1PghYcky8rtGXIrV7; sid=c5499826f0b1d51ae150cc68460ff5d3")

  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := ioutil.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}

PUT api/v2.0/retentions/1

新建项目的策略,下面为新建一个定时清理策略,保留所有仓库最近推送的5个镜像,清理时间为每周。
在这里插入图片描述

package main

import (
  "fmt"
  "strings"
  "net/http"
  "io/ioutil"
)

func main() {

  url := "http://harbor.cfuture.shop/api/v2.0/retentions/1"
  method := "PUT"

  payload := strings.NewReader(`{"algorithm":"or","rules":[{"action":"retain","params":{"latestPushedK":5},"scope_selectors":{"repository":[{"decoration":"repoMatches","kind":"doublestar","pattern":"**"}]},"tag_selectors":[{"decoration":"matches","extras":"{\"untagged\":true}","kind":"doublestar","pattern":"**"}],"template":"latestPushedK"}],"scope":{"level":"project","ref":2},"trigger":{"kind":"Schedule","settings":{"cron":"0 0 0 * * 0"}}}`)

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, payload)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("X-Harbor-CSRF-Token", "Tni7u0teESVyIAbx0iEBKarfCLgATsC+ZajVk33xrWYtrjNcHkSEPEtuvG9obxIWz/LDAYvO5jlhqe4abYA/bA==")
  req.Header.Add("Authorization", "Basic *******")
  req.Header.Add("Content-Type", "application/json")
  req.Header.Add("Cookie", "_gorilla_csrf=MTY1NTgwOTY2OXxJalpFUkhjd05WQXZUVGRaY1doWlREaERiMEp3V2pGemRUZHhkbE55WWswM1YxQXJZVFI2VURnMmJsVTlJZ289fP6uA3oEHIs4r6JzUDTdQqwbGaQ1PghYcky8rtGXIrV7; sid=c5499826f0b1d51ae150cc68460ff5d3")

  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := ioutil.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值