14 Commits
v1.7 ... v1.10b

4 changed files with 44 additions and 27 deletions

View File

@ -23,11 +23,16 @@ parser.add_argument('--verbose', '-v',
required=False, required=False,
action='store_true', action='store_true',
default=False) default=False)
parser.add_argument('--caBundle', '-B',
help='File with the CA certificates to trust', required=False,
default='/etc/ssl/certs/ca-certificates.crt')
parser.add_argument('--insecure', parser.add_argument('--insecure',
help='insecure ssl connect', help='insecure ssl connect',
required=False, required=False,
action='store_true', action='store_true',
default=False) default=False)
args = parser.parse_args() args = parser.parse_args()
privateToken = args.privateToken privateToken = args.privateToken
@ -35,9 +40,9 @@ projectId = args.projectId
releaseTag = args.releaseTag releaseTag = args.releaseTag
instanceUrl = args.instanceUrl instanceUrl = args.instanceUrl
verbose = args.verbose verbose = args.verbose
caBundle = args.caBundle
insecure = args.insecure insecure = args.insecure
# --- delete release # --- delete release
deleteReleaseUrl = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseTag) deleteReleaseUrl = "%s/api/v4/projects/%s/releases/%s" % (instanceUrl, projectId, releaseTag)
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"} headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
@ -45,7 +50,10 @@ headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
if verbose: if verbose:
print("URL: %s" % deleteReleaseUrl) print("URL: %s" % deleteReleaseUrl)
deleteReleaseResult = requests.delete(deleteReleaseUrl, headers=headers, verify=(not insecure)) if insecure:
caBundle = (false)
deleteReleaseResult = requests.delete(deleteReleaseUrl, headers=headers, verify=caBundle)
if deleteReleaseResult.status_code != 200: if deleteReleaseResult.status_code != 200:
print(deleteReleaseResult) print(deleteReleaseResult)

View File

