Compare commits
12 Commits
Author | SHA1 | Date | |
---|---|---|---|
adae5638d3 | |||
b66ca744ae | |||
f72c8b115f | |||
1b05213466
|
|||
f3f62d5cf5
|
|||
e5967bb726
|
|||
d194562474
|
|||
e87741bedb
|
|||
c64effea3b
|
|||
cb94e9e017
|
|||
0e8823bba1
|
|||
5fd785a826
|
@ -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,8 +40,7 @@ projectId = args.projectId
|
|||||||
releaseTag = args.releaseTag
|
releaseTag = args.releaseTag
|
||||||
instanceUrl = args.instanceUrl
|
instanceUrl = args.instanceUrl
|
||||||
verbose = args.verbose
|
verbose = args.verbose
|
||||||
insecure = args.insecure
|
caBundle = args.caBundle
|
||||||
|
|
||||||
|
|
||||||
# --- 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)
|
||||||
@ -45,7 +49,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)
|
||||||
|
@ -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)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"releaseTag": "v1.7",
|
"releaseTag": "v1.10",
|
||||||
"createReleaseTag": "true",
|
"createReleaseTag": "true",
|
||||||
"releaseName": "Delete Release supporting release",
|
"releaseName": "re-add insecure",
|
||||||
"description": "Separate tool to delete releases added"
|
"description": "re-add insecure option to deleterelease script"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 ≡]$
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user