debian-forge-composer/vendor/github.com/osbuild/pulp-client/pulpclient/api_content.go
Achilleas Koutsou bc6c2fb6af upload: define new pulp uploader
Define a basic client struct to pull in the pulp-client library.
2023-10-18 21:14:46 +02:00

250 lines
9.8 KiB
Go

/*
Pulp 3 API
Fetch, Upload, Organize, and Distribute Software Packages
API version: v3
Contact: pulp-list@redhat.com
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package pulpclient
import (
"bytes"
"context"
"io"
"net/http"
"net/url"
"reflect"
)
// ContentAPIService ContentAPI service
type ContentAPIService service
type ContentAPIContentListRequest struct {
ctx context.Context
ApiService *ContentAPIService
limit *int32
offset *int32
ordering *[]string
pulpHrefIn *[]string
pulpIdIn *[]string
pulpTypeIn *[]string
repositoryVersion *string
repositoryVersionAdded *string
repositoryVersionRemoved *string
fields *[]string
excludeFields *[]string
}
// Number of results to return per page.
func (r ContentAPIContentListRequest) Limit(limit int32) ContentAPIContentListRequest {
r.limit = &limit
return r
}
// The initial index from which to return the results.
func (r ContentAPIContentListRequest) Offset(offset int32) ContentAPIContentListRequest {
r.offset = &offset
return r
}
// Ordering * `pk` - Pk * `-pk` - Pk (descending)
func (r ContentAPIContentListRequest) Ordering(ordering []string) ContentAPIContentListRequest {
r.ordering = &ordering
return r
}
// Multiple values may be separated by commas.
func (r ContentAPIContentListRequest) PulpHrefIn(pulpHrefIn []string) ContentAPIContentListRequest {
r.pulpHrefIn = &pulpHrefIn
return r
}
// Multiple values may be separated by commas.
func (r ContentAPIContentListRequest) PulpIdIn(pulpIdIn []string) ContentAPIContentListRequest {
r.pulpIdIn = &pulpIdIn
return r
}
// Pulp type is in * `core.publishedmetadata` - core.publishedmetadata * `ansible.role` - ansible.role * `ansible.collection_version` - ansible.collection_version * `ansible.collection_mark` - ansible.collection_mark * `ansible.collection_signature` - ansible.collection_signature * `ansible.namespace` - ansible.namespace * `ansible.collection_deprecation` - ansible.collection_deprecation * `container.blob` - container.blob * `container.manifest` - container.manifest * `container.tag` - container.tag * `container.signature` - container.signature * `deb.package` - deb.package * `deb.installer_package` - deb.installer_package * `deb.generic` - deb.generic * `deb.release` - deb.release * `deb.release_architecture` - deb.release_architecture * `deb.release_component` - deb.release_component * `deb.package_release_component` - deb.package_release_component * `deb.release_file` - deb.release_file * `deb.package_index` - deb.package_index * `deb.installer_file_index` - deb.installer_file_index * `file.file` - file.file * `gem.shallow-gem` - gem.shallow-gem * `gem.gem` - gem.gem * `maven.artifact` - maven.artifact * `maven.metadata` - maven.metadata * `ostree.object` - ostree.object * `ostree.commit` - ostree.commit * `ostree.refs` - ostree.refs * `ostree.content` - ostree.content * `ostree.config` - ostree.config * `ostree.summary` - ostree.summary * `python.python` - python.python * `rpm.advisory` - rpm.advisory * `rpm.packagegroup` - rpm.packagegroup * `rpm.packagecategory` - rpm.packagecategory * `rpm.packageenvironment` - rpm.packageenvironment * `rpm.packagelangpacks` - rpm.packagelangpacks * `rpm.repo_metadata_file` - rpm.repo_metadata_file * `rpm.distribution_tree` - rpm.distribution_tree * `rpm.package` - rpm.package * `rpm.modulemd` - rpm.modulemd * `rpm.modulemd_defaults` - rpm.modulemd_defaults * `rpm.modulemd_obsolete` - rpm.modulemd_obsolete
func (r ContentAPIContentListRequest) PulpTypeIn(pulpTypeIn []string) ContentAPIContentListRequest {
r.pulpTypeIn = &pulpTypeIn
return r
}
// Repository Version referenced by HREF
func (r ContentAPIContentListRequest) RepositoryVersion(repositoryVersion string) ContentAPIContentListRequest {
r.repositoryVersion = &repositoryVersion
return r
}
// Repository Version referenced by HREF
func (r ContentAPIContentListRequest) RepositoryVersionAdded(repositoryVersionAdded string) ContentAPIContentListRequest {
r.repositoryVersionAdded = &repositoryVersionAdded
return r
}
// Repository Version referenced by HREF
func (r ContentAPIContentListRequest) RepositoryVersionRemoved(repositoryVersionRemoved string) ContentAPIContentListRequest {
r.repositoryVersionRemoved = &repositoryVersionRemoved
return r
}
// A list of fields to include in the response.
func (r ContentAPIContentListRequest) Fields(fields []string) ContentAPIContentListRequest {
r.fields = &fields
return r
}
// A list of fields to exclude from the response.
func (r ContentAPIContentListRequest) ExcludeFields(excludeFields []string) ContentAPIContentListRequest {
r.excludeFields = &excludeFields
return r
}
func (r ContentAPIContentListRequest) Execute() (*PaginatedMultipleArtifactContentResponseList, *http.Response, error) {
return r.ApiService.ContentListExecute(r)
}
/*
ContentList List content
Endpoint to list all content.
@param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background().
@return ContentAPIContentListRequest
*/
func (a *ContentAPIService) ContentList(ctx context.Context) ContentAPIContentListRequest {
return ContentAPIContentListRequest{
ApiService: a,
ctx: ctx,
}
}
// Execute executes the request
// @return PaginatedMultipleArtifactContentResponseList
func (a *ContentAPIService) ContentListExecute(r ContentAPIContentListRequest) (*PaginatedMultipleArtifactContentResponseList, *http.Response, error) {
var (
localVarHTTPMethod = http.MethodGet
localVarPostBody interface{}
formFiles []formFile
localVarReturnValue *PaginatedMultipleArtifactContentResponseList
)
localBasePath, err := a.client.cfg.ServerURLWithContext(r.ctx, "ContentAPIService.ContentList")
if err != nil {
return localVarReturnValue, nil, &GenericOpenAPIError{error: err.Error()}
}
localVarPath := localBasePath + "/pulp/api/v3/content/"
localVarHeaderParams := make(map[string]string)
localVarQueryParams := url.Values{}
localVarFormParams := url.Values{}
if r.limit != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "limit", r.limit, "")
}
if r.offset != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "offset", r.offset, "")
}
if r.ordering != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "ordering", r.ordering, "csv")
}
if r.pulpHrefIn != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "pulp_href__in", r.pulpHrefIn, "csv")
}
if r.pulpIdIn != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "pulp_id__in", r.pulpIdIn, "csv")
}
if r.pulpTypeIn != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "pulp_type__in", r.pulpTypeIn, "csv")
}
if r.repositoryVersion != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "repository_version", r.repositoryVersion, "")
}
if r.repositoryVersionAdded != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "repository_version_added", r.repositoryVersionAdded, "")
}
if r.repositoryVersionRemoved != nil {
parameterAddToHeaderOrQuery(localVarQueryParams, "repository_version_removed", r.repositoryVersionRemoved, "")
}
if r.fields != nil {
t := *r.fields
if reflect.TypeOf(t).Kind() == reflect.Slice {
s := reflect.ValueOf(t)
for i := 0; i < s.Len(); i++ {
parameterAddToHeaderOrQuery(localVarQueryParams, "fields", s.Index(i), "multi")
}
} else {
parameterAddToHeaderOrQuery(localVarQueryParams, "fields", t, "multi")
}
}
if r.excludeFields != nil {
t := *r.excludeFields
if reflect.TypeOf(t).Kind() == reflect.Slice {
s := reflect.ValueOf(t)
for i := 0; i < s.Len(); i++ {
parameterAddToHeaderOrQuery(localVarQueryParams, "exclude_fields", s.Index(i), "multi")
}
} else {
parameterAddToHeaderOrQuery(localVarQueryParams, "exclude_fields", t, "multi")
}
}
// to determine the Content-Type header
localVarHTTPContentTypes := []string{}
// set Content-Type header
localVarHTTPContentType := selectHeaderContentType(localVarHTTPContentTypes)
if localVarHTTPContentType != "" {
localVarHeaderParams["Content-Type"] = localVarHTTPContentType
}
// to determine the Accept header
localVarHTTPHeaderAccepts := []string{"application/json"}
// set Accept header
localVarHTTPHeaderAccept := selectHeaderAccept(localVarHTTPHeaderAccepts)
if localVarHTTPHeaderAccept != "" {
localVarHeaderParams["Accept"] = localVarHTTPHeaderAccept
}
req, err := a.client.prepareRequest(r.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, formFiles)
if err != nil {
return localVarReturnValue, nil, err
}
localVarHTTPResponse, err := a.client.callAPI(req)
if err != nil || localVarHTTPResponse == nil {
return localVarReturnValue, localVarHTTPResponse, err
}
localVarBody, err := io.ReadAll(localVarHTTPResponse.Body)
localVarHTTPResponse.Body.Close()
localVarHTTPResponse.Body = io.NopCloser(bytes.NewBuffer(localVarBody))
if err != nil {
return localVarReturnValue, localVarHTTPResponse, err
}
if localVarHTTPResponse.StatusCode >= 300 {
newErr := &GenericOpenAPIError{
body: localVarBody,
error: localVarHTTPResponse.Status,
}
return localVarReturnValue, localVarHTTPResponse, newErr
}
err = a.client.decode(&localVarReturnValue, localVarBody, localVarHTTPResponse.Header.Get("Content-Type"))
if err != nil {
newErr := &GenericOpenAPIError{
body: localVarBody,
error: err.Error(),
}
return localVarReturnValue, localVarHTTPResponse, newErr
}
return localVarReturnValue, localVarHTTPResponse, nil
}