diff --git a/CODEOWNERS b/CODEOWNERS
index 6d8ddc9c790..4b4e4a859c7 100644
--- a/CODEOWNERS
+++ b/CODEOWNERS
@@ -355,7 +355,6 @@
/bundles/org.openhab.binding.tplinksmarthome/ @Hilbrand
/bundles/org.openhab.binding.tr064/ @J-N-K
/bundles/org.openhab.binding.tradfri/ @cweitkamp @kaikreuzer
-/bundles/org.openhab.binding.twitter/ @computergeek1507
/bundles/org.openhab.binding.unifi/ @mgbowman @Hilbrand
/bundles/org.openhab.binding.unifiedremote/ @GiviMAD
/bundles/org.openhab.binding.upb/ @marcusb
@@ -386,6 +385,7 @@
/bundles/org.openhab.binding.wled/ @Skinah
/bundles/org.openhab.binding.wolfsmartset/ @BoBiene
/bundles/org.openhab.binding.wundergroundupdatereceiver/ @danieldemus
+/bundles/org.openhab.binding.x/ @computergeek1507
/bundles/org.openhab.binding.xmltv/ @clinique
/bundles/org.openhab.binding.xmppclient/ @pavel-gololobov
/bundles/org.openhab.binding.yamahamusiccast/ @coop-git
diff --git a/bom/openhab-addons/pom.xml b/bom/openhab-addons/pom.xml
index 9f322e518bc..bfee3215ad3 100644
--- a/bom/openhab-addons/pom.xml
+++ b/bom/openhab-addons/pom.xml
@@ -1761,11 +1761,6 @@
org.openhab.binding.tradfri
${project.version}
-
- org.openhab.addons.bundles
- org.openhab.binding.twitter
- ${project.version}
-
org.openhab.addons.bundles
org.openhab.binding.unifi
@@ -1921,6 +1916,11 @@
org.openhab.binding.wundergroundupdatereceiver
${project.version}
+
+ org.openhab.addons.bundles
+ org.openhab.binding.x
+ ${project.version}
+
org.openhab.addons.bundles
org.openhab.binding.xmltv
diff --git a/bundles/org.openhab.binding.twitter/README.md b/bundles/org.openhab.binding.twitter/README.md
deleted file mode 100644
index b0ed2e6abae..00000000000
--- a/bundles/org.openhab.binding.twitter/README.md
+++ /dev/null
@@ -1,63 +0,0 @@
-# Twitter Binding
-
-The Twitter binding allows your home to Tweet 280 characters at a time. It also supports direct messages and tweeting with media.
-
-## Supported Things
-
-```text
-account - Twitter Account.
-```
-
-## Thing Configuration
-
-The Twitter Account Thing requires you to create a Twitter App in the Twitter Developer Page.
-
-| Property | Default | Required | Description |
-|-------------------|---------|:--------:|-----------------------------------|
-| consumerKey | | Yes | Consumer API Key |
-| consumerSecret | | Yes | Consumer API Secret |
-| accessToken | | Yes | Access Token |
-| accessTokenSecret | | Yes | Access Token Secret |
-| refresh | 30 | No | Tweet refresh interval in minutes |
-
-## Channels
-
-| channel | type | description |
-|------------|--------|------------------------------------------------|
-| lasttweet | String | This channel provides the Latest Tweet message |
-
-## Full Example
-
-twitter.things:
-
-```java
-Thing twitter:account:sampleaccount [ consumerKey="11111", consumerSecret="22222", accessToken="33333", accessTokenSecret="444444" ]
-
-```
-
-twitter.items:
-
-```java
-String sample_tweet "Latest Tweet: [%s]" { channel="twitter:account:sampleaccount:lasttweet" }
-
-```
-
-## Rule Action
-
-This binding includes rule actions for sending tweets and direct messages.
-
-- `boolean success = sendTweet(String text)`
-- `boolean success = sendTweetWithAttachment(String text, String URL)`
-- `boolean success = sendDirectMessage(String recipientID, String text)`
-
-Examples:
-
-```java
-val tweetActions = getActions("twitter","twitter:account:sampleaccount")
-val success = tweetActions.sendTweet("This is A Tweet")
-val success2 = tweetActions.sendTweetWithAttachment("This is A Tweet with a Pic", file:///tmp/201601011031.jpg)
-val success3 = tweetActions.sendTweetWithAttachment("Windows Picture", "D:\\Test.png" )
-val success4 = tweetActions.sendTweetWithAttachment("HTTP Picture", "http://www.mywebsite.com/Test.png" )
-val success5 = tweetActions.sendDirectMessage("1234567", "Wake Up" )
-
-```
diff --git a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter.properties b/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter.properties
deleted file mode 100644
index 161cccf2a81..00000000000
--- a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter.properties
+++ /dev/null
@@ -1,32 +0,0 @@
-# add-on
-
-addon.twitter.name = Twitter Binding
-addon.twitter.description = Supports adding Thing for getting the Last Tweet. Send Tweets and Pictures with Actions.
-
-# thing types
-
-thing-type.twitter.account.label = Twitter Account
-thing-type.twitter.account.description = Account uses for sending Tweets
-
-# thing types config
-
-thing-type.config.twitter.account.accessToken.label = Access Token
-thing-type.config.twitter.account.accessTokenSecret.label = Access Token Secret
-thing-type.config.twitter.account.consumerKey.label = Consumer API Key
-thing-type.config.twitter.account.consumerSecret.label = Consumer API Secret
-thing-type.config.twitter.account.refresh.label = Refresh Time
-thing-type.config.twitter.account.refresh.description = Refresh Time for This Account in Mins
-
-# channel types
-
-channel-type.twitter.lasttweet.label = Last Tweet
-channel-type.twitter.lasttweet.description = Users Last Tweet
-
-# actions
-
-sendAttachmentTweetActionLabel = send a Tweet with attachment
-sendAttachmentTweetActionDescription = Sends a Tweet with an attachment.
-sendDirectMessageActionLabel = send a DirectMessage
-sendDirectMessageActionDescription = Sends a DirectMessage.
-sendTweetActionLabel = send a Tweet
-sendTweetActionDescription = Sends a Tweet.
diff --git a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_fr.properties b/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_fr.properties
deleted file mode 100644
index 06d82693efb..00000000000
--- a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_fr.properties
+++ /dev/null
@@ -1,32 +0,0 @@
-# add-on
-
-addon.twitter.name = Extension Twitter
-addon.twitter.description = Cette extension permet d'obtenir le dernier Tweet ou d'envoyer des Tweets et des images depuis vos règles d'automatisation.
-
-# thing types
-
-thing-type.twitter.account.label = Compte Twitter
-thing-type.twitter.account.description = Compte pour envoyer des Tweets
-
-# thing types config
-
-thing-type.config.twitter.account.accessToken.label = Jeton d'authentification
-thing-type.config.twitter.account.accessTokenSecret.label = Code secret du jeton d'authentification
-thing-type.config.twitter.account.consumerKey.label = Clé d'accès à l'API
-thing-type.config.twitter.account.consumerSecret.label = Code secret pour l'accès à l'API
-thing-type.config.twitter.account.refresh.label = Fréquence de rafraîchissement
-thing-type.config.twitter.account.refresh.description = Fréquence de rafraîchissement de ce compte en minutes
-
-# channel types
-
-channel-type.twitter.lasttweet.label = Dernier Tweet
-channel-type.twitter.lasttweet.description = Dernier Tweet des utilisateurs
-
-# actions
-
-sendAttachmentTweetActionLabel = envoyer un Tweet avec pièce jointe
-sendAttachmentTweetActionDescription = Envoie un Tweet avec pièce jointe.
-sendDirectMessageActionLabel = envoyer un message privé
-sendDirectMessageActionDescription = Envoie un message privé.
-sendTweetActionLabel = envoyer un Tweet
-sendTweetActionDescription = Envoie un Tweet.
diff --git a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_ru.properties b/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_ru.properties
deleted file mode 100644
index 69919458307..00000000000
--- a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/i18n/twitter_ru.properties
+++ /dev/null
@@ -1,9 +0,0 @@
-# actions
-sendTweetActionLabel = отправить твит
-sendTweetActionDescription = Отправляет твит.
-
-sendAttachmentTweetActionLabel = отправить твит с вложением
-sendAttachmentTweetActionDescription = Отправляет твит с вложением.
-
-sendDirectMessageActionLabel = отправить личное сообщение
-sendDirectMessageActionDescription = Отправляет личное сообщение.
diff --git a/bundles/org.openhab.binding.twitter/NOTICE b/bundles/org.openhab.binding.x/NOTICE
similarity index 100%
rename from bundles/org.openhab.binding.twitter/NOTICE
rename to bundles/org.openhab.binding.x/NOTICE
diff --git a/bundles/org.openhab.binding.x/README.md b/bundles/org.openhab.binding.x/README.md
new file mode 100644
index 00000000000..846ee864b11
--- /dev/null
+++ b/bundles/org.openhab.binding.x/README.md
@@ -0,0 +1,60 @@
+# X Binding
+
+The X (formerly known as Twitter) binding allows your home to post 280 characters at a time. It also supports direct messages and posting with media.
+
+## Supported Things
+
+```text
+account - X Account.
+```
+
+## Thing Configuration
+
+The X Account Thing requires you to create a X App in the X Developer Page.
+
+| Property | Default | Required | Description |
+|-------------------|---------|:--------:|-----------------------------------|
+| consumerKey | | Yes | Consumer API Key |
+| consumerSecret | | Yes | Consumer API Secret |
+| accessToken | | Yes | Access Token |
+| accessTokenSecret | | Yes | Access Token Secret |
+| refresh | 30 | No | Post refresh interval in minutes |
+
+## Channels
+
+| channel | type | description |
+|----------|--------|-----------------------------------------------|
+| lastpost | String | This channel provides the Latest post message |
+
+## Full Example
+
+x.things:
+
+```java
+Thing x:account:sampleaccount [ consumerKey="11111", consumerSecret="22222", accessToken="33333", accessTokenSecret="444444" ]
+```
+
+x.items:
+
+```java
+String sample_post "Latest post: [%s]" { channel="x:account:sampleaccount:lastpost" }
+```
+
+## Rule Action
+
+This binding includes rule actions for sending posts and direct messages.
+
+- `boolean success = sendPost(String text)`
+- `boolean success = sendPostWithAttachment(String text, String URL)`
+- `boolean success = sendDirectMessage(String recipientID, String text)`
+
+Examples:
+
+```java
+val postActions = getActions("x","x:account:sampleaccount")
+val success = postActions.sendPost("This is A Post")
+val success2 = postActions.sendPostWithAttachment("This is A Post with a Pic", file:///tmp/201601011031.jpg)
+val success3 = postActions.sendPostWithAttachment("Windows Picture", "D:\\Test.png" )
+val success4 = postActions.sendPostWithAttachment("HTTP Picture", "http://www.mywebsite.com/Test.png" )
+val success5 = postActions.sendDirectMessage("1234567", "Wake Up" )
+```
diff --git a/bundles/org.openhab.binding.twitter/pom.xml b/bundles/org.openhab.binding.x/pom.xml
similarity index 67%
rename from bundles/org.openhab.binding.twitter/pom.xml
rename to bundles/org.openhab.binding.x/pom.xml
index 00e42c8b7ff..f7020d2f91e 100644
--- a/bundles/org.openhab.binding.twitter/pom.xml
+++ b/bundles/org.openhab.binding.x/pom.xml
@@ -10,19 +10,19 @@
4.1.0-SNAPSHOT
- org.openhab.binding.twitter
+ org.openhab.binding.x
- openHAB Add-ons :: Bundles :: Twitter Binding
+ openHAB Add-ons :: Bundles :: X Binding
- !android.*,!com.android.org.*,!dalvik.*,!javax.annotation.meta.*,!org.apache.harmony.*,!org.conscrypt.*,!sun.*,!com.google.appengine.api.*
+ !org.slf4j.impl.*,!android.*,!com.android.org.*,!dalvik.*,!javax.annotation.meta.*,!org.apache.harmony.*,!org.conscrypt.*,!sun.*,!com.google.appengine.api.*
org.twitter4j
twitter4j-core
- 4.0.7
+ 4.1.2
compile
diff --git a/bundles/org.openhab.binding.twitter/src/main/feature/feature.xml b/bundles/org.openhab.binding.x/src/main/feature/feature.xml
similarity index 53%
rename from bundles/org.openhab.binding.twitter/src/main/feature/feature.xml
rename to bundles/org.openhab.binding.x/src/main/feature/feature.xml
index 86048f2829f..ffb954879f7 100644
--- a/bundles/org.openhab.binding.twitter/src/main/feature/feature.xml
+++ b/bundles/org.openhab.binding.x/src/main/feature/feature.xml
@@ -1,9 +1,9 @@
-
+
mvn:org.openhab.core.features.karaf/org.openhab.core.features.karaf.openhab-core/${ohc.version}/xml/features
-
+
openhab-runtime-base
- mvn:org.openhab.addons.bundles/org.openhab.binding.twitter/${project.version}
+ mvn:org.openhab.addons.bundles/org.openhab.binding.x/${project.version}
diff --git a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterBindingConstants.java b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XBindingConstants.java
similarity index 72%
rename from bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterBindingConstants.java
rename to bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XBindingConstants.java
index c42baaeb2ba..d35f5246b62 100644
--- a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterBindingConstants.java
+++ b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XBindingConstants.java
@@ -10,25 +10,25 @@
*
* SPDX-License-Identifier: EPL-2.0
*/
-package org.openhab.binding.twitter.internal;
+package org.openhab.binding.x.internal;
import org.eclipse.jdt.annotation.NonNullByDefault;
import org.openhab.core.thing.ThingTypeUID;
/**
- * The {@link TwitterBindingConstants} class defines common constants, which are
+ * The {@link XBindingConstants} class defines common constants, which are
* used across the whole binding.
*
* @author Scott Hanson - Initial contribution
*/
@NonNullByDefault
-public class TwitterBindingConstants {
+public class XBindingConstants {
- private static final String BINDING_ID = "twitter";
+ private static final String BINDING_ID = "x";
// List of all Thing Type UIDs
public static final ThingTypeUID THING_TYPE_ACCOUNT = new ThingTypeUID(BINDING_ID, "account");
// List of all Channel ids
- public static final String CHANNEL_LASTTWEET = "lasttweet";
+ public static final String CHANNEL_LASTPOST = "lastpost";
}
diff --git a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandler.java b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandler.java
similarity index 64%
rename from bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandler.java
rename to bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandler.java
index 8b962d7902e..b262840e2e6 100644
--- a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandler.java
+++ b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandler.java
@@ -10,9 +10,9 @@
*
* SPDX-License-Identifier: EPL-2.0
*/
-package org.openhab.binding.twitter.internal;
+package org.openhab.binding.x.internal;
-import static org.openhab.binding.twitter.internal.TwitterBindingConstants.CHANNEL_LASTTWEET;
+import static org.openhab.binding.x.internal.XBindingConstants.CHANNEL_LASTPOST;
import java.io.File;
import java.io.FileNotFoundException;
@@ -27,8 +27,8 @@ import java.util.concurrent.TimeUnit;
import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable;
-import org.openhab.binding.twitter.internal.action.TwitterActions;
-import org.openhab.binding.twitter.internal.config.TwitterConfig;
+import org.openhab.binding.x.internal.action.XActions;
+import org.openhab.binding.x.internal.config.XConfig;
import org.openhab.core.io.net.http.HttpUtil;
import org.openhab.core.library.types.RawType;
import org.openhab.core.library.types.StringType;
@@ -41,28 +41,26 @@ import org.openhab.core.types.Command;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-import twitter4j.DirectMessage;
-import twitter4j.ResponseList;
-import twitter4j.Status;
-import twitter4j.StatusUpdate;
import twitter4j.Twitter;
import twitter4j.TwitterException;
-import twitter4j.TwitterFactory;
-import twitter4j.auth.AccessToken;
+import twitter4j.v1.DirectMessage;
+import twitter4j.v1.ResponseList;
+import twitter4j.v1.Status;
+import twitter4j.v1.StatusUpdate;
/**
- * The {@link TwitterHandler} is responsible for handling commands, which are
+ * The {@link XHandler} is responsible for handling commands, which are
* sent to one of the channels.
*
* @author Scott Hanson - Initial contribution
*/
@NonNullByDefault
-public class TwitterHandler extends BaseThingHandler {
+public class XHandler extends BaseThingHandler {
- private final Logger logger = LoggerFactory.getLogger(TwitterHandler.class);
+ private final Logger logger = LoggerFactory.getLogger(XHandler.class);
- private TwitterConfig config = new TwitterConfig();
+ private XConfig config = new XConfig();
private @Nullable ScheduledFuture> refreshTask;
@@ -71,7 +69,7 @@ public class TwitterHandler extends BaseThingHandler {
private static @Nullable Twitter client = null;
boolean isProperlyConfigured = false;
- public TwitterHandler(Thing thing) {
+ public XHandler(Thing thing) {
super(thing);
}
@@ -82,14 +80,14 @@ public class TwitterHandler extends BaseThingHandler {
// creates list of available Actions
@Override
public Collection> getServices() {
- return List.of(TwitterActions.class);
+ return List.of(XActions.class);
}
@Override
public void initialize() {
- config = getConfigAs(TwitterConfig.class);
+ config = getConfigAs(XConfig.class);
- // create a New Twitter Client
+ // create a New X/Twitter Client
Twitter localClient = createClient();
client = localClient;
refresh();// Get latest status
@@ -107,7 +105,7 @@ public class TwitterHandler extends BaseThingHandler {
}
/**
- * Internal method for Getting Twitter Status
+ * Internal method for Getting X Status
*
*/
private void refresh() {
@@ -117,83 +115,83 @@ public class TwitterHandler extends BaseThingHandler {
}
Twitter localClient = client;
if (localClient != null) {
- ResponseList statuses = localClient.getUserTimeline();
+ ResponseList statuses = localClient.v1().timelines().getUserTimeline();
if (!statuses.isEmpty()) {
- updateState(CHANNEL_LASTTWEET, StringType.valueOf(statuses.get(0).getText()));
+ updateState(CHANNEL_LASTPOST, StringType.valueOf(statuses.get(0).getText()));
} else {
logger.debug("No Statuses Found");
}
}
} catch (TwitterException e) {
- logger.debug("Error when trying to refresh Twitter Account: {}", e.getMessage());
+ logger.debug("Error when trying to refresh X Account: {}", e.getMessage());
}
}
/**
- * Internal method for sending a tweet, with or without image
+ * Internal method for sending a post, with or without image
*
- * @param tweetTxt
- * text string to be sent as a Tweet
+ * @param postTxt
+ * text string to be sent as a Post
* @param fileToAttach
* the file to attach. May be null if no attached file.
*
- * @return true
, if sending the tweet has been successful and
+ * @return true
, if sending the post has been successful and
* false
in all other cases.
*/
- private boolean sendTweet(final String tweetTxt, final @Nullable File fileToAttach) {
+ private boolean sendPost(final String postTxt, final @Nullable File fileToAttach) {
if (!checkPrerequisites()) {
return false;
}
- // abbreviate the Tweet to meet the 280 character limit ...
- String abbreviatedTweetTxt = abbreviateString(tweetTxt, CHARACTER_LIMIT);
+ // abbreviate the Post to meet the 280 character limit ...
+ String abbreviatedPostTxt = abbreviateString(postTxt, CHARACTER_LIMIT);
try {
Twitter localClient = client;
if (localClient != null) {
- // send the Tweet
- StatusUpdate status = new StatusUpdate(abbreviatedTweetTxt);
+ // send the Post
+ StatusUpdate status = StatusUpdate.of(abbreviatedPostTxt);
if (fileToAttach != null && fileToAttach.isFile()) {
- status.setMedia(fileToAttach);
+ status = status.media(fileToAttach);
}
- Status updatedStatus = localClient.updateStatus(status);
- logger.debug("Successfully sent Tweet '{}'", updatedStatus.getText());
- updateState(CHANNEL_LASTTWEET, StringType.valueOf(updatedStatus.getText()));
+ Status updatedStatus = localClient.v1().tweets().updateStatus(status);
+ logger.debug("Successfully sent Post '{}'", updatedStatus.getText());
+ updateState(CHANNEL_LASTPOST, StringType.valueOf(updatedStatus.getText()));
return true;
}
} catch (TwitterException e) {
- logger.warn("Failed to send Tweet '{}' because of : {}", abbreviatedTweetTxt, e.getLocalizedMessage());
+ logger.warn("Failed to send Post '{}' because of : {}", abbreviatedPostTxt, e.getLocalizedMessage());
}
return false;
}
/**
- * Sends a standard Tweet.
+ * Sends a standard Post.
*
- * @param tweetTxt
- * text string to be sent as a Tweet
+ * @param postTxt
+ * text string to be sent as a Post
*
- * @return true
, if sending the tweet has been successful and
+ * @return true
, if sending the post has been successful and
* false
in all other cases.
*/
- public boolean sendTweet(String tweetTxt) {
+ public boolean sendPost(String postTxt) {
if (!checkPrerequisites()) {
return false;
}
- return sendTweet(tweetTxt, (File) null);
+ return sendPost(postTxt, (File) null);
}
/**
- * Sends a Tweet with an image
+ * Sends a Post with an image
*
- * @param tweetTxt
- * text string to be sent as a Tweet
- * @param tweetPicture
+ * @param postTxt
+ * text string to be sent as a Post
+ * @param postPicture
* the path of the picture that needs to be attached (either an url,
* either a path pointing to a local file)
*
- * @return true
, if sending the tweet has been successful and
+ * @return true
, if sending the post has been successful and
* false
in all other cases.
*/
- public boolean sendTweet(String tweetTxt, String tweetPicture) {
+ public boolean sendPost(String postTxt, String postPicture) {
if (!checkPrerequisites()) {
return false;
}
@@ -201,18 +199,18 @@ public class TwitterHandler extends BaseThingHandler {
// prepare the image attachment
File fileToAttach = null;
boolean deleteTemporaryFile = false;
- if (tweetPicture.startsWith("http://") || tweetPicture.startsWith("https://")) {
+ if (postPicture.startsWith("http://") || postPicture.startsWith("https://")) {
try {
// we have a remote url and need to download the remote file to a temporary location
Path tDir = Files.createTempDirectory("TempDirectory");
- String path = tDir + File.separator + "openhab-twitter-remote_attached_file" + "."
- + getExtension(tweetPicture);
+ String path = tDir + File.separator + "openhab-x-remote_attached_file" + "."
+ + getExtension(postPicture);
- // URL url = new URL(tweetPicture);
+ // URL url = new URL(postPicture);
fileToAttach = new File(path);
deleteTemporaryFile = true;
- RawType rawPicture = HttpUtil.downloadImage(tweetPicture);
+ RawType rawPicture = HttpUtil.downloadImage(postPicture);
if (rawPicture != null) {
try (FileOutputStream fos = new FileOutputStream(path)) {
fos.write(rawPicture.getBytes(), 0, rawPicture.getBytes().length);
@@ -222,24 +220,24 @@ public class TwitterHandler extends BaseThingHandler {
logger.debug("Could not write {} to temp dir. {}", path, ex.getMessage());
}
} else {
- logger.debug("Could not download tweet file from {}", tweetPicture);
+ logger.debug("Could not download post file from {}", postPicture);
}
} catch (IOException ex) {
- logger.debug("Could not write {} to temp dir. {}", tweetPicture, ex.getMessage());
+ logger.debug("Could not write {} to temp dir. {}", postPicture, ex.getMessage());
}
} else {
// we have a local file and can just use it directly
- fileToAttach = new File(tweetPicture);
+ fileToAttach = new File(postPicture);
}
if (fileToAttach != null && fileToAttach.isFile()) {
- logger.debug("Image '{}' correctly found, will be included in tweet", tweetPicture);
+ logger.debug("Image '{}' correctly found, will be included in post", postPicture);
} else {
- logger.warn("Image '{}' not found, will only tweet text", tweetPicture);
+ logger.warn("Image '{}' not found, will only post text", postPicture);
}
- // send the Tweet
- boolean result = sendTweet(tweetTxt, fileToAttach);
+ // send the Post
+ boolean result = sendPost(postTxt, fileToAttach);
// delete temp file (if needed)
if (deleteTemporaryFile) {
if (fileToAttach != null) {
@@ -272,10 +270,11 @@ public class TwitterHandler extends BaseThingHandler {
try {
Twitter localClient = client;
if (localClient != null) {
- // abbreviate the Tweet to meet the allowed character limit ...
+ // abbreviate the Post to meet the allowed character limit ...
String abbreviatedMessageTxt = abbreviateString(messageTxt, CHARACTER_LIMIT);
// send the direct message
- DirectMessage message = localClient.sendDirectMessage(recipientId, abbreviatedMessageTxt);
+ DirectMessage message = localClient.v1().directMessages().sendDirectMessage(recipientId,
+ abbreviatedMessageTxt);
logger.debug("Successfully sent direct message '{}' to @'{}'", message.getText(),
message.getRecipientId());
return true;
@@ -287,18 +286,18 @@ public class TwitterHandler extends BaseThingHandler {
}
/**
- * check if twitter account was created with prerequisites
- *
- * @return true
, if twitter account was initialized
+ * check if X account was created with prerequisites
+ *
+ * @return true
, if X account was initialized
* false
in all other cases.
*/
private boolean checkPrerequisites() {
if (client == null) {
- logger.debug("Twitter client is not yet configured > execution aborted!");
+ logger.debug("X client is not yet configured > execution aborted!");
return false;
}
if (!isProperlyConfigured) {
- logger.debug("Twitter client is not yet configured > execution aborted!");
+ logger.debug("X client is not yet configured > execution aborted!");
return false;
}
return true;
@@ -310,9 +309,9 @@ public class TwitterHandler extends BaseThingHandler {
* @return a new instance of a Twitter4J Twitter client.
*/
private twitter4j.Twitter createClient() {
- twitter4j.Twitter client = TwitterFactory.getSingleton();
- client.setOAuthConsumer(config.consumerKey, config.consumerSecret);
- client.setOAuthAccessToken(new AccessToken(config.accessToken, config.accessTokenSecret));
+ Twitter client = Twitter.newBuilder().oAuthConsumer(config.consumerKey, config.consumerSecret)
+ .oAuthAccessToken(config.accessToken, config.accessTokenSecret).build();
+
return client;
}
diff --git a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandlerFactory.java b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandlerFactory.java
similarity index 76%
rename from bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandlerFactory.java
rename to bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandlerFactory.java
index d27f76f7bd9..50a9341d252 100644
--- a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/TwitterHandlerFactory.java
+++ b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/XHandlerFactory.java
@@ -10,9 +10,9 @@
*
* SPDX-License-Identifier: EPL-2.0
*/
-package org.openhab.binding.twitter.internal;
+package org.openhab.binding.x.internal;
-import static org.openhab.binding.twitter.internal.TwitterBindingConstants.THING_TYPE_ACCOUNT;
+import static org.openhab.binding.x.internal.XBindingConstants.THING_TYPE_ACCOUNT;
import java.util.Set;
@@ -26,14 +26,14 @@ import org.openhab.core.thing.binding.ThingHandlerFactory;
import org.osgi.service.component.annotations.Component;
/**
- * The {@link TwitterHandlerFactory} is responsible for creating things and thing
+ * The {@link XHandlerFactory} is responsible for creating things and thing
* handlers.
*
* @author Scott Hanson - Initial contribution
*/
@NonNullByDefault
-@Component(configurationPid = "binding.twitter", service = ThingHandlerFactory.class)
-public class TwitterHandlerFactory extends BaseThingHandlerFactory {
+@Component(configurationPid = "binding.x", service = ThingHandlerFactory.class)
+public class XHandlerFactory extends BaseThingHandlerFactory {
private static final Set SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_ACCOUNT);
@@ -47,7 +47,7 @@ public class TwitterHandlerFactory extends BaseThingHandlerFactory {
ThingTypeUID thingTypeUID = thing.getThingTypeUID();
if (THING_TYPE_ACCOUNT.equals(thingTypeUID)) {
- return new TwitterHandler(thing);
+ return new XHandler(thing);
}
return null;
diff --git a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/action/TwitterActions.java b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/action/XActions.java
similarity index 60%
rename from bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/action/TwitterActions.java
rename to bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/action/XActions.java
index 12a56c35741..8133645ddf4 100644
--- a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/action/TwitterActions.java
+++ b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/action/XActions.java
@@ -10,11 +10,11 @@
*
* SPDX-License-Identifier: EPL-2.0
*/
-package org.openhab.binding.twitter.internal.action;
+package org.openhab.binding.x.internal.action;
import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable;
-import org.openhab.binding.twitter.internal.TwitterHandler;
+import org.openhab.binding.x.internal.XHandler;
import org.openhab.core.automation.annotation.ActionInput;
import org.openhab.core.automation.annotation.ActionOutput;
import org.openhab.core.automation.annotation.RuleAction;
@@ -25,53 +25,53 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
- * The {@link TwitterActions} class defines rule actions for sending tweet
+ * The {@link XActions} class defines rule actions for sending post
*
* @author Scott Hanson - Initial contribution
*/
-@ThingActionsScope(name = "twitter")
+@ThingActionsScope(name = "x")
@NonNullByDefault
-public class TwitterActions implements ThingActions {
+public class XActions implements ThingActions {
- private final Logger logger = LoggerFactory.getLogger(TwitterActions.class);
+ private final Logger logger = LoggerFactory.getLogger(XActions.class);
- private @Nullable TwitterHandler handler;
+ private @Nullable XHandler handler;
- @RuleAction(label = "@text/sendTweetActionLabel", description = "@text/sendTweetActionDescription")
- public @ActionOutput(name = "success", type = "java.lang.Boolean") Boolean sendTweet(
+ @RuleAction(label = "@text/sendPostActionLabel", description = "@text/sendPostActionDescription")
+ public @ActionOutput(name = "success", type = "java.lang.Boolean") Boolean sendPost(
@ActionInput(name = "text") @Nullable String text) {
if (text == null) {
- logger.warn("Cannot send Tweet as text is missing.");
+ logger.warn("Cannot send Post as text is missing.");
return false;
}
- final TwitterHandler handler = this.handler;
+ final XHandler handler = this.handler;
if (handler == null) {
- logger.debug("Handler is null, cannot tweet.");
+ logger.debug("Handler is null, cannot post.");
return false;
} else {
- return handler.sendTweet(text);
+ return handler.sendPost(text);
}
}
- @RuleAction(label = "@text/sendAttachmentTweetActionLabel", description = "@text/sendAttachmentTweetActionDescription")
- public @ActionOutput(name = "success", type = "java.lang.Boolean") Boolean sendTweetWithAttachment(
+ @RuleAction(label = "@text/sendAttachmentPostActionLabel", description = "@text/sendAttachmentPostActionDescription")
+ public @ActionOutput(name = "success", type = "java.lang.Boolean") Boolean sendPostWithAttachment(
@ActionInput(name = "text") @Nullable String text, @ActionInput(name = "url") @Nullable String urlString) {
if (text == null) {
- logger.warn("Cannot send Tweet as text is missing.");
+ logger.warn("Cannot send Post as text is missing.");
return false;
}
if (urlString == null) {
- logger.warn("Cannot send Tweet as urlString is missing.");
+ logger.warn("Cannot send Post as urlString is missing.");
return false;
}
- final TwitterHandler handler = this.handler;
+ final XHandler handler = this.handler;
if (handler == null) {
- logger.debug("Handler is null, cannot tweet.");
+ logger.debug("Handler is null, cannot post.");
return false;
} else {
- return handler.sendTweet(text, urlString);
+ return handler.sendPost(text, urlString);
}
}
@@ -88,32 +88,32 @@ public class TwitterActions implements ThingActions {
return false;
}
- final TwitterHandler handler = this.handler;
+ final XHandler handler = this.handler;
if (handler == null) {
- logger.debug("Handler is null, cannot tweet.");
+ logger.debug("Handler is null, cannot post.");
return false;
} else {
return handler.sendDirectMessage(recipient, text);
}
}
- public static boolean sendTweet(ThingActions actions, @Nullable String text) {
- return ((TwitterActions) actions).sendTweet(text);
+ public static boolean sendPost(ThingActions actions, @Nullable String text) {
+ return ((XActions) actions).sendPost(text);
}
- public static boolean sendTweetWithAttachment(ThingActions actions, @Nullable String text,
+ public static boolean sendPostWithAttachment(ThingActions actions, @Nullable String text,
@Nullable String urlString) {
- return ((TwitterActions) actions).sendTweetWithAttachment(text, urlString);
+ return ((XActions) actions).sendPostWithAttachment(text, urlString);
}
public static boolean sendDirectMessage(ThingActions actions, @Nullable String recipient, @Nullable String text) {
- return ((TwitterActions) actions).sendDirectMessage(recipient, text);
+ return ((XActions) actions).sendDirectMessage(recipient, text);
}
@Override
public void setThingHandler(@Nullable ThingHandler handler) {
- if (handler instanceof TwitterHandler twitterHandler) {
- this.handler = twitterHandler;
+ if (handler instanceof XHandler xHandler) {
+ this.handler = xHandler;
}
}
diff --git a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/config/TwitterConfig.java b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/config/XConfig.java
similarity index 80%
rename from bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/config/TwitterConfig.java
rename to bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/config/XConfig.java
index 529bee31a85..73e11d9dd75 100644
--- a/bundles/org.openhab.binding.twitter/src/main/java/org/openhab/binding/twitter/internal/config/TwitterConfig.java
+++ b/bundles/org.openhab.binding.x/src/main/java/org/openhab/binding/x/internal/config/XConfig.java
@@ -10,18 +10,18 @@
*
* SPDX-License-Identifier: EPL-2.0
*/
-package org.openhab.binding.twitter.internal.config;
+package org.openhab.binding.x.internal.config;
import org.eclipse.jdt.annotation.NonNullByDefault;
/**
- * The {@link TwitterConfig} class contains fields mapping thing configuration parameters.
+ * The {@link XConfig} class contains fields mapping thing configuration parameters.
*
* @author Scott Hanson - Initial contribution
*/
@NonNullByDefault
-public class TwitterConfig {
+public class XConfig {
public String consumerKey = "";
public String consumerSecret = "";
public String accessToken = "";
diff --git a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/addon/addon.xml b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/addon/addon.xml
similarity index 54%
rename from bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/addon/addon.xml
rename to bundles/org.openhab.binding.x/src/main/resources/OH-INF/addon/addon.xml
index 8c90697c78f..acb27648087 100644
--- a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/addon/addon.xml
+++ b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/addon/addon.xml
@@ -1,11 +1,11 @@
-
diff --git a/bundles/org.openhab.binding.x/src/main/resources/OH-INF/i18n/x.properties b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/i18n/x.properties
new file mode 100644
index 00000000000..66bc6924ed3
--- /dev/null
+++ b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/i18n/x.properties
@@ -0,0 +1,32 @@
+# add-on
+
+addon.x.name = X Binding
+addon.x.description = Supports adding Thing for getting the Last Post. Send Posts and Pictures with Actions.
+
+# thing types
+
+thing-type.x.account.label = X Account
+thing-type.x.account.description = Account uses for sending posts
+
+# thing types config
+
+thing-type.config.x.account.accessToken.label = Access Token
+thing-type.config.x.account.accessTokenSecret.label = Access Token Secret
+thing-type.config.x.account.consumerKey.label = Consumer API Key
+thing-type.config.x.account.consumerSecret.label = Consumer API Secret
+thing-type.config.x.account.refresh.label = Refresh Time
+thing-type.config.x.account.refresh.description = Refresh Time for This Account in Mins
+
+# channel types
+
+channel-type.x.lastpost.label = Last Post
+channel-type.x.lastpost.description = Users Last Post
+
+# actions
+
+sendAttachmentPostActionLabel = send a Post with attachment
+sendAttachmentPostActionDescription = Sends a Post with an attachment.
+sendDirectMessageActionLabel = send a DirectMessage
+sendDirectMessageActionDescription = Sends a DirectMessage.
+sendPostActionLabel = send a Post
+sendPostActionDescription = Sends a Post.
diff --git a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/thing/thing-types.xml b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/thing/thing-types.xml
similarity index 78%
rename from bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/thing/thing-types.xml
rename to bundles/org.openhab.binding.x/src/main/resources/OH-INF/thing/thing-types.xml
index 1ec1355e990..d18df8f5e1c 100644
--- a/bundles/org.openhab.binding.twitter/src/main/resources/OH-INF/thing/thing-types.xml
+++ b/bundles/org.openhab.binding.x/src/main/resources/OH-INF/thing/thing-types.xml
@@ -1,15 +1,14 @@
-
-
- Account uses for sending Tweets
+
+ Account uses for sending posts
-
+
@@ -38,10 +37,10 @@
-
diff --git a/bundles/pom.xml b/bundles/pom.xml
index e992b98ac4d..24ba021ef0c 100644
--- a/bundles/pom.xml
+++ b/bundles/pom.xml
@@ -387,7 +387,6 @@
org.openhab.binding.tplinksmarthome
org.openhab.binding.tr064
org.openhab.binding.tradfri
- org.openhab.binding.twitter
org.openhab.binding.unifi
org.openhab.binding.unifiedremote
org.openhab.binding.upnpcontrol
@@ -419,6 +418,7 @@
org.openhab.binding.wled
org.openhab.binding.wolfsmartset
org.openhab.binding.wundergroundupdatereceiver
+ org.openhab.binding.x
org.openhab.binding.xmltv
org.openhab.binding.xmppclient
org.openhab.binding.yamahamusiccast