added function to check versions
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
This commit is contained in:
parent
991d8a9977
commit
7029d039a3
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
target*
|
||||||
|
source*
|
7
main.go
7
main.go
@ -13,6 +13,7 @@ func main() {
|
|||||||
var source_dir = flag.String("s", "", "Path to image folder (/srv/fwuploads-tmp/)")
|
var source_dir = flag.String("s", "", "Path to image folder (/srv/fwuploads-tmp/)")
|
||||||
var target_dir = flag.String("t", "", "Path to image folder in public (/srv/fwuploads/troisdorf)")
|
var target_dir = flag.String("t", "", "Path to image folder in public (/srv/fwuploads/troisdorf)")
|
||||||
var branch = flag.String("b", "", "Branch to work with")
|
var branch = flag.String("b", "", "Branch to work with")
|
||||||
|
var version = flag.String("v", "", "which version should be released")
|
||||||
var dryrun = flag.Bool("d", false, "Dryrun, just show changes on filesystem")
|
var dryrun = flag.Bool("d", false, "Dryrun, just show changes on filesystem")
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
@ -20,8 +21,8 @@ func main() {
|
|||||||
tdir := *target_dir
|
tdir := *target_dir
|
||||||
br := *branch
|
br := *branch
|
||||||
|
|
||||||
var source_dir_branch string = sdir + br + "/"
|
var source_dir_branch string = sdir + br + "/images/"
|
||||||
var target_dir_branch string = tdir + br + "/"
|
var target_dir_branch string = tdir + br + "/images/"
|
||||||
|
|
||||||
if is_firmware_folder(source_dir_branch) {
|
if is_firmware_folder(source_dir_branch) {
|
||||||
//generate manifest file for branch
|
//generate manifest file for branch
|
||||||
@ -31,7 +32,7 @@ func main() {
|
|||||||
log.Println("Error generating Manifest file: ", err)
|
log.Println("Error generating Manifest file: ", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
release_branch(*branch, source_dir_branch, target_dir_branch, *dryrun)
|
release_branch(*branch, source_dir_branch, target_dir_branch, *dryrun, *version)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
53
release.go
53
release.go
@ -1,23 +1,36 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
func release_branch(branch string, source_dir string, target_dir string, dryrun bool) {
|
func release_branch(b string, sDir string, tDir string, dryrun bool, v string) {
|
||||||
checkOldFolder, _ := os.ReadDir(source_dir)
|
check_sDir, _ := os.ReadDir(sDir)
|
||||||
checkNewFolder, _ := os.ReadDir(target_dir)
|
check_tDir, _ := os.ReadDir(tDir)
|
||||||
var newImages bool = false
|
var newImages bool = false
|
||||||
if len(checkOldFolder) > 0 {
|
if len(check_sDir) > 0 {
|
||||||
newImages = true
|
newImages = true
|
||||||
}
|
}
|
||||||
|
sVersion := GetGluonVersion(sDir)
|
||||||
|
tVersion := GetGluonVersion(tDir)
|
||||||
|
//check wanted version in target
|
||||||
|
if tVersion != v {
|
||||||
|
log.Println("published version is outdated, try to update from source folder")
|
||||||
|
if sVersion != v {
|
||||||
|
log.Println("wanted Version is not availible in source folder")
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if newImages {
|
if newImages {
|
||||||
// delete old firmware files in public folder
|
// delete old firmware files in public folder
|
||||||
for _, file := range checkNewFolder {
|
for _, file := range check_tDir {
|
||||||
if !(dryrun) {
|
if !(dryrun) {
|
||||||
err := os.RemoveAll(target_dir + file.Name())
|
err := os.RemoveAll(tDir + file.Name())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("error deleting file: ", err)
|
log.Println("error deleting file: ", err)
|
||||||
} else {
|
} else {
|
||||||
@ -29,9 +42,9 @@ func release_branch(branch string, source_dir string, target_dir string, dryrun
|
|||||||
}
|
}
|
||||||
|
|
||||||
//move new files to folder
|
//move new files to folder
|
||||||
for _, file := range checkOldFolder {
|
for _, file := range check_sDir {
|
||||||
if !(dryrun) {
|
if !(dryrun) {
|
||||||
os.Rename(source_dir+file.Name(), target_dir+file.Name())
|
os.Rename(sDir+file.Name(), tDir+file.Name())
|
||||||
log.Println("moved file: ", file.Name())
|
log.Println("moved file: ", file.Name())
|
||||||
} else {
|
} else {
|
||||||
log.Println("DRYRUN: move folder: ", file.Name())
|
log.Println("DRYRUN: move folder: ", file.Name())
|
||||||
@ -39,3 +52,27 @@ func release_branch(branch string, source_dir string, target_dir string, dryrun
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetGluonVersion(path string) string {
|
||||||
|
image_folder := path + "sysupgrade/"
|
||||||
|
files, err := filepath.Glob(filepath.Join(image_folder, "gluon-tdf-*"))
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Error reading directory: ", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(files) > 0 {
|
||||||
|
fileName := filepath.Base(files[0])
|
||||||
|
parts := strings.Split(fileName, "-")
|
||||||
|
if len(parts) >= 4 {
|
||||||
|
version := parts[2]
|
||||||
|
return version
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
func check_Release() {
|
||||||
|
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user