#!/usr/bin/env bash # Copy and adaptation of ./test_push.sh, which takes 2 params: server key and fcm token. # It's unsafe to use it because it takes server key as parameter, that will remain in the terminal history. # Some doc # https://firebase.google.com/docs/cloud-messaging/android/first-message # http://bulkpush.com/pushnotification/guidedetail/s-4/android-gcm-api-configuration # http://www.feelzdroid.com/2016/02/android-google-cloud-messaging-push-notifications-gcm-tutorial.html if [[ "$#" -ne 2 ]]; then echo "Usage: $0 SERVER_KEY FCM_TOKEN" >&2 exit 1 fi # Get the command line parameters SERVER_KEY=$1 FCM_TOKEN=$2 echo echo "Check validity of API key, InvalidRegistration error is OK" # https://developers.google.com/cloud-messaging/http curl -H "Authorization: key=$SERVER_KEY" \ -H Content-Type:"application/json" \ -d "{\"registration_ids\":[\"ABC\"]}" \ -s \ https://fcm.googleapis.com/fcm/send \ | python -m json.tool # should obtain something like this: # {"multicast_id":5978845027639121780,"success":0,"failure":1,"canonical_ids":0,"results":[{"error":"InvalidRegistration"}]} # content of the notification DATA='{"event_id":"$THIS_IS_A_FAKE_EVENT_ID"}' echo echo echo "Send a push, you should see success:1..." curl -H "Authorization: key=$SERVER_KEY" \ -H Content-Type:"application/json" \ -d "{ \"data\" : $DATA, \"to\":\"$FCM_TOKEN\" }" \ -s \ https://fcm.googleapis.com/fcm/send \ | python -m json.tool echo echo # should obtain something like this: # {"multicast_id":7967233883611790812,"success":1,"failure":0,"canonical_ids":0,"results":[{"message_id":"0:1472636210339069%84ac25d9f9fd7ecd"}]}