324 lines
6.8 KiB
Go
324 lines
6.8 KiB
Go
package request
|
|
|
|
/*
|
|
Hello! This file is auto-generated from `docs/src/spec.json`.
|
|
|
|
For development:
|
|
In order to update the generated files, edit this file under the location,
|
|
add your struct fields, imports, API definitions and whatever you want, and:
|
|
|
|
1. run [spec](https://github.com/titpetric/spec) in the same folder,
|
|
2. run `./_gen.php` in this folder.
|
|
|
|
You may edit `trigger.go`, `trigger.util.go` or `trigger_test.go` to
|
|
implement your API calls, helper functions and tests. The file `trigger.go`
|
|
is only generated the first time, and will not be overwritten if it exists.
|
|
*/
|
|
|
|
import (
|
|
"io"
|
|
"strings"
|
|
|
|
"encoding/json"
|
|
"mime/multipart"
|
|
"net/http"
|
|
|
|
"github.com/go-chi/chi"
|
|
"github.com/pkg/errors"
|
|
|
|
"time"
|
|
)
|
|
|
|
var _ = chi.URLParam
|
|
var _ = multipart.FileHeader{}
|
|
|
|
// Trigger list request parameters
|
|
type TriggerList struct {
|
|
ModuleID uint64 `json:",string"`
|
|
Query string
|
|
Page uint
|
|
PerPage uint
|
|
NamespaceID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewTriggerList() *TriggerList {
|
|
return &TriggerList{}
|
|
}
|
|
|
|
func (tReq *TriggerList) Fill(r *http.Request) (err error) {
|
|
if strings.ToLower(r.Header.Get("content-type")) == "application/json" {
|
|
err = json.NewDecoder(r.Body).Decode(tReq)
|
|
|
|
switch {
|
|
case err == io.EOF:
|
|
err = nil
|
|
case err != nil:
|
|
return errors.Wrap(err, "error parsing http request body")
|
|
}
|
|
}
|
|
|
|
if err = r.ParseForm(); err != nil {
|
|
return err
|
|
}
|
|
|
|
get := map[string]string{}
|
|
post := map[string]string{}
|
|
urlQuery := r.URL.Query()
|
|
for name, param := range urlQuery {
|
|
get[name] = string(param[0])
|
|
}
|
|
postVars := r.Form
|
|
for name, param := range postVars {
|
|
post[name] = string(param[0])
|
|
}
|
|
|
|
if val, ok := get["moduleID"]; ok {
|
|
|
|
tReq.ModuleID = parseUInt64(val)
|
|
}
|
|
if val, ok := get["query"]; ok {
|
|
|
|
tReq.Query = val
|
|
}
|
|
if val, ok := get["page"]; ok {
|
|
|
|
tReq.Page = parseUint(val)
|
|
}
|
|
if val, ok := get["perPage"]; ok {
|
|
|
|
tReq.PerPage = parseUint(val)
|
|
}
|
|
tReq.NamespaceID = parseUInt64(chi.URLParam(r, "namespaceID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewTriggerList()
|
|
|
|
// Trigger create request parameters
|
|
type TriggerCreate struct {
|
|
ModuleID uint64 `json:",string"`
|
|
Name string
|
|
Actions []string
|
|
Enabled bool
|
|
Source string
|
|
UpdatedAt *time.Time
|
|
NamespaceID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewTriggerCreate() *TriggerCreate {
|
|
return &TriggerCreate{}
|
|
}
|
|
|
|
func (tReq *TriggerCreate) Fill(r *http.Request) (err error) {
|
|
if strings.ToLower(r.Header.Get("content-type")) == "application/json" {
|
|
err = json.NewDecoder(r.Body).Decode(tReq)
|
|
|
|
switch {
|
|
case err == io.EOF:
|
|
err = nil
|
|
case err != nil:
|
|
return errors.Wrap(err, "error parsing http request body")
|
|
}
|
|
}
|
|
|
|
if err = r.ParseForm(); err != nil {
|
|
return err
|
|
}
|
|
|
|
get := map[string]string{}
|
|
post := map[string]string{}
|
|
urlQuery := r.URL.Query()
|
|
for name, param := range urlQuery {
|
|
get[name] = string(param[0])
|
|
}
|
|
postVars := r.Form
|
|
for name, param := range postVars {
|
|
post[name] = string(param[0])
|
|
}
|
|
|
|
if val, ok := post["moduleID"]; ok {
|
|
|
|
tReq.ModuleID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["name"]; ok {
|
|
|
|
tReq.Name = val
|
|
}
|
|
if val, ok := post["enabled"]; ok {
|
|
|
|
tReq.Enabled = parseBool(val)
|
|
}
|
|
if val, ok := post["source"]; ok {
|
|
|
|
tReq.Source = val
|
|
}
|
|
if val, ok := post["updatedAt"]; ok {
|
|
|
|
if tReq.UpdatedAt, err = parseISODatePtrWithErr(val); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
tReq.NamespaceID = parseUInt64(chi.URLParam(r, "namespaceID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewTriggerCreate()
|
|
|
|
// Trigger read request parameters
|
|
type TriggerRead struct {
|
|
TriggerID uint64 `json:",string"`
|
|
NamespaceID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewTriggerRead() *TriggerRead {
|
|
return &TriggerRead{}
|
|
}
|
|
|
|
func (tReq *TriggerRead) Fill(r *http.Request) (err error) {
|
|
if strings.ToLower(r.Header.Get("content-type")) == "application/json" {
|
|
err = json.NewDecoder(r.Body).Decode(tReq)
|
|
|
|
switch {
|
|
case err == io.EOF:
|
|
err = nil
|
|
case err != nil:
|
|
return errors.Wrap(err, "error parsing http request body")
|
|
}
|
|
}
|
|
|
|
if err = r.ParseForm(); err != nil {
|
|
return err
|
|
}
|
|
|
|
get := map[string]string{}
|
|
post := map[string]string{}
|
|
urlQuery := r.URL.Query()
|
|
for name, param := range urlQuery {
|
|
get[name] = string(param[0])
|
|
}
|
|
postVars := r.Form
|
|
for name, param := range postVars {
|
|
post[name] = string(param[0])
|
|
}
|
|
|
|
tReq.TriggerID = parseUInt64(chi.URLParam(r, "triggerID"))
|
|
tReq.NamespaceID = parseUInt64(chi.URLParam(r, "namespaceID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewTriggerRead()
|
|
|
|
// Trigger update request parameters
|
|
type TriggerUpdate struct {
|
|
TriggerID uint64 `json:",string"`
|
|
NamespaceID uint64 `json:",string"`
|
|
ModuleID uint64 `json:",string"`
|
|
Name string
|
|
Actions []string
|
|
Enabled bool
|
|
Source string
|
|
}
|
|
|
|
func NewTriggerUpdate() *TriggerUpdate {
|
|
return &TriggerUpdate{}
|
|
}
|
|
|
|
func (tReq *TriggerUpdate) Fill(r *http.Request) (err error) {
|
|
if strings.ToLower(r.Header.Get("content-type")) == "application/json" {
|
|
err = json.NewDecoder(r.Body).Decode(tReq)
|
|
|
|
switch {
|
|
case err == io.EOF:
|
|
err = nil
|
|
case err != nil:
|
|
return errors.Wrap(err, "error parsing http request body")
|
|
}
|
|
}
|
|
|
|
if err = r.ParseForm(); err != nil {
|
|
return err
|
|
}
|
|
|
|
get := map[string]string{}
|
|
post := map[string]string{}
|
|
urlQuery := r.URL.Query()
|
|
for name, param := range urlQuery {
|
|
get[name] = string(param[0])
|
|
}
|
|
postVars := r.Form
|
|
for name, param := range postVars {
|
|
post[name] = string(param[0])
|
|
}
|
|
|
|
tReq.TriggerID = parseUInt64(chi.URLParam(r, "triggerID"))
|
|
tReq.NamespaceID = parseUInt64(chi.URLParam(r, "namespaceID"))
|
|
if val, ok := post["moduleID"]; ok {
|
|
|
|
tReq.ModuleID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["name"]; ok {
|
|
|
|
tReq.Name = val
|
|
}
|
|
if val, ok := post["enabled"]; ok {
|
|
|
|
tReq.Enabled = parseBool(val)
|
|
}
|
|
if val, ok := post["source"]; ok {
|
|
|
|
tReq.Source = val
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewTriggerUpdate()
|
|
|
|
// Trigger delete request parameters
|
|
type TriggerDelete struct {
|
|
TriggerID uint64 `json:",string"`
|
|
NamespaceID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewTriggerDelete() *TriggerDelete {
|
|
return &TriggerDelete{}
|
|
}
|
|
|
|
func (tReq *TriggerDelete) Fill(r *http.Request) (err error) {
|
|
if strings.ToLower(r.Header.Get("content-type")) == "application/json" {
|
|
err = json.NewDecoder(r.Body).Decode(tReq)
|
|
|
|
switch {
|
|
case err == io.EOF:
|
|
err = nil
|
|
case err != nil:
|
|
return errors.Wrap(err, "error parsing http request body")
|
|
}
|
|
}
|
|
|
|
if err = r.ParseForm(); err != nil {
|
|
return err
|
|
}
|
|
|
|
get := map[string]string{}
|
|
post := map[string]string{}
|
|
urlQuery := r.URL.Query()
|
|
for name, param := range urlQuery {
|
|
get[name] = string(param[0])
|
|
}
|
|
postVars := r.Form
|
|
for name, param := range postVars {
|
|
post[name] = string(param[0])
|
|
}
|
|
|
|
tReq.TriggerID = parseUInt64(chi.URLParam(r, "triggerID"))
|
|
tReq.NamespaceID = parseUInt64(chi.URLParam(r, "namespaceID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewTriggerDelete()
|