Added various functions to edgeapps package, working GetEdgeApps func running as scheduled task
parent
fc5b342c89
commit
5a97caacff
|
@ -1,12 +1,12 @@
|
||||||
package edgeapps
|
package edgeapps
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"gopkg.in/yaml.v2"
|
"github.com/edgebox-iot/sysctl/internal/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
// EdgeApp : Struct representing an EdgeApp in the system
|
// EdgeApp : Struct representing an EdgeApp in the system
|
||||||
|
@ -15,7 +15,7 @@ type EdgeApp struct {
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Status EdgeAppStatus `json:"status"`
|
Status EdgeAppStatus `json:"status"`
|
||||||
Services []EdgeAppService `json:"services"`
|
Services []EdgeAppService `json:"services"`
|
||||||
NetworkURL []string `json:"network_url"`
|
NetworkURL string `json:"network_url"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// EdgeAppStatus : Struct representing possible EdgeApp statuses (code + description)
|
// EdgeAppStatus : Struct representing possible EdgeApp statuses (code + description)
|
||||||
|
@ -27,18 +27,19 @@ type EdgeAppStatus struct {
|
||||||
// EdgeAppService : Struct representing a single container that can be part of an EdgeApp package
|
// EdgeAppService : Struct representing a single container that can be part of an EdgeApp package
|
||||||
type EdgeAppService struct {
|
type EdgeAppService struct {
|
||||||
ID string `json:"id"`
|
ID string `json:"id"`
|
||||||
Name string `json:"name"`
|
IsRunning bool `json:"is_running"`
|
||||||
Isrunning bool `json:"is_running"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const configFilename = "/edgebox-compose.yml"
|
||||||
|
const edgeAppsPath = "/home/jpt/Repositories/edgebox/apps/"
|
||||||
|
const wsPath = "/home/jpt/Repositories/edgebox/ws/"
|
||||||
|
|
||||||
// GetEdgeApps : Returns a list of EdgeApp struct filled with information
|
// GetEdgeApps : Returns a list of EdgeApp struct filled with information
|
||||||
func GetEdgeApps() string { // []EdgeApp {
|
func GetEdgeApps() []EdgeApp {
|
||||||
|
|
||||||
// var edgeApps []EdgeApp
|
var edgeApps []EdgeApp
|
||||||
|
|
||||||
// Building list of available edgeapps in the system.
|
// Building list of available edgeapps in the system with their status
|
||||||
configFilename := "edgebox-compose.yml"
|
|
||||||
edgeAppsPath := "/home/system/components/apps"
|
|
||||||
|
|
||||||
files, err := ioutil.ReadDir(edgeAppsPath)
|
files, err := ioutil.ReadDir(edgeAppsPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -46,59 +47,76 @@ func GetEdgeApps() string { // []EdgeApp {
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, f := range files {
|
for _, f := range files {
|
||||||
fmt.Println(f.Name())
|
|
||||||
if f.IsDir() {
|
if f.IsDir() {
|
||||||
// It is a folder that most probably contains an EdgeApp.
|
// It is a folder that most probably contains an EdgeApp.
|
||||||
// To be fully sure, test that edgebox-compose.yml file exists in the target directory.
|
// To be fully sure, test that edgebox-compose.yml file exists in the target directory.
|
||||||
_, err := os.Stat("/home/system/components/apps/" + f.Name() + "/" + configFilename)
|
_, err := os.Stat(edgeAppsPath + f.Name() + configFilename)
|
||||||
if !os.IsNotExist(err) {
|
if !os.IsNotExist(err) {
|
||||||
// File exists. Start digging!
|
// File exists. Start digging!
|
||||||
// edgeApp := EdgeApp{ID: f.Name(), Status: GetEdgeAppStatus(f.Name())}
|
edgeApp := EdgeApp{ID: f.Name(), Status: GetEdgeAppStatus(f.Name()), Services: GetEdgeAppServices(f.Name()), NetworkURL: f.Name() + ".edgebox.local"}
|
||||||
// edgeApps = append(edgeApps, edgeApp)
|
edgeApps = append(edgeApps, edgeApp)
|
||||||
GetEdgeAppServices(f.Name())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Querying to see which apps are running.
|
|
||||||
// cmdargs = []string{"ps", "-a"}
|
|
||||||
// executeCommand("docker", cmdargs)
|
|
||||||
// (...)
|
|
||||||
|
|
||||||
// return edgeApps
|
// return edgeApps
|
||||||
return "OK"
|
return edgeApps
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetEdgeAppStatus : Returns a struct representing the current status of the EdgeApp
|
// GetEdgeAppStatus : Returns a struct representing the current status of the EdgeApp
|
||||||
// func GetEdgeAppStatus(ID string) EdgeAppStatus {
|
func GetEdgeAppStatus(ID string) EdgeAppStatus {
|
||||||
|
|
||||||
// // Possible states of an EdgeApp:
|
// Possible states of an EdgeApp:
|
||||||
// // - All services running = EdgeApp running
|
// - All services running = EdgeApp running
|
||||||
// // - Some services running = Problem detected, needs restart
|
// - Some services running = Problem detected, needs restart
|
||||||
// // - No service running = EdgeApp is off
|
// - No service running = EdgeApp is off
|
||||||
|
|
||||||
// services := GetEdgeAppServices(ID)
|
runningServices := 0
|
||||||
|
status := EdgeAppStatus{0, "off"}
|
||||||
// return status
|
services := GetEdgeAppServices(ID)
|
||||||
// }
|
for _, edgeAppService := range services {
|
||||||
|
if edgeAppService.IsRunning {
|
||||||
// GetEdgeAppServices : Returns a
|
runningServices++
|
||||||
func GetEdgeAppServices(ID string) string {
|
}
|
||||||
|
|
||||||
data, err := ioutil.ReadFile("/home/system/components/apps/" + ID + "/edgebox-compose.yml")
|
|
||||||
|
|
||||||
// If this happens it means that no EdgeApp exists for the given ID. This func should not be called in that case.
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is application running?
|
if runningServices > 0 && runningServices != len(services) {
|
||||||
|
status = EdgeAppStatus{2, "error"}
|
||||||
|
}
|
||||||
|
|
||||||
t := make(map[string]interface{})
|
if runningServices == len(services) {
|
||||||
yaml.Unmarshal([]byte(data), &t)
|
status = EdgeAppStatus{1, "on"}
|
||||||
fmt.Println(t["services"])
|
}
|
||||||
|
|
||||||
return "OK"
|
return status
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetEdgeAppServices : Returns a
|
||||||
|
func GetEdgeAppServices(ID string) []EdgeAppService {
|
||||||
|
|
||||||
|
log.Println("Finding " + ID + " EdgeApp Services")
|
||||||
|
|
||||||
|
// strConfigFile := string(configFile) // convert content to a 'string'
|
||||||
|
|
||||||
|
cmdArgs := []string{"-r", ".services | keys[]", edgeAppsPath + ID + configFilename}
|
||||||
|
servicesString := utils.Exec("yq", cmdArgs)
|
||||||
|
serviceSlices := strings.Split(servicesString, "\n")
|
||||||
|
serviceSlices = utils.DeleteEmptySlices(serviceSlices)
|
||||||
|
var edgeAppServices []EdgeAppService
|
||||||
|
|
||||||
|
for _, serviceID := range serviceSlices {
|
||||||
|
log.Println(serviceID)
|
||||||
|
cmdArgs = []string{"-f", wsPath + "/docker-compose.yml", "ps", "-q", serviceID}
|
||||||
|
cmdResult := utils.Exec("docker-compose", cmdArgs)
|
||||||
|
isRunning := false
|
||||||
|
if cmdResult != "" {
|
||||||
|
isRunning = true
|
||||||
|
}
|
||||||
|
edgeAppServices = append(edgeAppServices, EdgeAppService{ID: serviceID, IsRunning: isRunning})
|
||||||
|
}
|
||||||
|
|
||||||
|
return edgeAppServices
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -192,7 +192,8 @@ func taskSetupTunnel(args taskSetupTunnelArgs) string {
|
||||||
func taskGetEdgeApps() string {
|
func taskGetEdgeApps() string {
|
||||||
|
|
||||||
fmt.Println("Executing taskGetEdgeApps")
|
fmt.Println("Executing taskGetEdgeApps")
|
||||||
edgeapps.GetEdgeApps()
|
|
||||||
|
log.Println(edgeapps.GetEdgeApps())
|
||||||
|
|
||||||
// Saving information in the "options" table.
|
// Saving information in the "options" table.
|
||||||
return "OK"
|
return "OK"
|
||||||
|
|
|
@ -18,7 +18,20 @@ func Exec(command string, args []string) string {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(fmt.Sprint(err) + ": " + stderr.String())
|
log.Println(fmt.Sprint(err) + ": " + stderr.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
log.Println("Result: " + out.String())
|
log.Println("Result: " + out.String())
|
||||||
|
|
||||||
return out.String()
|
return out.String()
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeleteEmptySlices : Given a string array, delete empty entries.
|
||||||
|
func DeleteEmptySlices(s []string) []string {
|
||||||
|
var r []string
|
||||||
|
for _, str := range s {
|
||||||
|
if str != "" {
|
||||||
|
r = append(r, str)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return r
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue