Fix GetArchive

Pass a writer to stream out the content of the archive.
Support for multiple `path` by splitting the path parameter by comma.
Add an optional parameter `apibasepath` that replaces the default base path `/api/1.0` as at least as seen in the wild, this base URL is different.
This commit is contained in:
Hugues Malphettes 2019-04-17 10:01:47 +08:00 committed by George Fleury
parent eb18f6f5ac
commit 47e160ef65

View File

@ -8,6 +8,7 @@ import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"io" "io"
"io/ioutil"
"net/url" "net/url"
"strings" "strings"
@ -3267,16 +3268,20 @@ func (a *DefaultApiService) GetApplicationProperties() (*APIResponse, error) {
/* /*
DefaultApiService DefaultApiService
Streams an archive of the repository's contents at the requested commit. If no <code>at=</code> commit is requested, an archive of the default branch is streamed. <p> The <code>filename=</code> query parameter may be used to specify the exact filename to include in the <code>\"Content-Disposition\"</code> header. If an explicit filename is not provided, one will be automatically generated based on what is being archived. Its format depends on the <code>at=</code> value: <ul> <li>No <code>at=</code> commit: <code><slug>-<default-branch-name>@<commit>.<format></code>; e.g. example-master@43c2f8a0fe8.zip</li> <li><code>at=sha</code>: <code><slug>-<at>.<format></code>; e.g. example-09bcbb00100cfbb5310fb6834a1d5ce6cac253e9.tar.gz</li> <li><code>at=branchOrTag</code>: <code><slug>-<branchOrTag>@<commit>.<format></code>; e.g. example-feature@bbb225f16e1.tar <ul> <li>If the branch or tag is qualified (e.g. <code>refs/heads/master</code>, the short name (<code>master</code>) will be included in the filename</li> <li>If the branch or tag's <i>short name</i> includes slashes (e.g. <code>release/4.6</code>), they will be converted to hyphens in the filename (<code>release-4.5</code>)</li> </ul> </li> </ul> <p> Archives may be requested in the following formats by adding the <code>format=</code> query parameter: <ul> <li><code>zip</code>: A zip file using standard compression (Default)</li> <li><code>tar</code>: An uncompressed tarball</li> <li><code>tar.gz</code> or <code>tgz</code>: A GZip-compressed tarball</li> </ul> The contents of the archive may be filtered by using the <code>path=</code> query parameter to specify paths to include. <code>path=</code> may be specified multiple times to include multiple paths. <p> The <code>prefix=</code> query parameter may be used to define a directory (or multiple directories) where the archive's contents should be placed. If the prefix does not end with <code>/</code>, one will be added automatically. The prefix is <i>always</i> treated as a directory; it is not possible to use it to prepend characters to the entries in the archive. <p> Archives of public repositories may be streamed by any authenticated or anonymous user. Streaming archives for non-public repositories requires an <i>authenticated user</i> with at least <b>REPO_READ</b> permission. Streams an archive of the repository's contents at the requested commit. If no <code>at=</code> commit is requested, an archive of the default branch is streamed. <p> The <code>filename=</code> query parameter may be used to specify the exact filename to include in the <code>\"Content-Disposition\"</code> header. If an explicit filename is not provided, one will be automatically generated based on what is being archived. Its format depends on the <code>at=</code> value: <ul> <li>No <code>at=</code> commit: <code><slug>-<default-branch-name>@<commit>.<format></code>; e.g. example-master@43c2f8a0fe8.zip</li> <li><code>at=sha</code>: <code><slug>-<at>.<format></code>; e.g. example-09bcbb00100cfbb5310fb6834a1d5ce6cac253e9.tar.gz</li> <li><code>at=branchOrTag</code>: <code><slug>-<branchOrTag>@<commit>.<format></code>; e.g. example-feature@bbb225f16e1.tar <ul> <li>If the branch or tag is qualified (e.g. <code>refs/heads/master</code>, the short name (<code>master</code>) will be included in the filename</li> <li>If the branch or tag's <i>short name</i> includes slashes (e.g. <code>release/4.6</code>), they will be converted to hyphens in the filename (<code>release-4.5</code>)</li> </ul> </li> </ul> <p> Archives may be requested in the following formats by adding the <code>format=</code> query parameter: <ul> <li><code>zip</code>: A zip file using standard compression (Default)</li> <li><code>tar</code>: An uncompressed tarball</li> <li><code>tar.gz</code> or <code>tgz</code>: A GZip-compressed tarball</li> </ul> The contents of the archive may be filtered by using the <code>path=</code> query parameter to specify paths to include. <code>path=</code> may be specified multiple times to include multiple paths. <p> The <code>prefix=</code> query parameter may be used to define a directory (or multiple directories) where the archive's contents should be placed. If the prefix does not end with <code>/</code>, one will be added automatically. The prefix is <i>always</i> treated as a directory; it is not possible to use it to prepend characters to the entries in the archive. <p> Archives of public repositories may be streamed by any authenticated or anonymous user. Streaming archives for non-public repositories requires an <i>authenticated user</i> with at least <b>REPO_READ</b> permission.
* @param ctx context.Context for authentication, logging, tracing, etc.
@param optional (nil or map[string]interface{}) with one or more of: @param optional (nil or map[string]interface{}) with one or more of:
@param "at" (string) the commit to stream an archive of; if not supplied, an archive of the default branch is streamed @param "at" (string) the commit to stream an archive of; if not supplied, an archive of the default branch is streamed
@param "filename" (string) a filename to include the \"Content-Disposition\" header @param "filename" (string) a filename to include the \"Content-Disposition\" header
@param "format" (string) the format to stream the archive in; must be one of: zip, tar, tar.gz or tgz @param "format" (string) the format to stream the archive in; must be one of: zip, tar, tar.gz or tgz
@param "path" (string) paths to include in the streamed archive; may be repeated to include multiple paths @param "path" (string) paths to include in the streamed archive; may be repeated to include multiple paths
@param "prefix" (string) a prefix to apply to all entries in the streamed archive; if the supplied prefix does not end with a trailing <code>/</code>, one will be added automatically @param "prefix" (string) a prefix to apply to all entries in the streamed archive; if the supplied prefix does not end with a trailing <code>/</code>, one will be added automatically
@return @param "apibasepath" (string) defaults to "/api/1.0" - in some installations, the value is "/archive/latest". Used as part of the URL endpoint. Not used as an actual parameter
@param writer Where the archive's content is streamed out.
@return the size of the archive written out
*/ */
func (a *DefaultApiService) GetArchive(project, repository string, localVarOptionals map[string]interface{}) (*APIResponse, error) { func (a *DefaultApiService) GetArchive(project, repository string, localVarOptionals map[string]interface{}, writer io.Writer) (int64, error) {
var ( var (
localVarHTTPMethod = strings.ToUpper("Get") localVarHTTPMethod = strings.ToUpper("Get")
localVarPostBody interface{} localVarPostBody interface{}
@ -3285,7 +3290,16 @@ func (a *DefaultApiService) GetArchive(project, repository string, localVarOptio
) )
// create path and map variables // create path and map variables
localVarPath := a.client.cfg.BasePath + "/api/1.0/projects/{projectKey}/repos/{repositorySlug}/archive" if err := typeCheckParameter(localVarOptionals["apibasepath"], "string", "apibasepath"); err != nil {
return 0, err
}
apibasepath, _ := localVarOptionals["apibasepath"].(string)
if apibasepath == "" {
apibasepath = "/api/1.0"
}
//localVarPath := a.client.cfg.BasePath + "/api/1.0/projects/{projectKey}/repos/{repositorySlug}/archive"
localVarPath := a.client.cfg.BasePath + apibasepath + "/projects/{projectKey}/repos/{repositorySlug}/archive"
localVarPath = strings.Replace(localVarPath, "{"+"projectKey"+"}", fmt.Sprintf("%v", project), -1) localVarPath = strings.Replace(localVarPath, "{"+"projectKey"+"}", fmt.Sprintf("%v", project), -1)
localVarPath = strings.Replace(localVarPath, "{"+"repositorySlug"+"}", fmt.Sprintf("%v", repository), -1) localVarPath = strings.Replace(localVarPath, "{"+"repositorySlug"+"}", fmt.Sprintf("%v", repository), -1)
@ -3294,19 +3308,19 @@ func (a *DefaultApiService) GetArchive(project, repository string, localVarOptio
localVarFormParams := url.Values{} localVarFormParams := url.Values{}
if err := typeCheckParameter(localVarOptionals["at"], "string", "at"); err != nil { if err := typeCheckParameter(localVarOptionals["at"], "string", "at"); err != nil {
return nil, err return 0, err
} }
if err := typeCheckParameter(localVarOptionals["filename"], "string", "filename"); err != nil { if err := typeCheckParameter(localVarOptionals["filename"], "string", "filename"); err != nil {
return nil, err return 0, err
} }
if err := typeCheckParameter(localVarOptionals["format"], "string", "format"); err != nil { if err := typeCheckParameter(localVarOptionals["format"], "string", "format"); err != nil {
return nil, err return 0, err
} }
if err := typeCheckParameter(localVarOptionals["path"], "string", "path"); err != nil { if err := typeCheckParameter(localVarOptionals["path"], "string", "path"); err != nil {
return nil, err return 0, err
} }
if err := typeCheckParameter(localVarOptionals["prefix"], "string", "prefix"); err != nil { if err := typeCheckParameter(localVarOptionals["prefix"], "string", "prefix"); err != nil {
return nil, err return 0, err
} }
if localVarTempParam, localVarOk := localVarOptionals["at"].(string); localVarOk { if localVarTempParam, localVarOk := localVarOptionals["at"].(string); localVarOk {
@ -3319,7 +3333,9 @@ func (a *DefaultApiService) GetArchive(project, repository string, localVarOptio
localVarQueryParams.Add("format", parameterToString(localVarTempParam, "")) localVarQueryParams.Add("format", parameterToString(localVarTempParam, ""))
} }
if localVarTempParam, localVarOk := localVarOptionals["path"].(string); localVarOk { if localVarTempParam, localVarOk := localVarOptionals["path"].(string); localVarOk {
localVarQueryParams.Add("path", parameterToString(localVarTempParam, "")) for _, path := range strings.Split(parameterToString(localVarTempParam, ""), ",") {
localVarQueryParams.Add("path", path)
}
} }
if localVarTempParam, localVarOk := localVarOptionals["prefix"].(string); localVarOk { if localVarTempParam, localVarOk := localVarOptionals["prefix"].(string); localVarOk {
localVarQueryParams.Add("prefix", parameterToString(localVarTempParam, "")) localVarQueryParams.Add("prefix", parameterToString(localVarTempParam, ""))
@ -3343,20 +3359,19 @@ func (a *DefaultApiService) GetArchive(project, repository string, localVarOptio
} }
r, err := a.client.prepareRequest(a.client.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, localVarFileName, localVarFileBytes) r, err := a.client.prepareRequest(a.client.ctx, localVarPath, localVarHTTPMethod, localVarPostBody, localVarHeaderParams, localVarQueryParams, localVarFormParams, localVarFileName, localVarFileBytes)
if err != nil { if err != nil {
return nil, err return 0, err
} }
localVarHTTPResponse, err := a.client.callAPI(r) localVarHTTPResponse, err := a.client.callAPI(r)
if err != nil || localVarHTTPResponse == nil { if err != nil || localVarHTTPResponse == nil {
return NewAPIResponseWithError(localVarHTTPResponse, nil, err) return 0, err
} }
defer localVarHTTPResponse.Body.Close() defer localVarHTTPResponse.Body.Close()
if localVarHTTPResponse.StatusCode >= 300 { if localVarHTTPResponse.StatusCode >= 300 {
bodyBytes, _ := io.ReadAll(localVarHTTPResponse.Body) bodyBytes, _ := ioutil.ReadAll(localVarHTTPResponse.Body)
return NewAPIResponseWithError(localVarHTTPResponse, bodyBytes, reportError("Status: %v, Body: %s", localVarHTTPResponse.Status, bodyBytes)) return 0, reportError("Status: %v, Body: %s", localVarHTTPResponse.Status, bodyBytes)
} }
return io.Copy(writer, localVarHTTPResponse.Body)
return NewRawAPIResponse(localVarHTTPResponse)
} }
/* /*