- more control over starting procedure, cli commands... - fix package paths - renaming symbols, comments, strings from Crust to Corteza
379 lines
8.1 KiB
Go
379 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 `webhooks.go`, `webhooks.util.go` or `webhooks_test.go` to
|
|
implement your API calls, helper functions and tests. The file `webhooks.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"
|
|
|
|
"github.com/cortezaproject/corteza-server/messaging/types"
|
|
)
|
|
|
|
var _ = chi.URLParam
|
|
var _ = multipart.FileHeader{}
|
|
|
|
// Webhooks list request parameters
|
|
type WebhooksList struct {
|
|
ChannelID uint64 `json:",string"`
|
|
UserID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewWebhooksList() *WebhooksList {
|
|
return &WebhooksList{}
|
|
}
|
|
|
|
func (r WebhooksList) Auditable() map[string]interface{} {
|
|
var out = map[string]interface{}{}
|
|
|
|
out["channelID"] = r.ChannelID
|
|
out["userID"] = r.UserID
|
|
|
|
return out
|
|
}
|
|
|
|
func (r *WebhooksList) 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["channelID"]; ok {
|
|
r.ChannelID = parseUInt64(val)
|
|
}
|
|
if val, ok := get["userID"]; ok {
|
|
r.UserID = parseUInt64(val)
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewWebhooksList()
|
|
|
|
// Webhooks create request parameters
|
|
type WebhooksCreate struct {
|
|
ChannelID uint64 `json:",string"`
|
|
Kind types.WebhookKind
|
|
UserID uint64 `json:",string"`
|
|
Trigger string
|
|
Url string
|
|
Username string
|
|
Avatar *multipart.FileHeader
|
|
AvatarURL string
|
|
}
|
|
|
|
func NewWebhooksCreate() *WebhooksCreate {
|
|
return &WebhooksCreate{}
|
|
}
|
|
|
|
func (r WebhooksCreate) Auditable() map[string]interface{} {
|
|
var out = map[string]interface{}{}
|
|
|
|
out["channelID"] = r.ChannelID
|
|
out["kind"] = r.Kind
|
|
out["userID"] = r.UserID
|
|
out["trigger"] = r.Trigger
|
|
out["url"] = r.Url
|
|
out["username"] = r.Username
|
|
out["avatar.size"] = r.Avatar.Size
|
|
out["avatar.filename"] = r.Avatar.Filename
|
|
|
|
out["avatarURL"] = r.AvatarURL
|
|
|
|
return out
|
|
}
|
|
|
|
func (r *WebhooksCreate) 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.ParseMultipartForm(32 << 20); 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["channelID"]; ok {
|
|
r.ChannelID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["kind"]; ok {
|
|
r.Kind = types.WebhookKind(val)
|
|
}
|
|
if val, ok := post["userID"]; ok {
|
|
r.UserID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["trigger"]; ok {
|
|
r.Trigger = val
|
|
}
|
|
if val, ok := post["url"]; ok {
|
|
r.Url = val
|
|
}
|
|
if val, ok := post["username"]; ok {
|
|
r.Username = val
|
|
}
|
|
if _, r.Avatar, err = req.FormFile("avatar"); err != nil {
|
|
return errors.Wrap(err, "error procesing uploaded file")
|
|
}
|
|
|
|
if val, ok := post["avatarURL"]; ok {
|
|
r.AvatarURL = val
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewWebhooksCreate()
|
|
|
|
// Webhooks update request parameters
|
|
type WebhooksUpdate struct {
|
|
WebhookID uint64 `json:",string"`
|
|
ChannelID uint64 `json:",string"`
|
|
Kind types.WebhookKind
|
|
UserID uint64 `json:",string"`
|
|
Trigger string
|
|
Url string
|
|
Username string
|
|
Avatar *multipart.FileHeader
|
|
AvatarURL string
|
|
}
|
|
|
|
func NewWebhooksUpdate() *WebhooksUpdate {
|
|
return &WebhooksUpdate{}
|
|
}
|
|
|
|
func (r WebhooksUpdate) Auditable() map[string]interface{} {
|
|
var out = map[string]interface{}{}
|
|
|
|
out["webhookID"] = r.WebhookID
|
|
out["channelID"] = r.ChannelID
|
|
out["kind"] = r.Kind
|
|
out["userID"] = r.UserID
|
|
out["trigger"] = r.Trigger
|
|
out["url"] = r.Url
|
|
out["username"] = r.Username
|
|
out["avatar.size"] = r.Avatar.Size
|
|
out["avatar.filename"] = r.Avatar.Filename
|
|
|
|
out["avatarURL"] = r.AvatarURL
|
|
|
|
return out
|
|
}
|
|
|
|
func (r *WebhooksUpdate) 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.ParseMultipartForm(32 << 20); 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.WebhookID = parseUInt64(chi.URLParam(req, "webhookID"))
|
|
if val, ok := post["channelID"]; ok {
|
|
r.ChannelID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["kind"]; ok {
|
|
r.Kind = types.WebhookKind(val)
|
|
}
|
|
if val, ok := post["userID"]; ok {
|
|
r.UserID = parseUInt64(val)
|
|
}
|
|
if val, ok := post["trigger"]; ok {
|
|
r.Trigger = val
|
|
}
|
|
if val, ok := post["url"]; ok {
|
|
r.Url = val
|
|
}
|
|
if val, ok := post["username"]; ok {
|
|
r.Username = val
|
|
}
|
|
if _, r.Avatar, err = req.FormFile("avatar"); err != nil {
|
|
return errors.Wrap(err, "error procesing uploaded file")
|
|
}
|
|
|
|
if val, ok := post["avatarURL"]; ok {
|
|
r.AvatarURL = val
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewWebhooksUpdate()
|
|
|
|
// Webhooks get request parameters
|
|
type WebhooksGet struct {
|
|
WebhookID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewWebhooksGet() *WebhooksGet {
|
|
return &WebhooksGet{}
|
|
}
|
|
|
|
func (r WebhooksGet) Auditable() map[string]interface{} {
|
|
var out = map[string]interface{}{}
|
|
|
|
out["webhookID"] = r.WebhookID
|
|
|
|
return out
|
|
}
|
|
|
|
func (r *WebhooksGet) 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.WebhookID = parseUInt64(chi.URLParam(req, "webhookID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewWebhooksGet()
|
|
|
|
// Webhooks delete request parameters
|
|
type WebhooksDelete struct {
|
|
WebhookID uint64 `json:",string"`
|
|
}
|
|
|
|
func NewWebhooksDelete() *WebhooksDelete {
|
|
return &WebhooksDelete{}
|
|
}
|
|
|
|
func (r WebhooksDelete) Auditable() map[string]interface{} {
|
|
var out = map[string]interface{}{}
|
|
|
|
out["webhookID"] = r.WebhookID
|
|
|
|
return out
|
|
}
|
|
|
|
func (r *WebhooksDelete) 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.WebhookID = parseUInt64(chi.URLParam(req, "webhookID"))
|
|
|
|
return err
|
|
}
|
|
|
|
var _ RequestFiller = NewWebhooksDelete()
|