UNPKG

@topoos/push

Version:

SDK para el servicio de envío de notificaciones mediante Firebase Cloud Messaging, desarrollado en NodeJS.

167 lines (124 loc) 5.76 kB
# @topoos/push @topoos/Push - JavaScript client for push Servicio para el envío de notificaciones, utilizando Firebase Cloud Messaging. Firebase Cloud Messaging (FCM) es una solución multiplataforma que permite el envío de forma seguro de mensajes, sin coste. Puede enviar mensajes a aplicaciones cliente Android, iOS y Web This SDK is automatically generated by the [OpenAPI Generator](https://openapi-generator.tech) project: - API version: 1.0.0 - Package version: 1.0.0 - Build package: org.openapitools.codegen.languages.JavascriptClientCodegen ## Installation ### For [Node.js](https://nodejs.org/) #### npm To publish the library as a [npm](https://www.npmjs.com/), please follow the procedure in ["Publishing npm packages"](https://docs.npmjs.com/getting-started/publishing-npm-packages). Then install it via: ```shell npm install @topoos/push --save ``` Finally, you need to build the module: ```shell npm run build ``` ##### Local development To use the library locally without publishing to a remote npm registry, first install the dependencies by changing into the directory containing `package.json` (and this README). Let's call this `JAVASCRIPT_CLIENT_DIR`. Then run: ```shell npm install ``` Next, [link](https://docs.npmjs.com/cli/link) it globally in npm with the following, also from `JAVASCRIPT_CLIENT_DIR`: ```shell npm link ``` To use the link you just defined in your project, switch to the directory you want to use your push from, and run: ```shell npm link /path/to/<JAVASCRIPT_CLIENT_DIR> ``` Finally, you need to build the module: ```shell npm run build ``` #### git If the library is hosted at a git repository, e.g.https://github.com/GIT_USER_ID/GIT_REPO_ID then install it via: ```shell npm install GIT_USER_ID/GIT_REPO_ID --save ``` ### For browser The library also works in the browser environment via npm and [browserify](http://browserify.org/). After following the above steps with Node.js and installing browserify with `npm install -g browserify`, perform the following (assuming *main.js* is your entry file): ```shell browserify main.js > bundle.js ``` Then include *bundle.js* in the HTML pages. ### Webpack Configuration Using Webpack you may encounter the following error: "Module not found: Error: Cannot resolve module", most certainly you should disable AMD loader. Add/merge the following section to your webpack config: ```javascript module: { rules: [ { parser: { amd: false } } ] } ``` ## Getting Started Please follow the [installation](#installation) instruction and execute the following JS code: ```javascript var Push = require('@topoos/push'); var defaultClient = Push.ApiClient.instance; // Configure OAuth2 access token for authorization: default var default = defaultClient.authentications['default']; default.accessToken = "YOUR ACCESS TOKEN"; var api = new Push.NotificacionApi(); var callback = function(error, data, response) { if (error) { console.error(error); } else { console.log('API called successfully. Returned data: ' + data); } }; const registrationTokens = ["<reg_token>"]; const sendNotificationDevice = new Push.SendNotificationDeviceId(new Push.DeviceId(registrationTokens)); sendNotificationDevice.notification = { title: "notification title", body: "notification body", }; sendNotificationDevice.data = { atr1: "value1" }; api.sendNotification(sendNotificationDevice, callback); ``` ## Documentation for API Endpoints All URIs are relative to *http://localhost:8077/ps/v1/providers/testing* Class | Method | HTTP request | Description ------------ | ------------- | ------------- | ------------- *Push.NotificacionApi* | [**sendNotification**](docs/NotificacionApi.md#sendNotification) | **POST** /notification | Enviar notificación *Push.TopicApi* | [**subscribeToTopic**](docs/TopicApi.md#subscribeToTopic) | **POST** /topic | Suscribir dispositivos a un topic *Push.TopicApi* | [**unsubscribeFromTopic**](docs/TopicApi.md#unsubscribeFromTopic) | **DELETE** /topic | Desuscribir dispositivos a un topic *Push.UsuarioApi* | [**addDevicesToUser**](docs/UsuarioApi.md#addDevicesToUser) | **POST** /users/{userId}/devices | Añadir dispositivos asignados al usuario *Push.UsuarioApi* | [**removeDevicesFromUser**](docs/UsuarioApi.md#removeDevicesFromUser) | **DELETE** /users/{userId}/devices | Quitar dispositivos asignados al usuario ## Documentation for Models - [Push.AddDeviceToGroup](docs/AddDeviceToGroup.md) - [Push.ConditionId](docs/ConditionId.md) - [Push.DeviceId](docs/DeviceId.md) - [Push.Error](docs/Error.md) - [Push.ErrorError](docs/ErrorError.md) - [Push.ErrorErrorErrors](docs/ErrorErrorErrors.md) - [Push.Notification](docs/Notification.md) - [Push.PostNotificationResult](docs/PostNotificationResult.md) - [Push.PostNotificationResultData](docs/PostNotificationResultData.md) - [Push.PostNotificationResultDataItems](docs/PostNotificationResultDataItems.md) - [Push.SendNotificationConditionId](docs/SendNotificationConditionId.md) - [Push.SendNotificationDeviceId](docs/SendNotificationDeviceId.md) - [Push.SendNotificationOptions](docs/SendNotificationOptions.md) - [Push.SendNotificationTopicId](docs/SendNotificationTopicId.md) - [Push.SendNotificationUserId](docs/SendNotificationUserId.md) - [Push.SubscribeToTopic](docs/SubscribeToTopic.md) - [Push.SubscribeToTopicResponse](docs/SubscribeToTopicResponse.md) - [Push.SubscribeToTopicResponseData](docs/SubscribeToTopicResponseData.md) - [Push.SubscribeToTopicResponseDataFailures](docs/SubscribeToTopicResponseDataFailures.md) - [Push.SubscribeToTopicResponseDataItems](docs/SubscribeToTopicResponseDataItems.md) - [Push.TopicId](docs/TopicId.md) - [Push.UserId](docs/UserId.md)