add option to add files to existing release and to extend description of existing release

This commit is contained in:
Wolfgang Hottgenroth 2021-01-13 17:30:11 +01:00
parent 9ba66614ec
commit 59f2add5c7
Signed by: wn
GPG Key ID: 6C1E5E531E0D5D7F

View File

@ -16,7 +16,7 @@ parser.add_argument('--projectUrl', '-u',
parser.add_argument('--file', '-f', parser.add_argument('--file', '-f',
help='File to be released, can appear multiple times', help='File to be released, can appear multiple times',
action='append', action='append',
required=True) required=False)
parser.add_argument('--releaseName', '-n', parser.add_argument('--releaseName', '-n',
help='Name of the release', required=False, help='Name of the release', required=False,
default='') default='')
@ -102,121 +102,160 @@ if (releaseInfoFilename):
if releaseName == '': if releaseName == '':
raise Exception('No release name given') raise Exception('No release name given')
if releaseTag == '': if (releaseTag == '') and createRelease:
raise Exception('No release tag given') raise Exception('No release tag given but creation of release requested')
if (releaseTagTarget == '') and createReleaseTag: if (releaseTagTarget == '') and createReleaseTag:
raise Exception('No release tag target given but creation of tag requested') raise Exception('No release tag target given but creation of tag requested')
if releaseDescription == '': if (releaseDescription == '') and createRelease:
raise Exception('No release description given') raise Exception('No release description given but creation of release requested')
if insecure: if insecure:
caBundle = (False) caBundle = (False)
def checkAndShowResult(result, expectedCode, errorMessage):
global verbose
if result.status_code != expectedCode:
print(result)
print(result.text)
raise Exception(errorMessage)
if verbose:
print(result)
print(result.text)
# --- upload the file # --- upload the file
uploadUrl = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId) assets = [] # is required later, must be defined
headers = {"PRIVATE-TOKEN": privateToken} if filesToUpload:
url = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId)
headers = {"PRIVATE-TOKEN": privateToken}
assets = [] for filename in filesToUpload:
with open(filename, 'rb') as filehandle:
files = {"file": filehandle}
for filename in filesToUpload: if verbose:
with open(filename, 'rb') as filehandle: print("POST to {}".format(url))
files = {"file": filehandle} result = requests.post(url, files=files, headers=headers, verify=caBundle)
uploadResult = requests.post(uploadUrl, files=files, headers=headers, verify=caBundle) checkAndShowResult(result, 201, 'Unable to upload file to Gitlab')
if uploadResult.status_code != 201: assetUrl = projectUrl + json.loads(result.text)['url']
print(uploadResult) assets.append({'name': filename, 'url': assetUrl, 'id': "new-link-{}".format(len(assets))})
print(uploadResult.text)
raise Exception('Unable to upload file to Gitlab')
if verbose: print('File {} successfully uploaded, url is {}'.format(filename, assetUrl))
print(uploadResult)
print(uploadResult.text)
url = projectUrl + json.loads(uploadResult.text)['url']
assets.append({'name': filename, 'url': url, 'id': "new-link-{}".format(len(assets))})
print('File {} successfully uploaded, url is {}'.format(filename, url))
# --- create release tag # --- create release tag
if createReleaseTag: if createReleaseTag:
createReleaseTagUrl = ("%s/api/v4//projects/%s/repository/tags" % url = ("%s/api/v4//projects/%s/repository/tags" % (instanceUrl, projectId))
(instanceUrl, projectId)) headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
headers = {"PRIVATE-TOKEN": privateToken,
"Content-Type": "application/json"}
payloadCreateReleaseTag = { payload = {
"tag_name": releaseTag, "tag_name": releaseTag,
"id": projectId, "id": projectId,
"ref": releaseTagTarget, "ref": releaseTagTarget,
"message": "Tag for release %s" % releaseName "message": "Tag for release %s" % releaseName
} }
createReleaseTagResult = requests.post(createReleaseTagUrl,
headers=headers,
data=json.dumps(payloadCreateReleaseTag),
verify=caBundle)
if createReleaseTagResult.status_code != 201:
print(createReleaseTagResult)
print(createReleaseTagResult.text)
raise Exception('Unable to create release tag')
if verbose: if verbose:
print(createReleaseTagResult) print("POST to {}".format(url))
print(createReleaseTagResult.text) result = requests.post(url, headers=headers, data=json.dumps(payload), verify=caBundle)
checkAndShowResult(result, 201, 'Unable to create release tag')
print('Tag successfully created') print('Tag successfully created')
# --- create release # --- create release
if createRelease: if createRelease:
createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId) url = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"} headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
payloadCreateRelease = { payload = {
"name": releaseName, "name": releaseName,
"tag_name": releaseTag, "tag_name": releaseTag,
"description": releaseDescription "description": releaseDescription
} }
createReleaseResult = requests.post(createReleaseUrl, headers=headers,
data=json.dumps(payloadCreateRelease),
verify=caBundle)
if createReleaseResult.status_code != 201:
print(createReleaseResult)
print(createReleaseResult.text)
raise Exception('Unable to create release')
if verbose: if verbose:
print(createReleaseResult) print("POST to {}".format(url))
print(createReleaseResult.text) result = requests.post(url, headers=headers, data=json.dumps(payload), verify=caBundle)
checkAndShowResult(result, 201, 'Unable to create release')
print('Release successfully created') print('Release successfully created')
## --- update release in case of additional description
if not createRelease and releaseDescription:
# --- get release to fetch existing description
url = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseName)
headers = {"PRIVATE-TOKEN": privateToken}
attachAssetsToReleaseUrl = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseTag) if verbose:
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"} print("GET to {}".format(url))
result = requests.get(url, headers=headers, verify=caBundle)
payloadAttachAssetsToRelease = { checkAndShowResult(result, 200, 'Unable to get release')
"name": releaseName, existingDescription = json.loads(result.text)['description']
"tag_name": releaseTag, print("Existing description is {}".format(existingDescription))
"assets": {
"links": assets
},
"description": releaseDescription
}
attachAssetsToReleaseResult = requests.put(attachAssetsToReleaseUrl, headers=headers, releaseDescription += "\n\n---------------------------------------------\n\n"
data=json.dumps(payloadAttachAssetsToRelease), releaseDescription += existingDescription
verify=caBundle)
if attachAssetsToReleaseResult.status_code != 200: # --- update release
print(attachAssetsToReleaseResult) url = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseName)
print(attachAssetsToReleaseResult.text) headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
raise Exception('Unable to assets to release')
payload = {
"name": releaseName,
"tag_name": releaseTag,
"description": releaseDescription
}
if verbose:
print("PUT to {}".format(url))
result = requests.put(url, headers=headers, data=json.dumps(payload), verify=caBundle)
checkAndShowResult(result, 200, 'Unable to update release')
print('Release successfully update')
## --- add assets
# get existing assets
headers = {"PRIVATE-TOKEN": privateToken}
url = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseName)
if verbose: if verbose:
print(attachAssetsToReleaseResult) print("GET to {}".format(url))
print(attachAssetsToReleaseResult.text) result = requests.get(url, headers=headers, verify=caBundle)
print('Assets attached to release successfully') checkAndShowResult(result, 200, 'Unable to get release information')
# add existing assets to list of assets
links = json.loads(result.text)['assets']['links']
assets.extend(links)
# delete existing assets
headers = {"PRIVATE-TOKEN": privateToken}
for link in links:
assetId = link['id']
url = "%s/api/v4/projects/%s/releases/%s/assets/links/%s" % (instanceUrl, projectId, releaseName, assetId)
if verbose:
print("DELETE to {}".format(url))
result = requests.delete(url, headers=headers, verify=caBundle)
checkAndShowResult(result, 200, 'Unable to delete asset')
print("Asset {} successfully deleted".format(assetId))
# create all assets ("existing" and new)
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
url = "%s/api/v4/projects/%s/releases/%s/assets/links" % (instanceUrl, projectId, releaseName)
for asset in assets:
if verbose:
print("POST to {}".format(url))
result = requests.post(url, headers=headers, data=json.dumps(asset), verify=caBundle)
checkAndShowResult(result, 201, "Unable to create asset")
print("Asset {} successfully created".format(asset))