diff --git a/bundles/org.openhab.binding.pushbullet/README.md b/bundles/org.openhab.binding.pushbullet/README.md index 54e70a65586a1..51e0cf4600885 100644 --- a/bundles/org.openhab.binding.pushbullet/README.md +++ b/bundles/org.openhab.binding.pushbullet/README.md @@ -1,45 +1,25 @@ # Pushbullet Binding -The Pushbullet binding allows you to notify iOS, Android & Windows 10 Phone & Desktop devices of a message using the Pushbullet API web service. +The Pushbullet binding allows you to notify supported devices of a message using the [Pushbullet API](https://docs.pushbullet.com). +To get started you need to [create an account](#creating-an-account) and [obtain an access token](#obtaining-an-access-token). ## Supported Things -This binding supports a generic "bot" which is a representation of the client. - -## Discovery - -This binding provides no discovery. -The desired bots must be configured manually or via a things file. - -## Binding Configuration - -The binding has no configuration options itself, all configuration is done at 'Things' level. +| Thing | Type | Description | +| ----- | ----- | ------------------------- | +| bot | Thing | Bot to send messages with | ## Thing Configuration -### Bot (`bot`) - -The bot thing is used to send messages to other recipients. -It has the following parameters: +### `bot` -| Config | Description | Required | Advanced | -|------------|------------------------------------------------------------------|----------|----------| -| token | Pushbullet [API token](#obtaining-an-api-key) to send to devices | Yes | False | -| name | Explicit Name, for later use when the bot can receive messages | No | True | -| apiUrlBase | Address of own Pushbullet server, for testing purposes | No | True | - -```java -Thing pushbullet:bot:r2d2 "R2D2" @ "Somewhere" [ token = "verysecretwonttellyou" ] - -``` +| Parameter | Required | Description | +| --------- | :------: | ---------------------------------------------------- | +| token | Yes | Access token obtained from the account settings page | ## Channels -| Channel ID | Channel Description | Supported item type | Advanced | -|------------|-------------------------------------------------|----------------------|----------| -| recipient | for later use when the bot can receive messages | String | False | -| title | for later use when the bot can receive messages | String | False | -| message | for later use when the bot can receive messages | String | False | +Currently the binding does not support any channels. ## Rule Action @@ -71,110 +51,47 @@ For the `sendPushbulletNote` action, parameter `message` is required. Likewise, for `sendPushbulletLink`, `url` and for `sendPushbulletFile`, `content` parameters are required. Any other parameters for these actions are optional and can be set to `null`. -Examples: - -```java -val actions = getActions("pushbullet", "pushbullet:bot:r2d2") -actions.sendPushbulletNote("someone@example.com", "Note Example", "This is the pushed note.") -actions.sendPushbulletLink("someone@example.com", "Link Example", "This is the pushed link", "https://example.com") -actions.sendPushbulletFile("someone@example.com", "File Example", "This is the pushed file", "https://example.com/image.png") -actions.sendPushbulletFile("someone@example.com", null, null, "/path/to/somefile.pdf", "document.pdf") -actions.sendPushbulletFile("someone@example.com", ImageItem.state.toFullString) -``` - ## Full Example -_Provide a full usage example based on textual configuration files (*.things, *.items, *.sitemap)._ - -pushbullet.things: - -```java -Thing pushbullet:bot:r2d2 "R2D2" @ "Somewhere" [ token = "verysecretwonttellyou" ] - -``` - -pushbullet.items +demo.things: ```java -Switch Pushbullet_R2D2_Button "Pushbullet Action bot R2D2" -``` - -pushbullet.sitemap +Thing pushbullet:bot:r2d2 [ token="" ] -```java -sitemap pushbullet label="Pushbullet" -{ - Switch item=Pushbullet_R2D2_Button -} ``` -pushbullet.rules +demo.rules ```java -rule "Pushbullet R2D2 changed" -when - Item Pushbullet_R2D2_Button changed -then - logInfo(filename, "Button R2D2 changed - OH2...") - - if (Pushbullet_R2D2_Button.state == ON) - { - sendCommand(Pushbullet_R2D2_Button, OFF) - - val actions = getActions("pushbullet", "pushbullet:bot:r2d2") - logInfo(filename, "Actions for 'R2D2' are: " + actions) - - if (actions != null) - { - val result = actions.sendPushbulletNote("someone@example.com", "Title R2D2 OH2", "This has been sent by the new R2D2 bot") - logInfo(filename, "Result of send action is: " + result) - } - } -end +val actions = getActions("pushbullet", "pushbullet:bot:r2d2") +// push a note +actions.sendPushbulletNote("someone@example.com", "Note Example", "This is the pushed note.") +// push a link +actions.sendPushbulletLink("someone@example.com", "Link Example", "This is the pushed link", "https://example.com") +// push a file +actions.sendPushbulletFile("someone@example.com", "File Example", "This is the pushed file", "https://example.com/image.png") +actions.sendPushbulletFile("someone@example.com", null, null, "/path/to/somefile.pdf", "document.pdf") +// use toFullString method to push the content of an Image item +actions.sendPushbulletFile("someone@example.com", ImageItem.state.toFullString) ``` -## Creating an account for your bot(s) +## Creating an account -The pushbullet accounts are bound to either Google or Facebook accounts. +A Pushbullet account is linked to either a Google or Facebook account. -- Create a bot account with either Facebook or Google -- Go to "" -- Chose to either "Sign up with Google" or "Sign up with Facebook". +- Go to the [Pushbullet](https://www.pushbullet.com) website. +- Select either "Sign up with Google" or "Sign up with Facebook". - Complete the signup process as guided by the pushbullet web site. -- Continue with "Obtaining an API key". -## Obtaining an API key +## Obtaining an access token -The API keys are bound to the pushbullet account. +An access token is linked to a Pushbullet account. -- Go to the pushbullet site. -- Log in with either your personal account or the one you created for your bot. -- Go to "" +- Go to your [Pushbullet account settings](https://www.pushbullet.com/#settings/account) page. - Click on "Create Access Token". -- Copy the token created on the site. - -You must at least provide an API token (Private or Alias Key from Pushbullet.com) and a message in some manner before a message can be pushed. -All other parameters are optional. -If you use an alias key, the parameters (device, icon, sound, vibration) are overwritten by the alias setting on pushbullet. +- Copy the created access token. ## Rate limits -As of 2019, free accounts have a limit of 100 pushes per month. -This action does not evaluate the rate limiting headers though. - -## Translation - -This project is being translated on transifex. -If you want to help, please join the project at the URL: - -- - -## Libraries - -This action has been written without using libraries as jpushbullet or jpushbullet2. -Both of those libraries use various libraries themselves which makes integrating them into openHAB a challenge. - -## pushbullet API - -- -- +As of 2024, free accounts are [limited](https://docs.pushbullet.com/#limits) to 500 pushes per month. +Going over will result in a warning message being logged indicating when your account rate limit will reset. diff --git a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletBindingConstants.java b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletBindingConstants.java index 6f55cd9c11ff5..2825dce1d8ce7 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletBindingConstants.java +++ b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletBindingConstants.java @@ -34,20 +34,19 @@ public class PushbulletBindingConstants { public static final Set SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_BOT); - // List of all Channel ids - public static final String RECIPIENT = "recipient"; - public static final String TITLE = "title"; - public static final String MESSAGE = "message"; - // Thing properties public static final String PROPERTY_EMAIL = "email"; public static final String PROPERTY_NAME = "name"; // Binding logic constants + public static final String API_BASE_URL = "https://api.pushbullet.com/v2"; + public static final String API_ENDPOINT_PUSHES = "/pushes"; public static final String API_ENDPOINT_UPLOAD_REQUEST = "/upload-request"; public static final String API_ENDPOINT_USERS_ME = "/users/me"; + public static final String HEADER_RATELIMIT_RESET = "X-Ratelimit-Reset"; + public static final String IMAGE_FILE_NAME = "image.jpg"; public static final int MAX_UPLOAD_SIZE = 26214400; diff --git a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletConfiguration.java b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletConfiguration.java index 8884d07f4a3c8..10032a6640e30 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletConfiguration.java +++ b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletConfiguration.java @@ -13,7 +13,6 @@ package org.openhab.binding.pushbullet.internal; import org.eclipse.jdt.annotation.NonNullByDefault; -import org.eclipse.jdt.annotation.Nullable; /** * The {@link PushbulletConfiguration} class contains fields mapping thing configuration parameters. @@ -24,21 +23,9 @@ @NonNullByDefault public class PushbulletConfiguration { - private @Nullable String name; - private String token = ""; - private String apiUrlBase = "https://api.pushbullet.com/v2"; - - public @Nullable String getName() { - return name; - } - public String getAccessToken() { return token; } - - public String getApiUrlBase() { - return apiUrlBase; - } } diff --git a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletHttpClient.java b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletHttpClient.java index eebd311576ac4..033d64bae78cb 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletHttpClient.java +++ b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/PushbulletHttpClient.java @@ -12,6 +12,8 @@ */ package org.openhab.binding.pushbullet.internal; +import static org.openhab.binding.pushbullet.internal.PushbulletBindingConstants.*; + import java.time.Instant; import java.util.Objects; import java.util.concurrent.ExecutionException; @@ -49,11 +51,10 @@ */ @NonNullByDefault public class PushbulletHttpClient { - private static final String AGENT = "openHAB/" + OpenHAB.getVersion(); - private static final int TIMEOUT = 30; // in seconds + private static final String USER_AGENT = "openHAB/" + OpenHAB.getVersion(); - private static final String HEADER_RATELIMIT_RESET = "X-Ratelimit-Reset"; + private static final int TIMEOUT = 30; // in seconds private final Logger logger = LoggerFactory.getLogger(PushbulletHttpClient.class); @@ -95,7 +96,7 @@ public T executeRequest(String apiEndpoint, Class responseType) throws Pu */ public T executeRequest(String apiEndpoint, @Nullable Object body, Class responseType) throws PushbulletApiException { - String url = config.getApiUrlBase() + apiEndpoint; + String url = API_BASE_URL + apiEndpoint; String accessToken = config.getAccessToken(); Request request = newRequest(url).header("Access-Token", accessToken); @@ -142,7 +143,7 @@ public void uploadFile(String url, RawType data) throws PushbulletApiException { * @return the new Request object with default parameters */ private Request newRequest(String url) { - return httpClient.newRequest(url).agent(AGENT).timeout(TIMEOUT, TimeUnit.SECONDS); + return httpClient.newRequest(url).agent(USER_AGENT).timeout(TIMEOUT, TimeUnit.SECONDS); } /** diff --git a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/handler/PushbulletHandler.java b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/handler/PushbulletHandler.java index 3055ea3f80ca5..cd45afc12a6e9 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/handler/PushbulletHandler.java +++ b/bundles/org.openhab.binding.pushbullet/src/main/java/org/openhab/binding/pushbullet/internal/handler/PushbulletHandler.java @@ -78,12 +78,7 @@ public PushbulletHandler(Thing thing, HttpClient httpClient) { @Override public void handleCommand(ChannelUID channelUID, Command command) { - logger.debug("About to handle {} on {}", command, channelUID); - - // Future improvement: If recipient is already set, send a push on a command channel change - // check reconnect channel of the unifi binding for that - - logger.debug("The Pushbullet binding is a read-only binding and cannot handle command '{}'.", command); + // do nothing } @Override diff --git a/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/i18n/pushbullet.properties b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/i18n/pushbullet.properties index beb771ae5f40e..967e305c39fce 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/i18n/pushbullet.properties +++ b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/i18n/pushbullet.properties @@ -7,20 +7,8 @@ thing-type.pushbullet.bot.label = Pushbullet Bot thing-type.pushbullet.bot.description = Bot to send messages with. # thing types config -thing-type.config.pushbullet.bot.name.label = Name -thing-type.config.pushbullet.bot.name.description = Explicit Name of Bot, if wanted thing-type.config.pushbullet.bot.token.label = Access Token -thing-type.config.pushbullet.bot.token.description = Access token obtained from the account settings page -thing-type.config.pushbullet.bot.apiUrlBase.label = API Server -thing-type.config.pushbullet.bot.apiUrlBase.description = The Pushbullet API Server to use, for local testing - -# channel types -channel-type.pushbullet.recipient-channel.label = Recipient -channel-type.pushbullet.recipient-channel.description = Mail address or Channel Name -channel-type.pushbullet.title-channel.label = Title -channel-type.pushbullet.title-channel.description = Title of the message -channel-type.pushbullet.message-channel.label = Message -channel-type.pushbullet.message-channel.description = The text that is to be sent +thing-type.config.pushbullet.bot.token.description = Access token obtained from the account settings page. # action actionSendPushbulletNoteLabel = publish a Pushbullet message @@ -42,6 +30,3 @@ actionSendPushbulletFileInputContent = File Content actionSendPushbulletFileInputContentDesc = The File Content to publish actionSendPushbulletFileInputName = File Name actionSendPushbulletFileInputNameDesc = The File Name to publish - -# error texts -offline.conf-error-httpresponseexception = The pushbullet server reported an error, possibly an expired token. Check on web site diff --git a/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/thing/thing-types.xml b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/thing/thing-types.xml index 9e5e31ef0d50f..529498ab8f585 100644 --- a/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/thing/thing-types.xml +++ b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/thing/thing-types.xml @@ -8,51 +8,18 @@ Bot to send messages with. - - - - - + + 1 + - - - Explicit Name of Bot, if wanted - true - - - Access token obtained from the account settings page - - - - - The Pushbullet API Server to use, for local testing - https://api.pushbullet.com/v2 - true + Access token obtained from the account settings page. - - String - - Mail address or Channel Name - - - - String - - Title of the message - - - - String - - The text that is to be sent - - diff --git a/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/update/instructions.xml b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/update/instructions.xml new file mode 100644 index 0000000000000..255a5b2f12c3d --- /dev/null +++ b/bundles/org.openhab.binding.pushbullet/src/main/resources/OH-INF/update/instructions.xml @@ -0,0 +1,14 @@ + + + + + + + + + + + +