mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-04 04:02:25 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			152 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2015 go-swagger maintainers
 | 
						|
//
 | 
						|
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
// you may not use this file except in compliance with the License.
 | 
						|
// You may obtain a copy of the License at
 | 
						|
//
 | 
						|
//    http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
//
 | 
						|
// Unless required by applicable law or agreed to in writing, software
 | 
						|
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
// See the License for the specific language governing permissions and
 | 
						|
// limitations under the License.
 | 
						|
 | 
						|
package runtime
 | 
						|
 | 
						|
import (
 | 
						|
	"io"
 | 
						|
	"net/http"
 | 
						|
	"net/url"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/go-openapi/strfmt"
 | 
						|
)
 | 
						|
 | 
						|
// ClientRequestWriterFunc converts a function to a request writer interface
 | 
						|
type ClientRequestWriterFunc func(ClientRequest, strfmt.Registry) error
 | 
						|
 | 
						|
// WriteToRequest adds data to the request
 | 
						|
func (fn ClientRequestWriterFunc) WriteToRequest(req ClientRequest, reg strfmt.Registry) error {
 | 
						|
	return fn(req, reg)
 | 
						|
}
 | 
						|
 | 
						|
// ClientRequestWriter is an interface for things that know how to write to a request
 | 
						|
type ClientRequestWriter interface {
 | 
						|
	WriteToRequest(ClientRequest, strfmt.Registry) error
 | 
						|
}
 | 
						|
 | 
						|
// ClientRequest is an interface for things that know how to
 | 
						|
// add information to a swagger client request.
 | 
						|
type ClientRequest interface { //nolint:interfacebloat // a swagger-capable request is quite rich, hence the many getter/setters
 | 
						|
	SetHeaderParam(string, ...string) error
 | 
						|
 | 
						|
	GetHeaderParams() http.Header
 | 
						|
 | 
						|
	SetQueryParam(string, ...string) error
 | 
						|
 | 
						|
	SetFormParam(string, ...string) error
 | 
						|
 | 
						|
	SetPathParam(string, string) error
 | 
						|
 | 
						|
	GetQueryParams() url.Values
 | 
						|
 | 
						|
	SetFileParam(string, ...NamedReadCloser) error
 | 
						|
 | 
						|
	SetBodyParam(interface{}) error
 | 
						|
 | 
						|
	SetTimeout(time.Duration) error
 | 
						|
 | 
						|
	GetMethod() string
 | 
						|
 | 
						|
	GetPath() string
 | 
						|
 | 
						|
	GetBody() []byte
 | 
						|
 | 
						|
	GetBodyParam() interface{}
 | 
						|
 | 
						|
	GetFileParam() map[string][]NamedReadCloser
 | 
						|
}
 | 
						|
 | 
						|
// NamedReadCloser represents a named ReadCloser interface
 | 
						|
type NamedReadCloser interface {
 | 
						|
	io.ReadCloser
 | 
						|
	Name() string
 | 
						|
}
 | 
						|
 | 
						|
// NamedReader creates a NamedReadCloser for use as file upload
 | 
						|
func NamedReader(name string, rdr io.Reader) NamedReadCloser {
 | 
						|
	rc, ok := rdr.(io.ReadCloser)
 | 
						|
	if !ok {
 | 
						|
		rc = io.NopCloser(rdr)
 | 
						|
	}
 | 
						|
	return &namedReadCloser{
 | 
						|
		name: name,
 | 
						|
		cr:   rc,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
type namedReadCloser struct {
 | 
						|
	name string
 | 
						|
	cr   io.ReadCloser
 | 
						|
}
 | 
						|
 | 
						|
func (n *namedReadCloser) Close() error {
 | 
						|
	return n.cr.Close()
 | 
						|
}
 | 
						|
func (n *namedReadCloser) Read(p []byte) (int, error) {
 | 
						|
	return n.cr.Read(p)
 | 
						|
}
 | 
						|
func (n *namedReadCloser) Name() string {
 | 
						|
	return n.name
 | 
						|
}
 | 
						|
 | 
						|
type TestClientRequest struct {
 | 
						|
	Headers http.Header
 | 
						|
	Body    interface{}
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) SetHeaderParam(name string, values ...string) error {
 | 
						|
	if t.Headers == nil {
 | 
						|
		t.Headers = make(http.Header)
 | 
						|
	}
 | 
						|
	t.Headers.Set(name, values[0])
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) SetQueryParam(_ string, _ ...string) error { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) SetFormParam(_ string, _ ...string) error { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) SetPathParam(_ string, _ string) error { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) SetFileParam(_ string, _ ...NamedReadCloser) error { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) SetBodyParam(body interface{}) error {
 | 
						|
	t.Body = body
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) SetTimeout(time.Duration) error {
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) GetQueryParams() url.Values { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) GetMethod() string { return "" }
 | 
						|
 | 
						|
func (t *TestClientRequest) GetPath() string { return "" }
 | 
						|
 | 
						|
func (t *TestClientRequest) GetBody() []byte { return nil }
 | 
						|
 | 
						|
func (t *TestClientRequest) GetBodyParam() interface{} {
 | 
						|
	return t.Body
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) GetFileParam() map[string][]NamedReadCloser {
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (t *TestClientRequest) GetHeaderParams() http.Header {
 | 
						|
	return t.Headers
 | 
						|
}
 |