@ -14,7 +14,9 @@ parser.add_argument('--projectId', '-i',
parser.add_argument('--projectUrl', '-u', parser.add_argument('--projectUrl', '-u',
help='URL of the related project at Gitlab', required=True) help='URL of the related project at Gitlab', required=True)
parser.add_argument('--file', '-f', parser.add_argument('--file', '-f',
help='File to be released', required=True) help='File to be released, can appear multiple times',
action='append',
required=True)
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='')
@ -42,6 +44,9 @@ parser.add_argument('--releaseInfoFile', '-F',
parser.add_argument('--instanceUrl', '-I', parser.add_argument('--instanceUrl', '-I',
help='URL of your gitlab instance', required=False, help='URL of your gitlab instance', required=False,
default='https://gitlab.com') default='https://gitlab.com')
parser.add_argument('--caBundle', '-B',
help='File with the CA certificates to trust', required=False,
default='/etc/ssl/certs/ca-certificates.crt')
parser.add_argument('--verbose', '-v', parser.add_argument('--verbose', '-v',
help='verbose output', help='verbose output',
required=False, required=False,
@ -52,7 +57,7 @@ args = parser.parse_args()
privateToken = args.privateToken privateToken = args.privateToken
projectId = args.projectId projectId = args.projectId
projectUrl = args.projectUrl projectUrl = args.projectUrl
fileToUpload = args.file filesToUpload = args.file
releaseName = args.releaseName releaseName = args.releaseName
releaseTag = args.releaseTag releaseTag = args.releaseTag
releaseTagTarget = args.releaseTagTarget releaseTagTarget = args.releaseTagTarget
@ -60,6 +65,7 @@ releaseDescription = args.description
instanceUrl = args.instanceUrl instanceUrl = args.instanceUrl
createReleaseTag = args.createReleaseTag createReleaseTag = args.createReleaseTag
releaseInfoFilename = args.releaseInfoFile releaseInfoFilename = args.releaseInfoFile
caBundle = args.caBundle
verbose = args.verbose verbose = args.verbose
releaseInfo = {} releaseInfo = {}
@ -92,21 +98,26 @@ if releaseDescription == '':
# --- upload the file # --- upload the file
uploadUrl = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId) uploadUrl = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId)
headers = {"PRIVATE-TOKEN": privateToken} headers = {"PRIVATE-TOKEN": privateToken}
files = {"file": open(fileToUpload, 'rb')}
uploadResult = requests.post(uploadUrl, files=files, headers=headers) assets = []
for filename in filesToUpload:
with open(filename, 'rb') as filehandle:
files = {"file": filehandle}
if uploadResult.status_code != 201: uploadResult = requests.post(uploadUrl, files=files, headers=headers, verify=caBundle)
print(uploadResult)
print(uploadResult.text)
raise Exception('Unable to upload file to Gitlab')
if verbose: if uploadResult.status_code != 201:
print(uploadResult) print(uploadResult)
print(uploadResult.text) print(uploadResult.text)
print('File successfully uploaded') raise Exception('Unable to upload file to Gitlab')
uploadResultJson = json.loads(uploadResult.text) if verbose:
print(uploadResult)
print(uploadResult.text)
print('File {} successfully uploaded'.format(filename))
url = projectUrl + json.loads(uploadResult.text)['url']
assets.append({'name': filename, 'url': url})
# --- create release tag # --- create release tag
if createReleaseTag: if createReleaseTag:
@ -124,7 +135,8 @@ if createReleaseTag:
createReleaseTagResult = requests.post(createReleaseTagUrl, createReleaseTagResult = requests.post(createReleaseTagUrl,
headers=headers, headers=headers,
data=json.dumps(payloadCreateReleaseTag)) data=json.dumps(payloadCreateReleaseTag),
verify=caBundle)
if createReleaseTagResult.status_code != 201: if createReleaseTagResult.status_code != 201:
print(createReleaseTagResult) print(createReleaseTagResult)
@ -140,24 +152,19 @@ if createReleaseTag:
# --- create release # --- create release
createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId) createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"} headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
fullUrl = projectUrl + uploadResultJson['url']
payloadCreateRelease = { payloadCreateRelease = {
"name": releaseName, "name": releaseName,
"tag_name": releaseTag, "tag_name": releaseTag,
"description": releaseDescription, "description": releaseDescription,
"assets": { "assets": {
"links": [ "links": assets
{
"name": fileToUpload,
"url": fullUrl
}
]
} }
} }
createReleaseResult = requests.post(createReleaseUrl, headers=headers, createReleaseResult = requests.post(createReleaseUrl, headers=headers,
data=json.dumps(payloadCreateRelease)) data=json.dumps(payloadCreateRelease),
verify=caBundle)
if createReleaseResult.status_code != 201: if createReleaseResult.status_code != 201:
print(createReleaseResult) print(createReleaseResult)

View File

@ -1,7 +1,7 @@
{ {
"releaseTag": "v1.7", "releaseTag": "v1.10b",
"createReleaseTag": "true", "createReleaseTag": "true",
"releaseName": "Delete Release supporting release", "releaseName": "re-add insecure, fix",
"description": "Separate tool to delete releases added" "description": "re-add insecure option to deleterelease script, fix"
} }

View File

@ -21,6 +21,7 @@ Gitlab CI scripts.
[--createReleaseTag] [--createReleaseTag]
[--description DESCRIPTION] [--description DESCRIPTION]
[--releaseInfoFile RELEASEINFOFILE] [--releaseInfoFile RELEASEINFOFILE]
[--caBundle FILE_WITH_CA_CERTIFICATES_TO_TRUST]
[--instanceUrl INSTANCEURL] [--verbose] [--instanceUrl INSTANCEURL] [--verbose]
Gitlab Release Uploader Gitlab Release Uploader
@ -49,6 +50,7 @@ Gitlab CI scripts.
tag, create release tag, description tag, create release tag, description
--instanceUrl INSTANCEURL, -I INSTANCEURL --instanceUrl INSTANCEURL, -I INSTANCEURL
URL of your gitlab instance URL of your gitlab instance
--caBundle FILE_WITH_CA_CERTIFICATES_TO_TRUST, -B FILE_WITH_CA_CERTIFICATES_TO_TRUST
--verbose, -v verbose output --verbose, -v verbose output
wn@tron:~/workspace-python/gitlabreleaseuploader [master ≡]$ wn@tron:~/workspace-python/gitlabreleaseuploader [master ≡]$