summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/jetpack/bin/partner-provision.sh')
-rwxr-xr-xplugins/jetpack/bin/partner-provision.sh228
1 files changed, 228 insertions, 0 deletions
diff --git a/plugins/jetpack/bin/partner-provision.sh b/plugins/jetpack/bin/partner-provision.sh
new file mode 100755
index 00000000..587bd2a6
--- /dev/null
+++ b/plugins/jetpack/bin/partner-provision.sh
@@ -0,0 +1,228 @@
+#!/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
+
+usage () {
+ echo 'Usage: partner-provision.sh \
+ --partner_id=partner_id \
+ --partner_secret=partner_secret \
+ --user=wp_user_id \
+ [--wp-cli-path=/usr/local/bin/wp]
+ [--plan=plan_name] \
+ [--onboarding=1] \
+ [--wpcom_user_id=1234] \
+ [--wpcom_user_email=wpcom_user_email] \
+ [--url=http://example.com] \
+ [--force_connect=1] \
+ [--force_register=1] \
+ [--allow-root] \
+ [--partner-tracking-id=1]'
+}
+
+# Note: this script should always be designed to keep wp-cli OPTIONAL
+# so that it can be run outside of the WordPress installation.
+WP_CLI_COMMAND="wp"
+WP_CLI_ARGS=""
+
+# Default API host that can be overridden.
+if [ -z "$JETPACK_START_API_HOST" ]; then
+ JETPACK_START_API_HOST='public-api.wordpress.com'
+fi
+
+PROVISION_REQUEST_ARGS=""
+PROVISION_REQUEST_URL="https://$JETPACK_START_API_HOST/rest/v1.3/jpphp/provision"
+
+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#*=}"
+ WP_CLI_ARGS="$WP_CLI_ARGS --user=${i#*=}"
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form local_user=${i#*=}"
+ shift
+ ;;
+ -w=* | --wpcom_user_id=* )
+ WPCOM_USER_ID=${i#*=}
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form wpcom_user_id=${i#*=}"
+ shift
+ ;;
+ -e=* | --wpcom_user_email=* )
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form wpcom_user_email=${i#*=}"
+ shift
+ ;;
+ -p=* | --plan=* )
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form plan=${i#*=}"
+ shift
+ ;;
+ -o=* | --onboarding=* )
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form onboarding=${i#*=}"
+ shift
+ ;;
+ -u=* | --url=* )
+ WP_CLI_ARGS="$WP_CLI_ARGS --url=${i#*=}"
+ SITEURL="${i#*=}"
+ shift
+ ;;
+ --force_register=* )
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form force_register=${i#*=}"
+ shift
+ ;;
+ --force_connect=* )
+ PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form force_connect=${i#*=}"
+ shift
+ ;;
+ --partner-tracking-id=* )
+ PROVISION_REQUEST_URL="$PROVISION_REQUEST_URL?partner-tracking-id=${i#*=}"
+ shift
+ ;;
+ --allow-root )
+ WP_CLI_ARGS="$WP_CLI_ARGS --allow-root"
+ shift
+ ;;
+ --wp-cli-path=* )
+ WP_CLI_COMMAND="${i#*=}"
+ shift
+ ;;
+ -h | --help )
+ usage
+ exit
+ ;;
+ * )
+ echo $(usage) >&2
+ exit 1
+ esac
+done
+
+WP_CLI_CHECK=$($WP_CLI_COMMAND --skip-plugins --skip-themes option get home 2>/dev/null)
+if [ -z "$WP_CLI_CHECK" ]; then
+ WP_CLI_EXISTS=0
+else
+ WP_CLI_EXISTS=1
+fi
+
+if [ "$WP_CLI_EXISTS" -eq "1" ]; then
+ WP_CLI_ARGS="$WP_CLI_ARGS --skip-themes --skip-plugins=$($WP_CLI_COMMAND plugin list --field=name | grep -v ^jetpack$ | tr '\n' ',')"
+fi
+
+if [ "$CLIENT_ID" = "" ] || [ "$CLIENT_SECRET" = "" ] || [ "$WP_USER" = "" ]; then
+ echo $(usage) >&2
+ exit 1
+fi
+
+jetpack_shell_is_errored() {
+ if [ -z "$1" ]; then
+ exit 1
+ fi
+
+ JSON_ERROR=$( jetpack_echo_key_from_json "$1" error | xargs echo )
+
+ if [ -z "$JSON_ERROR" ]; then
+ return 1
+ else
+ return 0
+ fi
+}
+
+jetpack_is_wp_cli_error() {
+ if [ -z "$1" ]; then
+ exit 1
+ fi
+
+ if [ ! -z $( echo "$1" | grep Error:) ] || [ -z "$1" ]; then
+ return 0
+ fi
+
+ return 1
+}
+
+jetpack_echo_key_from_json() {
+ if [ -z "$1" ]; then
+ exit 1
+ fi
+
+ echo $1 | sed -n "s/.*\"$2\":\"\([^\"]*\)\".*/\1/p"
+}
+
+# Fetch an access token using our client ID/secret.
+ACCESS_TOKEN_JSON=$(
+ curl \
+ --silent \
+ --request POST \
+ --url https://$JETPACK_START_API_HOST/oauth2/token \
+ --header 'cache-control: no-cache' \
+ --header 'content-type: multipart/form-data;' \
+ --header "Host: public-api.wordpress.com" \
+ --form client_id="$CLIENT_ID" \
+ --form client_secret="$CLIENT_SECRET" \
+ --form grant_type=client_credentials \
+ --form scope=jetpack-partner
+)
+
+if jetpack_shell_is_errored "$ACCESS_TOKEN_JSON"; then
+ echo "$ACCESS_TOKEN_JSON" >&2
+ exit 1
+fi
+
+ACCESS_TOKEN=$( jetpack_echo_key_from_json "$ACCESS_TOKEN_JSON" access_token | xargs echo )
+
+# If we don't have an access token, we can't go further.
+if [ -z "$ACCESS_TOKEN" ] || [ "$ACCESS_TOKEN" = "" ]; then
+ echo "$ACCESS_TOKEN_JSON" >&2
+ exit 1
+fi
+
+# Silently ensure Jetpack is active
+# Intentionally not quoting $WP_CLI_ARGS so that words in the string are split
+if [ "$WP_CLI_EXISTS" -eq "1" ]; then
+ $WP_CLI_COMMAND $WP_CLI_ARGS plugin activate jetpack >/dev/null 2>&1
+fi
+
+if [ -z "$SITEURL" ] && [ "$WP_CLI_EXISTS" -eq "1" ]; then
+ SITEURL=$( $WP_CLI_COMMAND $WP_CLI_ARGS option get siteurl | xargs echo )
+fi
+
+PROVISION_REQUEST_ARGS="$PROVISION_REQUEST_ARGS --form siteurl=$SITEURL"
+
+PROVISION_REQUEST=$(
+ curl \
+ --silent \
+ --request POST \
+ --url "$PROVISION_REQUEST_URL" \
+ --header "authorization: Bearer $ACCESS_TOKEN" \
+ --header "Host: public-api.wordpress.com" \
+ --header 'cache-control: no-cache' \
+ --header 'content-type: multipart/form-data;' \
+ $PROVISION_REQUEST_ARGS
+)
+
+if [ -z "$PROVISION_REQUEST" ]; then
+ echo "{\"success\":false,\"error_code\":\"unknown_error\",\"error_message\":\"Empty response from server\"}" >&2
+fi
+
+if jetpack_shell_is_errored "$PROVISION_REQUEST"; then
+ echo "$PROVISION_REQUEST" >&2
+ exit 1
+fi
+
+# Get the access token for the Jetpack connection.
+ACCESS_TOKEN=$( jetpack_echo_key_from_json "$PROVISION_REQUEST" access_token | xargs echo )
+
+# If we have an access token, set it and activate default modules!
+if [ ! -z "$ACCESS_TOKEN" ] && [ "$ACCESS_TOKEN" != "" ] && [ ! -z "$WPCOM_USER_ID" ] && [ "$WP_CLI_EXISTS" -eq "1" ]; then
+ AUTHORIZE_RESULT=$( $WP_CLI_COMMAND $WP_CLI_ARGS jetpack authorize_user --token="$ACCESS_TOKEN" )
+ if jetpack_is_wp_cli_error "$AUTHORIZE_RESULT"; then
+ echo "{\"success\":false,\"error_code\":\"authorization_failure\",\"error_message\":\"$AUTHORIZE_RESULT\"}" >&2
+ exit 1
+ fi
+fi
+
+echo "$PROVISION_REQUEST"
+exit 0