3
0

380 lines
8.1 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 (r TriggerList) Auditable() map[string]interface{} {
var out = map[string]interface{}{}
out["moduleID"] = r.ModuleID
out["query"] = r.Query
out["page"] = r.Page
out["perPage"] = r.PerPage
out["namespaceID"] = r.NamespaceID
return out
}
func (r *TriggerList) Fill(req *http.Request) (err error) {
if strings.ToLower(req.Header.Get("content-type")) == "application/json" {
err = json.NewDecoder(req.Body).Decode(r)
switch {
case err == io.EOF:
err = nil
case err != nil:
return errors.Wrap(err, "error parsing http request body")
}
}
if err = req.ParseForm(); err != nil {
return err
}
get := map[string]string{}
post := map[string]string{}
urlQuery := req.URL.Query()
for name, param := range urlQuery {
get[name] = string(param[0])
}
postVars := req.Form
for name, param := range postVars {
post[name] = string(param[0])
}
if val, ok := get["moduleID"]; ok {
r.ModuleID = parseUInt64(val)
}
if val, ok := get["query"]; ok {
r.Query = val
}
if val, ok := get["page"]; ok {
r.Page = parseUint(val)
}
if val, ok := get["perPage"]; ok {
r.PerPage = parseUint(val)
}
r.NamespaceID = parseUInt64(chi.URLParam(req, "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 (r TriggerCreate) Auditable() map[string]interface{} {
var out = map[string]interface{}{}
out["moduleID"] = r.ModuleID
out["name"] = r.Name
out["actions"] = r.Actions
out["enabled"] = r.Enabled
out["source"] = r.Source
out["updatedAt"] = r.UpdatedAt
out["namespaceID"] = r.NamespaceID
return out
}
func (r *TriggerCreate) Fill(req *http.Request) (err error) {
if strings.ToLower(req.Header.Get("content-type")) == "application/json" {
err = json.NewDecoder(req.Body).Decode(r)
switch {
case err == io.EOF:
err = nil
case err != nil:
return errors.Wrap(err, "error parsing http request body")
}
}
if err = req.ParseForm(); err != nil {
return err
}
get := map[string]string{}
post := map[string]string{}
urlQuery := req.URL.Query()
for name, param := range urlQuery {
get[name] = string(param[0])
}
postVars := req.Form
for name, param := range postVars {
post[name] = string(param[0])
}
if val, ok := post["moduleID"]; ok {
r.ModuleID = parseUInt64(val)
}
if val, ok := post["name"]; ok {
r.Name = val
}
if val, ok := req.Form["actions"]; ok {
r.Actions = parseStrings(val)
}
if val, ok := post["enabled"]; ok {
r.Enabled = parseBool(val)
}
if val, ok := post["source"]; ok {
r.Source = val
}
if val, ok := post["updatedAt"]; ok {
if r.UpdatedAt, err = parseISODatePtrWithErr(val); err != nil {
return err
}
}
r.NamespaceID = parseUInt64(chi.URLParam(req, "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 (r TriggerRead) Auditable() map[string]interface{} {
var out = map[string]interface{}{}
out["triggerID"] = r.TriggerID
out["namespaceID"] = r.NamespaceID
return out
}
func (r *TriggerRead) Fill(req *http.Request) (err error) {
if strings.ToLower(req.Header.Get("content-type")) == "application/json" {
err = json.NewDecoder(req.Body).Decode(r)
switch {
case err == io.EOF:
err = nil
case err != nil:
return errors.Wrap(err, "error parsing http request body")
}
}
if err = req.ParseForm(); err != nil {
return err
}
get := map[string]string{}
post := map[string]string{}
urlQuery := req.URL.Query()
for name, param := range urlQuery {
get[name] = string(param[0])
}
postVars := req.Form
for name, param := range postVars {
post[name] = string(param[0])
}
r.TriggerID = parseUInt64(chi.URLParam(req, "triggerID"))
r.NamespaceID = parseUInt64(chi.URLParam(req, "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 (r TriggerUpdate) Auditable() map[string]interface{} {
var out = map[string]interface{}{}
out["triggerID"] = r.TriggerID
out["namespaceID"] = r.NamespaceID
out["moduleID"] = r.ModuleID
out["name"] = r.Name
out["actions"] = r.Actions
out["enabled"] = r.Enabled
out["source"] = r.Source
return out
}
func (r *TriggerUpdate) Fill(req *http.Request) (err error) {
if strings.ToLower(req.Header.Get("content-type")) == "application/json" {
err = json.NewDecoder(req.Body).Decode(r)
switch {
case err == io.EOF:
err = nil
case err != nil:
return errors.Wrap(err, "error parsing http request body")
}
}
if err = req.ParseForm(); err != nil {
return err
}
get := map[string]string{}
post := map[string]string{}
urlQuery := req.URL.Query()
for name, param := range urlQuery {
get[name] = string(param[0])
}
postVars := req.Form
for name, param := range postVars {
post[name] = string(param[0])
}
r.TriggerID = parseUInt64(chi.URLParam(req, "triggerID"))
r.NamespaceID = parseUInt64(chi.URLParam(req, "namespaceID"))
if val, ok := post["moduleID"]; ok {
r.ModuleID = parseUInt64(val)
}
if val, ok := post["name"]; ok {
r.Name = val
}
if val, ok := req.Form["actions"]; ok {
r.Actions = parseStrings(val)
}
if val, ok := post["enabled"]; ok {
r.Enabled = parseBool(val)
}
if val, ok := post["source"]; ok {
r.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 (r TriggerDelete) Auditable() map[string]interface{} {
var out = map[string]interface{}{}
out["triggerID"] = r.TriggerID
out["namespaceID"] = r.NamespaceID
return out
}
func (r *TriggerDelete) Fill(req *http.Request) (err error) {
if strings.ToLower(req.Header.Get("content-type")) == "application/json" {
err = json.NewDecoder(req.Body).Decode(r)
switch {
case err == io.EOF:
err = nil
case err != nil:
return errors.Wrap(err, "error parsing http request body")
}
}
if err = req.ParseForm(); err != nil {
return err
}
get := map[string]string{}
post := map[string]string{}
urlQuery := req.URL.Query()
for name, param := range urlQuery {
get[name] = string(param[0])
}
postVars := req.Form
for name, param := range postVars {
post[name] = string(param[0])
}
r.TriggerID = parseUInt64(chi.URLParam(req, "triggerID"))
r.NamespaceID = parseUInt64(chi.URLParam(req, "namespaceID"))
return err
}
var _ RequestFiller = NewTriggerDelete()