add option to add files to existing release and to extend description of existing release
This commit is contained in:
parent
9ba66614ec
commit
59f2add5c7
@ -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))
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user