databag/net/server/internal/api_setAccountApp.go

65 lines
1.4 KiB
Go
Raw Normal View History

2022-01-18 06:56:00 +00:00
package databag
import (
"net/http"
"encoding/hex"
"gorm.io/gorm"
"databag/internal/store"
"github.com/theckman/go-securerandom"
)
func SetAccountApp(w http.ResponseWriter, r *http.Request) {
token, res := BearerAccountToken(r);
if res != nil || token.TokenType != "attach" {
LogMsg("invalid bearer token")
w.WriteHeader(http.StatusUnauthorized)
return
}
// parse app data
var appData AppData
if ParseRequest(r, w, &appData) != nil {
LogMsg("invalid request data")
w.WriteHeader(http.StatusBadRequest)
return
}
// gernate app token
2022-01-22 19:40:20 +00:00
data, err := securerandom.Bytes(APP_TOKENSIZE)
2022-01-18 06:56:00 +00:00
if err != nil {
LogMsg("failed to generate token")
w.WriteHeader(http.StatusInternalServerError);
return
}
access := hex.EncodeToString(data)
// create app entry
app := store.App {
AccountID: token.Account.Guid,
2022-01-18 06:56:00 +00:00
Name: appData.Name,
Description: appData.Description,
Image: appData.Image,
Url: appData.Url,
Token: access,
};
// save app and delete token
err = store.DB.Transaction(func(tx *gorm.DB) error {
if res := store.DB.Create(&app).Error; res != nil {
return res;
}
if res := store.DB.Delete(token).Error; res != nil {
return res;
}
return nil;
});
if err != nil {
LogMsg("failed to save app")
w.WriteHeader(http.StatusInternalServerError)
return
}
WriteResponse(w, access)
}