blob: cfeca6d6b0d7f4f6ab4c5b1486d24deee8a377ab (
plain)
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
|
#!/usr/bin/env sh
# accepts: partner client ID and secret key, and some site info
# executes wp-cli command to provision Jetpack site for given partner
# change to script directory so that wp finds the wordpress install part for this Jetpack instance
SCRIPT_DIR=$(CDPATH='' cd -- "$(dirname -- "$0")" && pwd -P)
cd "$SCRIPT_DIR" || exit
usage () {
echo "Usage: partner-provision.sh --partner_id=partner_id --partner_secret=partner_secret [--user=wp_user_id] [--plan=plan_name] [--onboarding=1] [--wpcom_user_id=1234] [--url=http://example.com] [--force_connect=1] [--force_register=1]"
}
for i in "$@"; do
case $i in
-c=* | --partner_id=* ) CLIENT_ID="${i#*=}"
shift
;;
-s=* | --partner_secret=* ) CLIENT_SECRET="${i#*=}"
shift
;;
-i=* | --user_id=* | --user=* ) WP_USER="${i#*=}"
shift
;;
-w=* | --wpcom_user_id=* ) WPCOM_USER_ID="${i#*=}"
shift
;;
-p=* | --plan=* ) PLAN_NAME="${i#*=}"
shift
;;
-o=* | --onboarding=* ) ONBOARDING="${i#*=}"
shift
;;
-u=* | --url=* ) SITE_URL="${i#*=}"
shift
;;
-h | --help ) usage
exit
;;
* ) usage
exit 1
esac
done
if [ "$CLIENT_ID" = "" ] || [ "$CLIENT_SECRET" = "" ]; then
usage
exit 1
fi
# default API host that can be overridden
if [ -z "$JETPACK_START_API_HOST" ]; then
JETPACK_START_API_HOST='public-api.wordpress.com'
fi
# fetch an access token using our client ID/secret
ACCESS_TOKEN_JSON=$(curl https://$JETPACK_START_API_HOST/oauth2/token --silent --header "Host: public-api.wordpress.com" -d "grant_type=client_credentials&client_id=$CLIENT_ID&client_secret=$CLIENT_SECRET&scope=jetpack-partner")
# set URL arg for multisite compatibility
if [ ! -z "$SITE_URL" ]; then
ADDITIONAL_ARGS="--url=$SITE_URL"
fi
# silently ensure Jetpack is active
wp plugin activate jetpack $ADDITIONAL_ARGS >/dev/null 2>&1 --allow-root
# add extra args if available
if [ ! -z "$WP_USER" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --user=$WP_USER"
fi
if [ ! -z "$ONBOARDING" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --onboarding=$ONBOARDING"
fi
if [ ! -z "$PLAN_NAME" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --plan=$PLAN_NAME"
fi
if [ ! -z "$WPCOM_USER_ID" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --wpcom_user_id=$WPCOM_USER_ID"
fi
if [ ! -z "$FORCE_REGISTER" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --force_register=$FORCE_REGISTER"
fi
if [ ! -z "$FORCE_CONNECT" ]; then
ADDITIONAL_ARGS="$ADDITIONAL_ARGS --force_connect=$FORCE_CONNECT"
fi
# provision the partner plan
wp jetpack partner_provision "$ACCESS_TOKEN_JSON" $ADDITIONAL_ARGS --allow-root
|