Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
I
Imldeployment
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
IML Open Source
Imldeployment
Commits
b6357621
Commit
b6357621
authored
2 months ago
by
Hahn Axel (hahn)
Browse files
Options
Downloads
Patches
Plain Diff
api shel script: shell fixes; long cli parameters
parent
6b595fa4
No related branches found
No related tags found
1 merge request
!82
7821 improve api error messages
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
shellscripts/api-imlciserver.sh
+64
-60
64 additions, 60 deletions
shellscripts/api-imlciserver.sh
with
64 additions
and
60 deletions
shellscripts/api-imlciserver.sh
+
64
−
60
View file @
b6357621
...
@@ -7,6 +7,7 @@
...
@@ -7,6 +7,7 @@
# 2020-07-23 v1.0 <axel.hahn@iml.unibe.ch> first lines
# 2020-07-23 v1.0 <axel.hahn@iml.unibe.ch> first lines
# 2020-07-29 v1.1 <axel.hahn@iml.unibe.ch> check "/" in branch; check http status 200
# 2020-07-29 v1.1 <axel.hahn@iml.unibe.ch> check "/" in branch; check http status 200
# 2021-03-29 v1.2 <axel.hahn@iml.unibe.ch> support slashes in branch names
# 2021-03-29 v1.2 <axel.hahn@iml.unibe.ch> support slashes in branch names
# 2025-02-19 v1.3 <axel.hahn@iml.unibe.ch> shell fixes; long cli parameters
# ======================================================================
# ======================================================================
# ----------------------------------------------------------------------
# ----------------------------------------------------------------------
...
@@ -22,30 +23,35 @@ line="----------------------------------------------------------------------"
...
@@ -22,30 +23,35 @@ line="----------------------------------------------------------------------"
# FUNCTIONS
# FUNCTIONS
# ----------------------------------------------------------------------
# ----------------------------------------------------------------------
# Show help with parameters
function
showhelp
(){
function
showhelp
(){
local
_self
;
_self
=
"
$(
basename
"
$0
"
)
"
echo
"
echo
"
SYNTAX:
SYNTAX:
-a ACTION set name of an action
-a, --action ACTION
-b BRANCH set custom branch to access, i.e. origin/feature-123
set name of an action
-p PROJECT project name in the ci server; overrides env variable IMLCI_PROJECT
... without given project and secret
-s SECRET API secret for the given project; overrides env variable IMLCI_API_SECRET
projects show projects
-u URL URL of iml ci server without trailing /; overrides env variable IMLCI_URL
... with project and secret
ACTION:
buildinfo BRANCH
... without given project and secret
show infos about what happens on build
projects show projects
build BRANCH
execute build
... with project and secret
phases show status of phases
buildinfo [branch]
-b, --branch BRANCH
show infos about what happens on build
set custom branch to access, i.e. origin/feature-123
build [branch]
-p, --project PROJECT
execute build
project name in the ci server; overrides env variable IMLCI_PROJECT
phases show status of phases
-s, --secret SECRET
API secret for the given project; overrides env variable IMLCI_API_SECRET
-u. --url URL
URL of iml ci server without trailing /; overrides env variable IMLCI_URL
EXAMPLES:
EXAMPLES:
`
basename
$0
`
-u https://ci.example.com -a projects
$_self
-u https://ci.example.com -a projects
`
basename
$0
`
-u https://ci.example.com -p myproject -s 12345678 -a buildinfo
$_self
-u https://ci.example.com -p myproject -s 12345678 -a buildinfo
`
basename
$0
`
-u https://ci.example.com -p myproject -s 12345678 -a build
$_self
-u https://ci.example.com -p myproject -s 12345678 -a build
"
"
}
}
...
@@ -59,7 +65,7 @@ function makeRequest(){
...
@@ -59,7 +65,7 @@ function makeRequest(){
local
outfile
=
$(
mktemp
)
local
outfile
=
$(
mktemp
)
echo
$line
echo
$line
echo
$apiMethod
${
apiHost
}${
apiRequest
}
echo
"
$apiMethod
${
IMLCI_URL
}${
apiRequest
}
"
echo
$line
echo
$line
if
[
!
-z
"
$secret
"
]
;
then
if
[
!
-z
"
$secret
"
]
;
then
...
@@ -67,7 +73,7 @@ function makeRequest(){
...
@@ -67,7 +73,7 @@ function makeRequest(){
# --- date in http format
# --- date in http format
LANG
=
en_EN
LANG
=
en_EN
# export TZ=GMT
# export TZ=GMT
apiTS
=
`
date
"+%a, %d %b %Y %H:%M:%S %Z"
`
apiTS
=
$(
date
"+%a, %d %b %Y %H:%M:%S %Z"
)
# --- generate data to hash: method + uri + timestamp; delimited with line break
# --- generate data to hash: method + uri + timestamp; delimited with line break
...
@@ -77,30 +83,32 @@ ${apiTS}
...
@@ -77,30 +83,32 @@ ${apiTS}
"
"
# generate hash - split in 2 commands (piping "cut" sends additional line break)
# generate hash - split in 2 commands (piping "cut" sends additional line break)
myHash
=
`
echo
-n
"
$data
"
| openssl sha1
-hmac
"
${
secret
}
"
|
cut
-f
2
-d
" "
`
myHash
=
$(
echo
-n
"
$data
"
| openssl sha1
-hmac
"
${
secret
}
"
|
cut
-f
2
-d
" "
)
myHash
=
`
echo
-n
"
$myHash
"
|
base64
`
myHash
=
$(
echo
-n
"
$myHash
"
|
base64
)
curl
-i
\
curl
-i
\
-H
"Accept: application/json"
-H
"Content-Type: application/json"
\
-H
"Accept: application/json"
-H
"Content-Type: application/json"
\
-H
"Date:
${
apiTS
}
"
\
-H
"Date:
${
apiTS
}
"
\
-H
"Authorization: demo-bash-client:
${
myHash
}
"
\
-H
"Authorization: demo-bash-client:
${
myHash
}
"
\
-X
$apiMethod
\
-X
"
$apiMethod
"
\
${
IMLCI_URL
}${
apiRequest
}
|
tee
-a
$outfile
-s
\
"
${
IMLCI_URL
}${
apiRequest
}
"
|
tee
-a
"
$outfile
"
else
else
curl
-i
\
curl
-i
\
-H
"Accept: application/json"
-H
"Content-Type: application/json"
\
-H
"Accept: application/json"
-H
"Content-Type: application/json"
\
-X
$apiMethod
\
-X
"
$apiMethod
"
\
${
IMLCI_URL
}${
apiRequest
}
|
tee
-a
$outfile
-s
\
"
${
IMLCI_URL
}${
apiRequest
}
"
|
tee
-a
"
$outfile
"
fi
fi
grep
"^HTTP/"
$outfile
|
head
-1
|
grep
" 200 "
>
/dev/null
grep
"^HTTP/"
"
$outfile
"
|
head
-1
|
grep
" 200 "
>
/dev/null
local
rccurl
=
$?
local
rccurl
=
$?
rm
-f
$outfile
rm
-f
"
$outfile
"
if
[
$rccurl
-ne
0
]
;
then
if
[
$rccurl
-ne
0
]
;
then
echo
echo
echo
"ERROR: API request failed. CURL request did not get respond status code 200."
echo
"ERROR: API request failed. CURL request did not get respond status code 200."
exit
4
exit
5
fi
fi
}
}
...
@@ -110,38 +118,34 @@ ${apiTS}
...
@@ -110,38 +118,34 @@ ${apiTS}
# ----------------------------------------------------------------------
# ----------------------------------------------------------------------
echo
echo
echo
=====
API CALL TO IML CI SERVER ::
`
date
`
=====
echo
"
===== API CALL TO IML CI SERVER ::
$(
date
)
=====
"
echo
echo
if
[
$#
-
lt
1
]
;
then
if
[
$#
-
eq
0
]
;
then
showhelp
showhelp
exit
1
exit
1
fi
fi
while
getopts
"a:b:u:p:s:"
option
;
do
while
[[
"$#"
-gt
0
]]
;
do case
$1
in
case
${
option
}
in
-a
|
--action
)
apiAction
=
"
$2
"
;
shift
;
shift
;;
a
)
-b
|
--branch
)
branch
=
"
$2
"
;
shift
;
shift
;;
apiAction
=
$OPTARG
-h
|
--help
)
showhelp
;
exit
0
;;
;;
-u
|
--url
)
IMLCI_URL
=
"
$2
"
;
shift
;
shift
;;
b
)
-p
|
--project
)
IMLCI_PROJECT
=
"
$2
"
;
shift
;
shift
;;
branch
=
$OPTARG
-s
|
--secret
)
IMLCI_API_SECRET
=
"
$2
"
;
shift
;
shift
;;
;;
*
)
if
grep
"^-"
<<<
"
$1
"
>
/dev/null
;
then
u
)
echo
;
echo
"ERROR: Unknown parameter:
$1
"
;
echo
;
showhelp
;
exit
2
export
IMLCI_URL
=
$OPTARG
fi
;;
break
;
p
)
;;
export
IMLCI_PROJECT
=
$OPTARG
esac
;
done
;;
if
[
$#
-gt
0
]
;
then
s
)
showhelp
export
IMLCI_API_SECRET
=
$OPTARG
exit
3
;;
fi
*
)
echo
ERROR: invalid option
[
${
option
}
]
exit
2
esac
done
echo
Params:
$*
echo
"
Params:
$*
"
echo
"IMLCI_URL =
$IMLCI_URL
"
echo
"IMLCI_URL =
$IMLCI_URL
"
echo
"IMLCI_PROJECT =
$IMLCI_PROJECT
"
echo
"IMLCI_PROJECT =
$IMLCI_PROJECT
"
echo
"IMLCI_API_SECRET =
$IMLCI_API_SECRET
"
echo
"IMLCI_API_SECRET =
$IMLCI_API_SECRET
"
...
@@ -151,7 +155,7 @@ echo
...
@@ -151,7 +155,7 @@ echo
# echo $branch | grep '/.*/.*' >/dev/null && ( echo "WARNING: Do NOT use a branch containing a slash [/] in the name"; echo )
# echo $branch | grep '/.*/.*' >/dev/null && ( echo "WARNING: Do NOT use a branch containing a slash [/] in the name"; echo )
echo
ACTION:
$apiAction
echo
"
ACTION:
$apiAction
"
case
$apiAction
in
case
$apiAction
in
# --- projects is an access without autorization
# --- projects is an access without autorization
...
@@ -161,17 +165,17 @@ case $apiAction in
...
@@ -161,17 +165,17 @@ case $apiAction in
# --- access WITH autorization only
# --- access WITH autorization only
"build"
)
"build"
)
makeRequest POST /api/v1/project/
$IMLCI_PROJECT
/build/
$branch
"
$IMLCI_API_SECRET
"
makeRequest POST
"
/api/v1/project/
$IMLCI_PROJECT
/build/
$branch
"
"
$IMLCI_API_SECRET
"
;;
;;
"buildinfo"
)
"buildinfo"
)
makeRequest GET /api/v1/project/
$IMLCI_PROJECT
/build/
$branch
"
$IMLCI_API_SECRET
"
makeRequest GET
"
/api/v1/project/
$IMLCI_PROJECT
/build/
$branch
"
"
$IMLCI_API_SECRET
"
;;
;;
"phases"
)
"phases"
)
makeRequest GET /api/v1/project/
$IMLCI_PROJECT
/phases
"
$IMLCI_API_SECRET
"
makeRequest GET
"
/api/v1/project/
$IMLCI_PROJECT
/phases
"
"
$IMLCI_API_SECRET
"
;;
;;
*
)
*
)
echo
"ERROR: unknown action [
$apiAction
]"
echo
"ERROR: unknown action [
$apiAction
]"
exit
3
exit
4
esac
esac
rc
=
$?
rc
=
$?
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment