mirror of
https://codeberg.org/scip/ephemerup.git
synced 2025-12-16 20:20:58 +01:00
added modify command for upload and form
This commit is contained in:
@@ -199,7 +199,7 @@ func FormDescribe(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
response, err := db.Get(apicontext, id, common.TypeForm)
|
response, err := db.Get(apicontext, id, common.TypeForm)
|
||||||
if err != nil {
|
if err != nil || len(response.Forms) == 0 {
|
||||||
return JsonStatus(c, fiber.StatusForbidden,
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
"No form with that id could be found!")
|
"No form with that id could be found!")
|
||||||
}
|
}
|
||||||
@@ -262,6 +262,19 @@ func FormPage(c *fiber.Ctx, cfg *cfg.Config, db *Db, shallexpire bool) error {
|
|||||||
func FormModify(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
func FormModify(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
||||||
var formdata common.Form
|
var formdata common.Form
|
||||||
|
|
||||||
|
// retrieve the API Context name from the session
|
||||||
|
apicontext, err := SessionGetApicontext(c)
|
||||||
|
if err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusInternalServerError,
|
||||||
|
"Unable to initialize session store from context: "+err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
id, err := common.Untaint(c.Params("id"), cfg.RegKey)
|
||||||
|
if err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"Invalid id provided!")
|
||||||
|
}
|
||||||
|
|
||||||
// extract form data
|
// extract form data
|
||||||
if err := c.BodyParser(&formdata); err != nil {
|
if err := c.BodyParser(&formdata); err != nil {
|
||||||
return JsonStatus(c, fiber.StatusInternalServerError,
|
return JsonStatus(c, fiber.StatusInternalServerError,
|
||||||
@@ -281,5 +294,36 @@ func FormModify(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
// lookup orig entry
|
||||||
|
response, err := db.Get(apicontext, id, common.TypeForm)
|
||||||
|
if err != nil || len(response.Forms) == 0 {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"No form with that id could be found!")
|
||||||
|
}
|
||||||
|
|
||||||
|
form := response.Forms[0]
|
||||||
|
|
||||||
|
// modify fields
|
||||||
|
if formdata.Expire != "" {
|
||||||
|
form.Expire = formdata.Expire
|
||||||
|
}
|
||||||
|
|
||||||
|
if formdata.Notify != "" {
|
||||||
|
form.Notify = formdata.Notify
|
||||||
|
}
|
||||||
|
|
||||||
|
if formdata.Description != "" {
|
||||||
|
form.Description = formdata.Description
|
||||||
|
}
|
||||||
|
|
||||||
|
// run in foreground because we need the feedback here
|
||||||
|
if err := db.Insert(id, form); err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"Failed to insert: "+err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
res := &common.Response{Forms: []*common.Form{form}}
|
||||||
|
res.Success = true
|
||||||
|
res.Code = fiber.StatusOK
|
||||||
|
return c.Status(fiber.StatusOK).JSON(res)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -76,6 +76,11 @@ func Runserver(conf *cfg.Config, args []string) error {
|
|||||||
return UploadDescribe(c, conf, db)
|
return UploadDescribe(c, conf, db)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// modify
|
||||||
|
api.Put("/uploads/:id", auth, func(c *fiber.Ctx) error {
|
||||||
|
return UploadModify(c, conf, db)
|
||||||
|
})
|
||||||
|
|
||||||
// download w/o expire
|
// download w/o expire
|
||||||
api.Get("/uploads/:id/file", auth, func(c *fiber.Ctx) error {
|
api.Get("/uploads/:id/file", auth, func(c *fiber.Ctx) error {
|
||||||
return UploadFetch(c, conf, db)
|
return UploadFetch(c, conf, db)
|
||||||
@@ -101,6 +106,11 @@ func Runserver(conf *cfg.Config, args []string) error {
|
|||||||
api.Get("/forms/:id", auth, func(c *fiber.Ctx) error {
|
api.Get("/forms/:id", auth, func(c *fiber.Ctx) error {
|
||||||
return FormDescribe(c, conf, db)
|
return FormDescribe(c, conf, db)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// modify
|
||||||
|
api.Put("/forms/:id", auth, func(c *fiber.Ctx) error {
|
||||||
|
return FormModify(c, conf, db)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// public routes
|
// public routes
|
||||||
|
|||||||
@@ -328,3 +328,64 @@ func UploadDescribe(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
|||||||
|
|
||||||
return c.Status(fiber.StatusOK).JSON(response)
|
return c.Status(fiber.StatusOK).JSON(response)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func UploadModify(c *fiber.Ctx, cfg *cfg.Config, db *Db) error {
|
||||||
|
var formdata common.Upload
|
||||||
|
|
||||||
|
// retrieve the API Context name from the session
|
||||||
|
apicontext, err := SessionGetApicontext(c)
|
||||||
|
if err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusInternalServerError,
|
||||||
|
"Unable to initialize session store from context: "+err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
id, err := common.Untaint(c.Params("id"), cfg.RegKey)
|
||||||
|
if err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"Invalid id provided!")
|
||||||
|
}
|
||||||
|
|
||||||
|
// extract form data
|
||||||
|
if err := c.BodyParser(&formdata); err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusInternalServerError,
|
||||||
|
"bodyparser error : "+err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
// post process input data
|
||||||
|
if err := untaintField(c, &formdata.Expire, cfg.RegDuration, "expire data"); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := untaintField(c, &formdata.Description, cfg.RegDuration, "description"); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// lookup orig entry
|
||||||
|
response, err := db.Get(apicontext, id, common.TypeUpload)
|
||||||
|
if err != nil || len(response.Uploads) == 0 {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"No upload with that id could be found!")
|
||||||
|
}
|
||||||
|
|
||||||
|
upload := response.Uploads[0]
|
||||||
|
|
||||||
|
// modify fields
|
||||||
|
if formdata.Expire != "" {
|
||||||
|
upload.Expire = formdata.Expire
|
||||||
|
}
|
||||||
|
|
||||||
|
if formdata.Description != "" {
|
||||||
|
upload.Description = formdata.Description
|
||||||
|
}
|
||||||
|
|
||||||
|
// run in foreground because we need the feedback here
|
||||||
|
if err := db.Insert(id, upload); err != nil {
|
||||||
|
return JsonStatus(c, fiber.StatusForbidden,
|
||||||
|
"Failed to insert: "+err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
res := &common.Response{Uploads: []*common.Upload{upload}}
|
||||||
|
res.Success = true
|
||||||
|
res.Code = fiber.StatusOK
|
||||||
|
return c.Status(fiber.StatusOK).JSON(res)
|
||||||
|
}
|
||||||
|
|||||||
@@ -48,6 +48,7 @@ func FormCommand(conf *cfg.Config) *cobra.Command {
|
|||||||
formCmd.AddCommand(FormListCommand(conf))
|
formCmd.AddCommand(FormListCommand(conf))
|
||||||
formCmd.AddCommand(FormDeleteCommand(conf))
|
formCmd.AddCommand(FormDeleteCommand(conf))
|
||||||
formCmd.AddCommand(FormDescribeCommand(conf))
|
formCmd.AddCommand(FormDescribeCommand(conf))
|
||||||
|
formCmd.AddCommand(FormModifyCommand(conf))
|
||||||
|
|
||||||
return formCmd
|
return formCmd
|
||||||
}
|
}
|
||||||
@@ -66,9 +67,12 @@ func FormCreateCommand(conf *cfg.Config) *cobra.Command {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// options
|
// options
|
||||||
formCreateCmd.PersistentFlags().StringVarP(&conf.Expire, "expire", "e", "", "Expire setting: asap or duration (accepted shortcuts: dmh)")
|
formCreateCmd.PersistentFlags().StringVarP(&conf.Expire, "expire", "e", "",
|
||||||
formCreateCmd.PersistentFlags().StringVarP(&conf.Description, "description", "D", "", "Description of the form")
|
"Expire setting: asap or duration (accepted shortcuts: dmh)")
|
||||||
formCreateCmd.PersistentFlags().StringVarP(&conf.Notify, "notify", "n", "", "Email address to get notified when consumer has uploaded files")
|
formCreateCmd.PersistentFlags().StringVarP(&conf.Description, "description", "D", "",
|
||||||
|
"Description of the form")
|
||||||
|
formCreateCmd.PersistentFlags().StringVarP(&conf.Notify, "notify", "n", "",
|
||||||
|
"Email address to get notified when consumer has uploaded files")
|
||||||
|
|
||||||
formCreateCmd.Aliases = append(formCreateCmd.Aliases, "add")
|
formCreateCmd.Aliases = append(formCreateCmd.Aliases, "add")
|
||||||
formCreateCmd.Aliases = append(formCreateCmd.Aliases, "+")
|
formCreateCmd.Aliases = append(formCreateCmd.Aliases, "+")
|
||||||
@@ -76,6 +80,37 @@ func FormCreateCommand(conf *cfg.Config) *cobra.Command {
|
|||||||
return formCreateCmd
|
return formCreateCmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func FormModifyCommand(conf *cfg.Config) *cobra.Command {
|
||||||
|
var formModifyCmd = &cobra.Command{
|
||||||
|
Use: "modify [options] <id>",
|
||||||
|
Short: "Modify a form",
|
||||||
|
Long: `Modify an existing form.`,
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
if len(args) == 0 {
|
||||||
|
return cmd.Help()
|
||||||
|
}
|
||||||
|
|
||||||
|
// errors at this stage do not cause the usage to be shown
|
||||||
|
cmd.SilenceUsage = true
|
||||||
|
|
||||||
|
return lib.Modify(os.Stdout, conf, args, common.TypeForm)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// options
|
||||||
|
formModifyCmd.PersistentFlags().StringVarP(&conf.Expire, "expire", "e", "",
|
||||||
|
"Expire setting: asap or duration (accepted shortcuts: dmh)")
|
||||||
|
formModifyCmd.PersistentFlags().StringVarP(&conf.Description, "description", "D", "",
|
||||||
|
"Description of the form")
|
||||||
|
formModifyCmd.PersistentFlags().StringVarP(&conf.Notify, "notify", "n", "",
|
||||||
|
"Email address to get notified when consumer has uploaded files")
|
||||||
|
|
||||||
|
formModifyCmd.Aliases = append(formModifyCmd.Aliases, "mod")
|
||||||
|
formModifyCmd.Aliases = append(formModifyCmd.Aliases, "change")
|
||||||
|
|
||||||
|
return formModifyCmd
|
||||||
|
}
|
||||||
|
|
||||||
func FormListCommand(conf *cfg.Config) *cobra.Command {
|
func FormListCommand(conf *cfg.Config) *cobra.Command {
|
||||||
var listCmd = &cobra.Command{
|
var listCmd = &cobra.Command{
|
||||||
Use: "list [options]",
|
Use: "list [options]",
|
||||||
|
|||||||
@@ -146,3 +146,32 @@ func DownloadCommand(conf *cfg.Config) *cobra.Command {
|
|||||||
|
|
||||||
return listCmd
|
return listCmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func ModifyCommand(conf *cfg.Config) *cobra.Command {
|
||||||
|
var uploadModifyCmd = &cobra.Command{
|
||||||
|
Use: "modify [options] <id>",
|
||||||
|
Short: "Modify an upload",
|
||||||
|
Long: `Modify an existing upload.`,
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
if len(args) == 0 {
|
||||||
|
return cmd.Help()
|
||||||
|
}
|
||||||
|
|
||||||
|
// errors at this stage do not cause the usage to be shown
|
||||||
|
cmd.SilenceUsage = true
|
||||||
|
|
||||||
|
return lib.Modify(os.Stdout, conf, args, common.TypeUpload)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// options
|
||||||
|
uploadModifyCmd.PersistentFlags().StringVarP(&conf.Expire, "expire", "e", "",
|
||||||
|
"Expire setting: asap or duration (accepted shortcuts: dmh)")
|
||||||
|
uploadModifyCmd.PersistentFlags().StringVarP(&conf.Description, "description", "D", "",
|
||||||
|
"Description of the upload")
|
||||||
|
|
||||||
|
uploadModifyCmd.Aliases = append(uploadModifyCmd.Aliases, "mod")
|
||||||
|
uploadModifyCmd.Aliases = append(uploadModifyCmd.Aliases, "change")
|
||||||
|
|
||||||
|
return uploadModifyCmd
|
||||||
|
}
|
||||||
|
|||||||
@@ -92,6 +92,9 @@ func Execute() {
|
|||||||
rootCmd.AddCommand(DeleteCommand(&conf))
|
rootCmd.AddCommand(DeleteCommand(&conf))
|
||||||
rootCmd.AddCommand(DescribeCommand(&conf))
|
rootCmd.AddCommand(DescribeCommand(&conf))
|
||||||
rootCmd.AddCommand(DownloadCommand(&conf))
|
rootCmd.AddCommand(DownloadCommand(&conf))
|
||||||
|
rootCmd.AddCommand(ModifyCommand(&conf))
|
||||||
|
|
||||||
|
// forms are being handled with its own subcommand
|
||||||
rootCmd.AddCommand(FormCommand(&conf))
|
rootCmd.AddCommand(FormCommand(&conf))
|
||||||
|
|
||||||
err := rootCmd.Execute()
|
err := rootCmd.Execute()
|
||||||
|
|||||||
@@ -357,6 +357,43 @@ func Download(w io.Writer, c *cfg.Config, args []string) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Modify(w io.Writer, c *cfg.Config, args []string, typ int) error {
|
||||||
|
id := args[0]
|
||||||
|
var rq *Request
|
||||||
|
|
||||||
|
// setup url, req.Request, timeout handling etc
|
||||||
|
switch typ {
|
||||||
|
case common.TypeUpload:
|
||||||
|
rq = Setup(c, "/uploads/"+id)
|
||||||
|
rq.R.
|
||||||
|
SetBody(&common.Upload{
|
||||||
|
Expire: c.Expire,
|
||||||
|
Description: c.Description,
|
||||||
|
})
|
||||||
|
case common.TypeForm:
|
||||||
|
rq = Setup(c, "/forms/"+id)
|
||||||
|
rq.R.
|
||||||
|
SetBody(&common.Form{
|
||||||
|
Expire: c.Expire,
|
||||||
|
Description: c.Description,
|
||||||
|
Notify: c.Notify,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// actual put w/ settings
|
||||||
|
resp, err := rq.R.Put(rq.Url)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := HandleResponse(c, resp); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return RespondExtended(w, resp)
|
||||||
|
}
|
||||||
|
|
||||||
/**** Forms stuff ****/
|
/**** Forms stuff ****/
|
||||||
func CreateForm(w io.Writer, c *cfg.Config) error {
|
func CreateForm(w io.Writer, c *cfg.Config) error {
|
||||||
// setup url, req.Request, timeout handling etc
|
// setup url, req.Request, timeout handling etc
|
||||||
|
|||||||
@@ -80,7 +80,7 @@ func WriteExtended(w io.Writer, response *common.Response) {
|
|||||||
for _, entry := range response.Uploads {
|
for _, entry := range response.Uploads {
|
||||||
expire := prepareExpire(entry.Expire, entry.Created)
|
expire := prepareExpire(entry.Expire, entry.Created)
|
||||||
fmt.Fprintf(w, format, "Upload-Id", entry.Id)
|
fmt.Fprintf(w, format, "Upload-Id", entry.Id)
|
||||||
fmt.Fprintf(w, format, "Description", entry.Id)
|
fmt.Fprintf(w, format, "Description", entry.Description)
|
||||||
fmt.Fprintf(w, format, "Expire", expire)
|
fmt.Fprintf(w, format, "Expire", expire)
|
||||||
fmt.Fprintf(w, format, "Context", entry.Context)
|
fmt.Fprintf(w, format, "Context", entry.Context)
|
||||||
fmt.Fprintf(w, format, "Created", entry.Created)
|
fmt.Fprintf(w, format, "Created", entry.Created)
|
||||||
|
|||||||
Reference in New Issue
Block a user