forked from psalm/psalm-github-actions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
entrypoint.sh
executable file
·89 lines (74 loc) · 2.37 KB
/
entrypoint.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/bin/sh -l
set -e
TAINT_ANALYSIS=""
if [ "$INPUT_SECURITY_ANALYSIS" = "true" ]; then
TAINT_ANALYSIS="--taint-analysis"
fi
REPORT=""
if [ ! -z "$INPUT_REPORT_FILE" ]; then
REPORT="--report=$INPUT_REPORT_FILE"
fi
if [ -n "$INPUT_SSH_KEY" ]
then
echo "::group::Keys setup for private repositories"
echo "Keyscan:"
mkdir -p /tmp/.ssh
ssh-keyscan -t rsa github.com >> /tmp/.ssh/known_hosts
ssh-keyscan -t rsa gitlab.com >> /tmp/.ssh/known_hosts
ssh-keyscan -t rsa bitbucket.org >> /tmp/.ssh/known_hosts
if [ -n "$INPUT_SSH_DOMAIN" ]
then
ssh-keyscan -t rsa "$INPUT_SSH_DOMAIN" >> /tmp/.ssh/known_hosts
fi
echo "Installing keys:"
echo "$INPUT_SSH_KEY" > /tmp/.ssh/action_rsa
echo "$INPUT_SSH_KEY_PUB" > /tmp/.ssh/action_rsa.pub
chmod 600 /tmp/.ssh/action_rsa
echo "Private key hash:"
md5sum /tmp/.ssh/action_rsa
echo "Public key hash:"
md5sum /tmp/.ssh/action_rsa.pub
echo "[core]" >> ~/.gitconfig
echo "sshCommand = \"ssh -i /tmp/.ssh/action_rsa -o UserKnownHostsFile=/tmp/.ssh/known_hosts\"" >> ~/.gitconfig
echo "OK"
echo "::endgroup::"
else
echo "No private keys supplied"
fi
if [ -n "$INPUT_COMPOSER_GITHUB_TOKEN" ]
then
echo "::group::OAuth setting github oauth token"
composer global config github-oauth.github.com "$INPUT_COMPOSER_GITHUB_TOKEN"
echo "OK"
echo "::endgroup::"
else
echo "No github token supplied"
fi
if [ -n "$INPUT_RELATIVE_DIR" ]
then
if [ -d "$INPUT_RELATIVE_DIR" ]; then
echo "changing directory into $INPUT_RELATIVE_DIR"
cd "$INPUT_RELATIVE_DIR"
else
echo "given relative_dir not existing"
exit 1
fi
fi
if test -f "composer.json"; then
IGNORE_PLATFORM_REQS=""
if [ "$CHECK_PLATFORM_REQUIREMENTS" = "false" ] || [ "$INPUT_COMPOSER_IGNORE_PLATFORM_REQS" = "true" ]; then
IGNORE_PLATFORM_REQS="--ignore-platform-reqs"
fi
NO_DEV="--no-dev"
if [ "$REQUIRE_DEV" = "true" ] || [ "$INPUT_COMPOSER_REQUIRE_DEV" = "true" ]; then
NO_DEV=""
fi
COMPOSER_COMMAND="composer install --no-scripts --no-progress $NO_DEV $IGNORE_PLATFORM_REQS"
echo "::group::$COMPOSER_COMMAND"
$COMPOSER_COMMAND
echo "::endgroup::"
else
echo "composer.json not found in repo, skipping Composer installation"
fi
vendor/bin/psalm --version
vendor/bin/psalm --output-format=github $TAINT_ANALYSIS $REPORT $*