pyfcm


Namepyfcm JSON
Version 2.0.7 PyPI version JSON
download
home_pagehttps://github.com/olucurious/pyfcm
SummaryPython client for FCM - Firebase Cloud Messaging (Android, iOS and Web)
upload_time2024-09-13 01:48:59
maintainerNone
docs_urlNone
authorEmmanuel Adegbite
requires_pythonNone
licenseMIT License
keywords firebase fcm apns ios gcm android push notifications
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI
coveralls test coverage No coveralls.
            # PyFCM

[![version](http://img.shields.io/pypi/v/pyfcm.svg?style=flat-square)](https://pypi.python.org/pypi/pyfcm/)
[![license](http://img.shields.io/pypi/l/pyfcm.svg?style=flat-square)](https://pypi.python.org/pypi/pyfcm/)

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

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

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

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

## Links

-   Project: <https://github.com/olucurious/pyfcm>
-   PyPi: <https://pypi.python.org/pypi/pyfcm/>

### Updates (Breaking Changes)

-   MIGRATION TO FCM HTTP V1 (JUNE 2024):
    <https://github.com/olucurious/PyFCM/releases/tag/2.0.0> (big
    shoutout to @Subhrans for the PR, for more information:
    <https://firebase.google.com/docs/cloud-messaging/migrate-v1>)
-   MAJOR UPDATES (AUGUST 2017):
    <https://github.com/olucurious/PyFCM/releases/tag/1.4.0>

Installation ==========

Install using pip:

    pip install pyfcm

    OR

    pip 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 the `FCMNotification` class

``` python
# Send to single device.
from pyfcm import FCMNotification

fcm = 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 proxies

proxy_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)

from google.oauth2 import service_account
gcp_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 notification
fcm_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)
print result
```

### Send a data message

``` python
# 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 payload
data_payload = {
    "foo": "bar",
    "body": "great match!",
    "room": "PortugalVSDenmark"
}
# To a single device
result = 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 device
result = 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 like
data_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

``` python
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

``` python
# Send a message to devices subscribed to a topic.
result = fcm.notify(topic_name="news", notification_body=message)

# Conditional topic messaging
topic_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

-   android_config (dict, optional): Android specific options for messages -
        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#androidconfig>

-   apns_config (dict, optional): Apple Push Notification Service specific options -
        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#apnsconfig>

-   webpush_config (dict, optional): Webpush protocol options -
        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#webpushconfig>

-   fcm_options (dict, optional): Platform independent options for features provided by the FCM SDKs -
        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#fcmoptions>
-  dry_run (bool, optional): If `True` no message will be sent but
        request will be tested.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/olucurious/pyfcm",
    "name": "pyfcm",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "firebase fcm apns ios gcm android push notifications",
    "author": "Emmanuel Adegbite",
    "author_email": "olucurious@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/69/4a/eea2775e0590d2ce88bce74f3f9f5da28bcb0c689e1a1e7627c3cea96268/pyfcm-2.0.7.tar.gz",
    "platform": null,
    "description": "# PyFCM\n\n[![version](http://img.shields.io/pypi/v/pyfcm.svg?style=flat-square)](https://pypi.python.org/pypi/pyfcm/)\n[![license](http://img.shields.io/pypi/l/pyfcm.svg?style=flat-square)](https://pypi.python.org/pypi/pyfcm/)\n\nPython client for FCM - Firebase Cloud Messaging (Android, iOS and Web)\n\nFirebase Cloud Messaging (FCM) is the new version of GCM. It inherits\nthe reliable and scalable GCM infrastructure, plus new features. GCM\nusers are strongly recommended to upgrade to FCM.\n\nUsing FCM, you can notify a client app that new email or other data is\navailable to sync. You can send notifications to drive user reengagement\nand retention. For use cases such as instant messaging, a message can\ntransfer a payload of up to 4KB to a client app.\n\nFor more information, visit:\n<https://firebase.google.com/docs/cloud-messaging/>\n\n## Links\n\n-   Project: <https://github.com/olucurious/pyfcm>\n-   PyPi: <https://pypi.python.org/pypi/pyfcm/>\n\n### Updates (Breaking Changes)\n\n-   MIGRATION TO FCM HTTP V1 (JUNE 2024):\n    <https://github.com/olucurious/PyFCM/releases/tag/2.0.0> (big\n    shoutout to @Subhrans for the PR, for more information:\n    <https://firebase.google.com/docs/cloud-messaging/migrate-v1>)\n-   MAJOR UPDATES (AUGUST 2017):\n    <https://github.com/olucurious/PyFCM/releases/tag/1.4.0>\n\nInstallation ==========\n\nInstall using pip:\n\n    pip install pyfcm\n\n    OR\n\n    pip install git+https://github.com/olucurious/PyFCM.git\n\nPyFCM supports Android, iOS and Web.\n\n## Features\n\n-   All FCM functionality covered\n-   Tornado support\n\n## Examples\n\n### Send notifications using the `FCMNotification` class\n\n``` python\n# Send to single device.\nfrom pyfcm import FCMNotification\n\nfcm = FCMNotification(service_account_file=\"<service-account-json-path>\", project_id=\"<project-id>\")\n\n# Google oauth2 credentials(such as ADC, impersonate credentials) can be used instead of service account file.\n\nfcm = FCMNotification(\n    service_account_file=None, credentials=your_credentials, project_id=\"<project-id>\"\n)\n\n# OR initialize with proxies\n\nproxy_dict = {\n          \"http\"  : \"http://127.0.0.1\",\n          \"https\" : \"http://127.0.0.1\",\n        }\nfcm = FCMNotification(service_account_file=\"<service-account-json-path>\", project_id=\"<project-id>\", proxy_dict=proxy_dict)\n\n# OR using credentials from environment variable\n# Often you would save service account json in evironment variable\n# Assuming GCP_CREDENTIALS contains the data (TIP: use \"export GCP_CREDENTIALS=$(filename.json)\" to quickly load the json)\n\nfrom google.oauth2 import service_account\ngcp_json_credentials_dict = json.loads(os.getenv('GCP_CREDENTIALS', None))\ncredentials = service_account.Credentials.from_service_account_info(gcp_json_credentials_dict, scopes=['https://www.googleapis.com/auth/firebase.messaging'])\nfcm = FCMNotification(service_account_file=None, credentials=credentials, project_id=\"<project-id>\")\n\n# Your service account file can be gotten from:  https://console.firebase.google.com/u/0/project/_/settings/serviceaccounts/adminsdk\n\n# Now you are ready to send notification\nfcm_token = \"<fcm token>\"\nnotification_title = \"Uber update\"\nnotification_body = \"Hi John, your order is on the way!\"\nnotification_image = \"https://example.com/image.png\"\nresult = fcm.notify(fcm_token=fcm_token, notification_title=notification_title, notification_body=notification_body, notification_image=notification_image)\nprint result\n```\n\n### Send a data message\n\n``` python\n# With FCM, you can send two types of messages to clients:\n# 1. Notification messages, sometimes thought of as \"display messages.\"\n# 2. Data messages, which are handled by the client app.\n# 3. Notification messages with optional data payload.\n\n# Client app is responsible for processing data messages. Data messages have only custom key-value pairs. (Python dict)\n# Data messages let developers send up to 4KB of custom key-value pairs.\n\n# Sending a notification with data message payload\ndata_payload = {\n    \"foo\": \"bar\",\n    \"body\": \"great match!\",\n    \"room\": \"PortugalVSDenmark\"\n}\n# To a single device\nresult = fcm.notify(fcm_token=fcm_token, notification_body=notification_body, data_payload=data_payload)\n\n# Sending a data message only payload, do NOT include notification_body also do NOT include notification body\n# To a single device\nresult = fcm.notify(fcm_token=fcm_token, data_payload=data_payload)\n\n# Only string key and values are accepted. booleans, nested dicts are not supported\n# To send nested dict, use something like\ndata_payload = {\n    \"foo\": \"bar\",\n    \"data\": json.dumps(data).\n}\n# For more info on format see https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#Message\n# and https://firebase.google.com/docs/cloud-messaging/http-server-ref#downstream-http-messages-json\n\n# Use notification messages when you want FCM to handle displaying a notification on your app's behalf.\n# Use data messages when you just want to process the messages only in your app.\n# PyFCM can send a message including both notification and data payloads.\n# In such cases, FCM handles displaying the notification payload, and the client app handles the data payload.\n```\n\n### Appengine users should define their environment\n\n``` python\nfcm = FCMNotification(service_account_file=\"<service-account-json-path>\", project_id=\"<project-id>\", proxy_dict=proxy_dict, env='app_engine')\nresult = fcm.notify(fcm_token=fcm_token, notification_body=message)\n```\n\n### Sending a message to a topic\n\n``` python\n# Send a message to devices subscribed to a topic.\nresult = fcm.notify(topic_name=\"news\", notification_body=message)\n\n# Conditional topic messaging\ntopic_condition = \"'TopicA' in topics && ('TopicB' in topics || 'TopicC' in topics)\"\nresult = fcm.notify(notification_body=message, topic_condition=topic_condition)\n# FCM first evaluates any conditions in parentheses, and then evaluates the expression from left to right.\n# In the above expression, a user subscribed to any single topic does not receive the message. Likewise,\n# a user who does not subscribe to TopicA does not receive the message. These combinations do receive it:\n# TopicA and TopicB\n# TopicA and TopicC\n# Conditions for topics support two operators per expression, and parentheses are supported.\n# For more information, check: https://firebase.google.com/docs/cloud-messaging/topic-messaging\n```\n\n### Extra argument options\n\n-   android_config (dict, optional): Android specific options for messages -\n        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#androidconfig>\n\n-   apns_config (dict, optional): Apple Push Notification Service specific options -\n        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#apnsconfig>\n\n-   webpush_config (dict, optional): Webpush protocol options -\n        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#webpushconfig>\n\n-   fcm_options (dict, optional): Platform independent options for features provided by the FCM SDKs -\n        <https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#fcmoptions>\n-  dry_run (bool, optional): If `True` no message will be sent but\n        request will be tested.\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Python client for FCM - Firebase Cloud Messaging (Android, iOS and Web)",
    "version": "2.0.7",
    "project_urls": {
        "Homepage": "https://github.com/olucurious/pyfcm"
    },
    "split_keywords": [
        "firebase",
        "fcm",
        "apns",
        "ios",
        "gcm",
        "android",
        "push",
        "notifications"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "017410584724ab36daf4f17c45a9ff58d99dd52eecd7279ff8d9d11efb8f1733",
                "md5": "6abd7bde22386bd0248693f7aa697f00",
                "sha256": "2d79f26f028fa0c3eff82d962532df6825eeafac621c2fbffbb771f39d3cf6e8"
            },
            "downloads": -1,
            "filename": "pyfcm-2.0.7-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "6abd7bde22386bd0248693f7aa697f00",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 10917,
            "upload_time": "2024-09-13T01:48:58",
            "upload_time_iso_8601": "2024-09-13T01:48:58.306527Z",
            "url": "https://files.pythonhosted.org/packages/01/74/10584724ab36daf4f17c45a9ff58d99dd52eecd7279ff8d9d11efb8f1733/pyfcm-2.0.7-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "694aeea2775e0590d2ce88bce74f3f9f5da28bcb0c689e1a1e7627c3cea96268",
                "md5": "dbee763d5827fb46e037965144cf8a39",
                "sha256": "6b9382d28e88150f3a265cef79975108b2bf644063c1e8b2b90ded25b0757369"
            },
            "downloads": -1,
            "filename": "pyfcm-2.0.7.tar.gz",
            "has_sig": false,
            "md5_digest": "dbee763d5827fb46e037965144cf8a39",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 14059,
            "upload_time": "2024-09-13T01:48:59",
            "upload_time_iso_8601": "2024-09-13T01:48:59.431388Z",
            "url": "https://files.pythonhosted.org/packages/69/4a/eea2775e0590d2ce88bce74f3f9f5da28bcb0c689e1a1e7627c3cea96268/pyfcm-2.0.7.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-09-13 01:48:59",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "olucurious",
    "github_project": "pyfcm",
    "travis_ci": true,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "pyfcm"
}
        
Elapsed time: 0.41688s