Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

Python client for FCM - Firebase Cloud Messaging (Android, iOS and Web)

License

NotificationsYou must be signed in to change notification settings

olucurious/PyFCM

Repository files navigation

versionlicense

Python client for FCM - Firebase Cloud Messaging (Android, iOS and Web)

Firebase Cloud Messaging (FCM) is the new version of GCM. It inheritsthe reliable and scalable GCM infrastructure, plus new features. GCMusers are strongly recommended to upgrade to FCM.

Using FCM, you can notify a client app that new email or other data isavailable to sync. You can send notifications to drive user reengagementand retention. For use cases such as instant messaging, a message cantransfer a payload of up to 4KB to a client app.

For more information, visit:https://firebase.google.com/docs/cloud-messaging/

Links

Updates (Breaking Changes)

Installation ==========

Install using pip:

pip install pyfcmORpip install git+https://github.com/olucurious/PyFCM.git

PyFCM supports Android, iOS and Web.

Features

  • All FCM functionality covered
  • Tornado support

Examples

Send notifications using theFCMNotification class

# Send to single device.frompyfcmimportFCMNotificationfcm=FCMNotification(service_account_file="<service-account-json-path>",project_id="<project-id>")# Google oauth2 credentials(such as ADC, impersonate credentials) can be used instead of service account file.fcm=FCMNotification(service_account_file=None,credentials=your_credentials,project_id="<project-id>")# OR initialize with proxiesproxy_dict= {"http"  :"http://127.0.0.1","https" :"http://127.0.0.1",        }fcm=FCMNotification(service_account_file="<service-account-json-path>",project_id="<project-id>",proxy_dict=proxy_dict)# OR using credentials from environment variable# Often you would save service account json in evironment variable# Assuming GCP_CREDENTIALS contains the data (TIP: use "export GCP_CREDENTIALS=$(filename.json)" to quickly load the json)fromgoogle.oauth2importservice_accountgcp_json_credentials_dict=json.loads(os.getenv('GCP_CREDENTIALS',None))credentials=service_account.Credentials.from_service_account_info(gcp_json_credentials_dict,scopes=['https://www.googleapis.com/auth/firebase.messaging'])fcm=FCMNotification(service_account_file=None,credentials=credentials,project_id="<project-id>")# Your service account file can be gotten from:  https://console.firebase.google.com/u/0/project/_/settings/serviceaccounts/adminsdk# Now you are ready to send notificationfcm_token="<fcm token>"notification_title="Uber update"notification_body="Hi John, your order is on the way!"notification_image="https://example.com/image.png"result=fcm.notify(fcm_token=fcm_token,notification_title=notification_title,notification_body=notification_body,notification_image=notification_image)printresult

Send a data message

# With FCM, you can send two types of messages to clients:# 1. Notification messages, sometimes thought of as "display messages."# 2. Data messages, which are handled by the client app.# 3. Notification messages with optional data payload.# Client app is responsible for processing data messages. Data messages have only custom key-value pairs. (Python dict)# Data messages let developers send up to 4KB of custom key-value pairs.# Sending a notification with data message payloaddata_payload= {"foo":"bar","body":"great match!","room":"PortugalVSDenmark"}# To a single deviceresult=fcm.notify(fcm_token=fcm_token,notification_body=notification_body,data_payload=data_payload)# Sending a data message only payload, do NOT include notification_body also do NOT include notification body# To a single deviceresult=fcm.notify(fcm_token=fcm_token,data_payload=data_payload)# Only string key and values are accepted. booleans, nested dicts are not supported# To send nested dict, use something likedata_payload= {"foo":"bar","data":json.dumps(data).}# For more info on format see https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#Message# and https://firebase.google.com/docs/cloud-messaging/http-server-ref#downstream-http-messages-json# Use notification messages when you want FCM to handle displaying a notification on your app's behalf.# Use data messages when you just want to process the messages only in your app.# PyFCM can send a message including both notification and data payloads.# In such cases, FCM handles displaying the notification payload, and the client app handles the data payload.

Appengine users should define their environment

fcm=FCMNotification(service_account_file="<service-account-json-path>",project_id="<project-id>",proxy_dict=proxy_dict,env='app_engine')result=fcm.notify(fcm_token=fcm_token,notification_body=message)

Sending a message to a topic

# Send a message to devices subscribed to a topic.result=fcm.notify(topic_name="news",notification_body=message)# Conditional topic messagingtopic_condition="'TopicA' in topics && ('TopicB' in topics || 'TopicC' in topics)"result=fcm.notify(notification_body=message,topic_condition=topic_condition)# FCM first evaluates any conditions in parentheses, and then evaluates the expression from left to right.# In the above expression, a user subscribed to any single topic does not receive the message. Likewise,# a user who does not subscribe to TopicA does not receive the message. These combinations do receive it:# TopicA and TopicB# TopicA and TopicC# Conditions for topics support two operators per expression, and parentheses are supported.# For more information, check: https://firebase.google.com/docs/cloud-messaging/topic-messaging

Extra argument options


[8]ページ先頭

©2009-2025 Movatter.jp