-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathdevhub.sh
executable file
·94 lines (70 loc) · 2.99 KB
/
devhub.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
90
91
92
93
94
#!/bin/bash
if [ -f ~/.dev_hub_authenticated ]; then
exit 0
fi
if [ -z "$DEV_HUB_AUTH_URL" ]; then
if [ -z "$DEV_HUB_USERNAME" ]; then
echo "DEV_HUB_USERNAME is not set, length is $(echo $(($(echo $DEV_HUB_USERNAME|wc -c)-1))). You must set either DEV_HUB_AUTH_URL or DEV_HUB_USERNAME, DEV_HUB_CLIENT_ID, and DEV_HUB_PRIVATE_KEY."
exit 1
fi
if [ -z "$DEV_HUB_CLIENT_ID" ]; then
echo "DEV_HUB_CLIENT_ID is not set, length is $(echo $(($(echo $DEV_HUB_CLIENT_ID|wc -c)-1))). You must set either DEV_HUB_AUTH_URL or DEV_HUB_USERNAME, DEV_HUB_CLIENT_ID, and DEV_HUB_PRIVATE_KEY."
exit 1
fi
if [ -z "$DEV_HUB_PRIVATE_KEY" ]; then
echo "DEV_HUB_PRIVATE_KEY is not set, length is $(echo $(($(echo $DEV_HUB_PRIVATE_KEY|wc -c)-1))). You must set either DEV_HUB_AUTH_URL or DEV_HUB_USERNAME, DEV_HUB_CLIENT_ID, and DEV_HUB_PRIVATE_KEY."
exit 1
fi
echo "Authenticating to DevHub using JWT..."
# Write the DEV_HUB_PRIVATE_KEY to a file
echo $DEV_HUB_PRIVATE_KEY > /tmp/dev_hub.key
# Authenticate the DevHub
sf org login jwt \
--username $DEV_HUB_USERNAME \
--jwt-key-file /tmp/dev_hub.key \
--client-id $DEV_HUB_CLIENT_ID \
--alias DevHub \
--set-default-dev-hub
[[ -f /tmp/dev_hub.key ]] && rm /tmp/dev_hub.key
else
# Authenticate using Auth URL
echo "Authenticating to DevHub using auth url..."
# Write the DEV_HUB_AUTH_URL to a file
echo $DEV_HUB_AUTH_URL > /tmp/dev_hub_auth_url
# Authenticate the DevHub
sfdx org login sfdx-url -f /tmp/dev_hub_auth_url -a DevHub -d
[[ -f /tmp/dev_hub_auth_url ]] && rm /tmp/dev_hub_auth_url
fi
if [ -z "$PACKAGING_ORG_AUTH_URL" ]; then
echo "No PACKAGING_ORG_AUTH_URL set, skipping packaging org authentication."
else
# Authenticate using Auth URL
echo "Authenticating to Packaging Org using auth url..."
# Write the PACKAGING_ORG_AUTH_URL to a file
echo $PACKAGING_ORG_AUTH_URL > /tmp/packaging_org_auth_url
# Authenticate the DevHub
sfdx org login sfdx-url -f /tmp/packaging_org_auth_url -a packaging
# Import the org to CumulusCI
cci org import packaging packaging
[[ -f /tmp/packaging_org_auth_url ]] && rm /tmp/packaging_org_auth_url
fi
if [ -z "$TARGET_ORG_AUTH_URL" ]; then
echo "No TARGET_ORG_AUTH_URL set, skipping target org authentication."
else
# Authenticate using Auth URL
echo "Authenticating to Target Org using auth url..."
# Write the TARGET_ORG_AUTH_URL to a file
echo $TARGET_ORG_AUTH_URL > /tmp/target_org_auth_url
# Authenticate the DevHub
sfdx org login sfdx-url -f /tmp/target_org_auth_url -a target
# Import the org to CumulusCI
cci org import target target
[[ -f /tmp/target_org_auth_url ]] && rm /tmp/target_org_auth_url
fi
if [ "`whoami`" == "d2x" ]; then
echo "Setting dev as the default org"
cci org default dev
fi
# Ensure the force-app/main/default folder exists
mkdir -p force-app/main/default
touch ~/.dev_hub_authenticated