Publish
This commit is contained in:
parent
36e87f0696
commit
ef1f38c58d
@ -21,7 +21,6 @@ func main() {
|
||||
|
||||
vversion := fmt.Sprintf("v%s", version)
|
||||
existe, _ := releases.CheckRelease(vversion)
|
||||
fmt.Printf(" << existe : %t\n", existe)
|
||||
|
||||
if existe == false {
|
||||
err := releases.CreateRelease(vversion, occonst.PUBLISH_BRANCH)
|
||||
@ -32,18 +31,36 @@ func main() {
|
||||
}
|
||||
|
||||
idRelease, _ := releases.GetReleaseId(vversion)
|
||||
fmt.Println(fmt.Sprintf(" << id : %d ", idRelease))
|
||||
|
||||
ficversion := fmt.Sprintf("../oc_%s.yml", version)
|
||||
ficjson := fmt.Sprintf("../oc.json")
|
||||
createJsonFile(ficversion, ficjson)
|
||||
|
||||
idAsset, _ := releases.GetAssetId(idRelease, "oc.json")
|
||||
if idAsset == 0 {
|
||||
releases.CreateAsset(idRelease, ficjson)
|
||||
if existe == true {
|
||||
fmt.Println(fmt.Sprintf(" << Release existante : %d ", idRelease))
|
||||
} else {
|
||||
releases.UpdateAsset(idRelease, idAsset, ficjson)
|
||||
fmt.Println(fmt.Sprintf(" << idAsset : %d ", idAsset))
|
||||
fmt.Println(fmt.Sprintf(" << Release crée : %d ", idRelease))
|
||||
}
|
||||
|
||||
assetname := "oc.json"
|
||||
ficversion := fmt.Sprintf("../oc_%s.yml", version)
|
||||
ficjson := fmt.Sprintf("../%s", assetname)
|
||||
err := createJsonFile(ficversion, ficjson)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
idAsset, _ := releases.GetAssetId(idRelease, assetname)
|
||||
if idAsset == 0 {
|
||||
fmt.Println(fmt.Sprintf(" << Ajout Asset : %s", assetname))
|
||||
err := releases.CreateAsset(idRelease, ficjson, assetname)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
os.Exit(1)
|
||||
}
|
||||
} else {
|
||||
fmt.Println(fmt.Sprintf(" << Mise à jour : %s (idAsset=%d) ", assetname, idAsset))
|
||||
err := releases.UpdateAsset(idRelease, idAsset, ficjson, assetname)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
os.Exit(1)
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -6,6 +6,7 @@ import (
|
||||
"path/filepath"
|
||||
"mime/multipart"
|
||||
"io"
|
||||
"io/ioutil"
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
"bytes"
|
||||
@ -53,7 +54,7 @@ func GetAssetId(idRelease int, name string) (int, error) {
|
||||
// -H 'accept: application/json' \
|
||||
// -H 'Content-Type: multipart/form-data' \
|
||||
// -F 'attachment=oc-deploy'
|
||||
func CreateAsset(idRelease int, filename string, name string) (int, error) {
|
||||
func CreateAsset(idRelease int, filename string, name string) (error) {
|
||||
url := fmt.Sprintf("%s/api/v1/repos/%s/releases/%d/assets?name=%s&token=%s",
|
||||
occonst.PUBLISH_URL,
|
||||
occonst.PUBLISH_REPO,
|
||||
@ -63,20 +64,42 @@ func CreateAsset(idRelease int, filename string, name string) (int, error) {
|
||||
|
||||
err := uploadFile(url, "attachment", filename)
|
||||
|
||||
return 0, err
|
||||
return err
|
||||
}
|
||||
|
||||
func UpdateAsset(idRelease int, idAsset int,filename string, name string) (int, error) {
|
||||
url := fmt.Sprintf("%s/api/v1/repos/%s/releases/%d/assets?name=%s&token=%s",
|
||||
func UpdateAsset(idRelease int, idAsset int, filename string, name string) (error) {
|
||||
|
||||
url := fmt.Sprintf("%s/api/v1/repos/%s/releases/%d/assets/%d?token=%s",
|
||||
occonst.PUBLISH_URL,
|
||||
occonst.PUBLISH_REPO,
|
||||
idRelease,
|
||||
name,
|
||||
idAsset,
|
||||
occonst.PUBLISH_TOKEN)
|
||||
|
||||
err := uploadFile(url, "attachment", filename)
|
||||
// Create client
|
||||
client := &http.Client{}
|
||||
|
||||
return 0, err
|
||||
// Create request
|
||||
req, err := http.NewRequest("DELETE", url, nil)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// Fetch Request
|
||||
resp, err := client.Do(req)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
// Read Response Body
|
||||
respBody, err := ioutil.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
fmt.Println(string(respBody))
|
||||
|
||||
return CreateAsset(idRelease, filename, name)
|
||||
}
|
||||
|
||||
func uploadFile(url string, paramName string, filePath string) error {
|
||||
@ -106,12 +129,17 @@ func uploadFile(url string, paramName string, filePath string) error {
|
||||
response, err := client.Do(request)
|
||||
|
||||
if err != nil {
|
||||
fmt.Println(109, err)
|
||||
return err
|
||||
}
|
||||
defer response.Body.Close()
|
||||
|
||||
_, err := io.ReadAll(response.Body)
|
||||
if response.StatusCode > 400 {
|
||||
return fmt.Errorf(response.Status)
|
||||
}
|
||||
|
||||
_, err1 := io.ReadAll(response.Body)
|
||||
|
||||
// Handle the server response...
|
||||
return nil
|
||||
return err1
|
||||
}
|
||||
|
@ -3,6 +3,7 @@ package releases
|
||||
import (
|
||||
"fmt"
|
||||
"io"
|
||||
"io/ioutil"
|
||||
"strings"
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
@ -86,14 +87,19 @@ func CreateRelease(version string, branch string) (error) {
|
||||
occonst.PUBLISH_REPO,
|
||||
occonst.PUBLISH_TOKEN)
|
||||
|
||||
releasebytes, err := ioutil.ReadFile("release.txt")
|
||||
releasetxt := string(releasebytes)
|
||||
releasetxt = strings.Replace(releasetxt, "\n", "\\n", -1)
|
||||
releasetxt = fmt.Sprintf(releasetxt, version, occonst.PUBLISH_URL, occonst.PUBLISH_REPO, version)
|
||||
|
||||
body := fmt.Sprintf(`{
|
||||
"body": "Version %s",
|
||||
"body": "%s",
|
||||
"draft": false,
|
||||
"name": "%s",
|
||||
"prerelease": false,
|
||||
"tag_name": "%s",
|
||||
"target_commitish": "%s"
|
||||
}`, version, version, version, branch)
|
||||
}`, releasetxt, version, version, branch)
|
||||
|
||||
request, err := http.NewRequest("POST", url, strings.NewReader(body))
|
||||
if err != nil {
|
||||
@ -110,6 +116,9 @@ func CreateRelease(version string, branch string) (error) {
|
||||
defer response.Body.Close()
|
||||
|
||||
_, err1 := io.ReadAll(response.Body)
|
||||
// cnt, err1 := io.ReadAll(response.Body)
|
||||
// fmt.Println(string(cnt))
|
||||
|
||||
if err1 != nil {
|
||||
return err1
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user