Compare commits

..

No commits in common. "6e7cd93bffae06d7dc328719e245fc1fc96cd6ad" and "e1e93a933660dc3cefa18a98ad2244f00834d9e7" have entirely different histories.

2 changed files with 27 additions and 28 deletions

View File

@ -3,7 +3,7 @@
This allows you to host custom (known as 3rd party) App Market repositories of WebDesk applications.
## Features
- Listing currently uploaded apps (/apps endpoint and root of web server)
- Listing currently uploaded apps (/apps endpoint)
- Showing app source code (under /uploads/app_name/index.js)
- Uploading new apps (/apps endpoint with Bearer token)
- Editing app info (/editapp endpoint with Bearer token)

53
main.go
View File

@ -46,7 +46,7 @@ func init() {
}
websrvport := os.Getenv("PORT")
if websrvport == "" {
websrvport = "8080"
websrvport = "8080"
}
fmt.Printf("Starting web server on port %s\n", websrvport)
}
@ -77,26 +77,20 @@ func main() {
// Serve static files
r.Static("/apps/files", "./apps/files")
// Handler function for getting apps list
getAppsHandler := func(c *gin.Context) {
data, err := ioutil.ReadFile("apps.json")
if err != nil {
c.JSON(http.StatusOK, []App{})
return
}
var apps []App
json.Unmarshal(data, &apps)
c.JSON(http.StatusOK, apps)
}
// Serve apps list on root path
r.GET("/", getAppsHandler)
// Group routes for /apps
apps := r.Group("/apps")
{
apps.GET("", getAppsHandler)
apps.GET("", func(c *gin.Context) {
data, err := ioutil.ReadFile("apps.json")
if err != nil {
c.JSON(http.StatusOK, []App{})
return
}
var apps []App
json.Unmarshal(data, &apps)
c.JSON(http.StatusOK, apps)
})
// Handle other methods for /apps
apps.Handle("POST", "", methodNotAllowedHandler("GET"))
apps.Handle("PUT", "", methodNotAllowedHandler("GET"))
@ -115,21 +109,17 @@ func main() {
return
}
var metadata struct {
AppMetadata
AppID string `json:"appid,omitempty"`
}
var metadata AppMetadata
if err := json.Unmarshal([]byte(metadataStr), &metadata); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid metadata"})
return
}
appID := metadata.AppID
if appID == "" {
rand.Seed(time.Now().UnixNano())
appID = fmt.Sprintf("%012d", rand.Intn(1000000000000))
}
// Generate 12-digit app ID
rand.Seed(time.Now().UnixNano())
appID := fmt.Sprintf("%012d", rand.Intn(1000000000000))
// Create new app entry
newApp := App{
Name: metadata.Name,
Ver: metadata.Ver,
@ -139,6 +129,7 @@ func main() {
Path: fmt.Sprintf("/apps/files/%s_%s%s", metadata.Name, metadata.Ver, filepath.Ext(file.Filename)),
}
// Save file
if err := os.MkdirAll("apps/files", 0755); err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to create directory"})
return
@ -149,6 +140,7 @@ func main() {
return
}
// Update apps.json
var apps []App
data, _ := ioutil.ReadFile("apps.json")
json.Unmarshal(data, &apps)
@ -168,6 +160,7 @@ func main() {
editapp := r.Group("/editapp")
{
editapp.PUT("", authMiddleware(), func(c *gin.Context) {
// Get metadata from form
metadataStr := c.PostForm("metadata")
if metadataStr == "" {
c.JSON(http.StatusBadRequest, gin.H{"error": "Metadata is required"})
@ -196,13 +189,17 @@ func main() {
apps[i].Ver = updateData.App.Ver
apps[i].Info = updateData.App.Info
// Handle file update if provided
if file, err := c.FormFile("file"); err == nil {
// Delete old file
os.Remove(oldFilePath)
// Generate new path
newPath := fmt.Sprintf("/apps/files/%s_%s%s",
apps[i].Name, apps[i].Ver, filepath.Ext(file.Filename))
apps[i].Path = newPath
// Save new file
if err := c.SaveUploadedFile(file, "."+newPath); err != nil {
c.JSON(http.StatusInternalServerError,
gin.H{"error": "Failed to save new file"})
@ -263,8 +260,10 @@ func main() {
return
}
// Delete the file
os.Remove(filePath)
// Update apps.json
appsJSON, _ := json.Marshal(apps)
ioutil.WriteFile("apps.json", appsJSON, 0644)
c.JSON(http.StatusOK, gin.H{"message": "App deleted successfully"})