go-kimai/client/timesheet/post_api_timesheets_parameters.go
2023-01-17 12:34:18 +01:00

176 lines
4.9 KiB
Go

// Code generated by go-swagger; DO NOT EDIT.
package timesheet
// This file was generated by the swagger tool.
// Editing this file might prove futile when you re-run the swagger generate command
import (
"context"
"net/http"
"time"
"github.com/go-openapi/errors"
"github.com/go-openapi/runtime"
cr "github.com/go-openapi/runtime/client"
"github.com/go-openapi/strfmt"
"github.com/decentral1se/go-kimai/models"
)
// NewPostAPITimesheetsParams creates a new PostAPITimesheetsParams object,
// with the default timeout for this client.
//
// Default values are not hydrated, since defaults are normally applied by the API server side.
//
// To enforce default values in parameter, use SetDefaults or WithDefaults.
func NewPostAPITimesheetsParams() *PostAPITimesheetsParams {
return &PostAPITimesheetsParams{
timeout: cr.DefaultTimeout,
}
}
// NewPostAPITimesheetsParamsWithTimeout creates a new PostAPITimesheetsParams object
// with the ability to set a timeout on a request.
func NewPostAPITimesheetsParamsWithTimeout(timeout time.Duration) *PostAPITimesheetsParams {
return &PostAPITimesheetsParams{
timeout: timeout,
}
}
// NewPostAPITimesheetsParamsWithContext creates a new PostAPITimesheetsParams object
// with the ability to set a context for a request.
func NewPostAPITimesheetsParamsWithContext(ctx context.Context) *PostAPITimesheetsParams {
return &PostAPITimesheetsParams{
Context: ctx,
}
}
// NewPostAPITimesheetsParamsWithHTTPClient creates a new PostAPITimesheetsParams object
// with the ability to set a custom HTTPClient for a request.
func NewPostAPITimesheetsParamsWithHTTPClient(client *http.Client) *PostAPITimesheetsParams {
return &PostAPITimesheetsParams{
HTTPClient: client,
}
}
/*
PostAPITimesheetsParams contains all the parameters to send to the API endpoint
for the post API timesheets operation.
Typically these are written to a http.Request.
*/
type PostAPITimesheetsParams struct {
// Body.
Body *models.TimesheetEditForm
/* Full.
Allows to fetch fully serialized objects including subresources (TimesheetEntityExpanded). Allowed values: true (default: false)
*/
Full string
timeout time.Duration
Context context.Context
HTTPClient *http.Client
}
// WithDefaults hydrates default values in the post API timesheets params (not the query body).
//
// All values with no default are reset to their zero value.
func (o *PostAPITimesheetsParams) WithDefaults() *PostAPITimesheetsParams {
o.SetDefaults()
return o
}
// SetDefaults hydrates default values in the post API timesheets params (not the query body).
//
// All values with no default are reset to their zero value.
func (o *PostAPITimesheetsParams) SetDefaults() {
// no default values defined for this parameter
}
// WithTimeout adds the timeout to the post API timesheets params
func (o *PostAPITimesheetsParams) WithTimeout(timeout time.Duration) *PostAPITimesheetsParams {
o.SetTimeout(timeout)
return o
}
// SetTimeout adds the timeout to the post API timesheets params
func (o *PostAPITimesheetsParams) SetTimeout(timeout time.Duration) {
o.timeout = timeout
}
// WithContext adds the context to the post API timesheets params
func (o *PostAPITimesheetsParams) WithContext(ctx context.Context) *PostAPITimesheetsParams {
o.SetContext(ctx)
return o
}
// SetContext adds the context to the post API timesheets params
func (o *PostAPITimesheetsParams) SetContext(ctx context.Context) {
o.Context = ctx
}
// WithHTTPClient adds the HTTPClient to the post API timesheets params
func (o *PostAPITimesheetsParams) WithHTTPClient(client *http.Client) *PostAPITimesheetsParams {
o.SetHTTPClient(client)
return o
}
// SetHTTPClient adds the HTTPClient to the post API timesheets params
func (o *PostAPITimesheetsParams) SetHTTPClient(client *http.Client) {
o.HTTPClient = client
}
// WithBody adds the body to the post API timesheets params
func (o *PostAPITimesheetsParams) WithBody(body *models.TimesheetEditForm) *PostAPITimesheetsParams {
o.SetBody(body)
return o
}
// SetBody adds the body to the post API timesheets params
func (o *PostAPITimesheetsParams) SetBody(body *models.TimesheetEditForm) {
o.Body = body
}
// WithFull adds the full to the post API timesheets params
func (o *PostAPITimesheetsParams) WithFull(full string) *PostAPITimesheetsParams {
o.SetFull(full)
return o
}
// SetFull adds the full to the post API timesheets params
func (o *PostAPITimesheetsParams) SetFull(full string) {
o.Full = full
}
// WriteToRequest writes these params to a swagger request
func (o *PostAPITimesheetsParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error {
if err := r.SetTimeout(o.timeout); err != nil {
return err
}
var res []error
if o.Body != nil {
if err := r.SetBodyParam(o.Body); err != nil {
return err
}
}
// query param full
qrFull := o.Full
qFull := qrFull
if err := r.SetQueryParam("full", qFull); err != nil {
return err
}
if len(res) > 0 {
return errors.CompositeValidationError(res...)
}
return nil
}