Slack Plugin Example (#8542)
This commit is contained in:
parent
d4fbeb6b15
commit
be43c91610
|
@ -0,0 +1,61 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<groupId>com.baeldung.examples</groupId>
|
||||||
|
<artifactId>slack</artifactId>
|
||||||
|
<version>1.0</version>
|
||||||
|
<name>slack</name>
|
||||||
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>com.baeldung</groupId>
|
||||||
|
<artifactId>parent-modules</artifactId>
|
||||||
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.hubspot.slack</groupId>
|
||||||
|
<artifactId>slack-base</artifactId>
|
||||||
|
<version>${slack.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.hubspot.slack</groupId>
|
||||||
|
<artifactId>slack-java-client</artifactId>
|
||||||
|
<version>${slack.version}</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-jar-plugin</artifactId>
|
||||||
|
<version>${maven-jar-plugin.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<archive>
|
||||||
|
<manifest>
|
||||||
|
<addClasspath>true</addClasspath>
|
||||||
|
<mainClass>com.baeldung.examples.slack.MainClass</mainClass>
|
||||||
|
</manifest>
|
||||||
|
</archive>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.codehaus.mojo</groupId>
|
||||||
|
<artifactId>exec-maven-plugin</artifactId>
|
||||||
|
<version>1.6.0</version>
|
||||||
|
<configuration>
|
||||||
|
<mainClass>com.baeldung.examples.slack.MainClass</mainClass>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<slack.version>1.4</slack.version>
|
||||||
|
<maven-jar-plugin.version>2.4</maven-jar-plugin.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
</project>
|
|
@ -0,0 +1,42 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.FileSystems;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
public class DiskSpaceErrorChecker implements ErrorChecker {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(DiskSpaceErrorChecker.class);
|
||||||
|
|
||||||
|
private final ErrorReporter errorReporter;
|
||||||
|
|
||||||
|
private final double limit;
|
||||||
|
|
||||||
|
public DiskSpaceErrorChecker(ErrorReporter errorReporter, double limit) {
|
||||||
|
this.errorReporter = errorReporter;
|
||||||
|
this.limit = limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void check() {
|
||||||
|
LOG.info("Checking disk space");
|
||||||
|
FileSystems.getDefault().getFileStores().forEach(fileStore -> {
|
||||||
|
try {
|
||||||
|
long totalSpace = fileStore.getTotalSpace();
|
||||||
|
long usableSpace = fileStore.getUsableSpace();
|
||||||
|
double usablePercentage = ((double) usableSpace) / totalSpace;
|
||||||
|
LOG.debug("File store {} has {} of {} ({}) usable space",
|
||||||
|
fileStore, usableSpace, totalSpace, usablePercentage);
|
||||||
|
|
||||||
|
if (totalSpace > 0 && usablePercentage < limit) {
|
||||||
|
String error = String.format("File store %s only has %d%% usable disk space",
|
||||||
|
fileStore.name(), (int)(usablePercentage * 100));
|
||||||
|
errorReporter.reportProblem(error);
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Error getting disk space for file store {}", fileStore, e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
public interface ErrorChecker {
|
||||||
|
void check();
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
public interface ErrorReporter {
|
||||||
|
void reportProblem(String problem);
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
|
||||||
|
import com.hubspot.slack.client.SlackClient;
|
||||||
|
import com.hubspot.slack.client.SlackClientFactory;
|
||||||
|
import com.hubspot.slack.client.SlackClientRuntimeConfig;
|
||||||
|
|
||||||
|
public class MainClass {
|
||||||
|
public static final long MINUTES = 1000 * 60;
|
||||||
|
|
||||||
|
public static void main(String[] args) throws IOException {
|
||||||
|
SlackClientRuntimeConfig runtimeConfig = SlackClientRuntimeConfig.builder()
|
||||||
|
.setTokenSupplier(() -> "<Your API Token>")
|
||||||
|
.build();
|
||||||
|
|
||||||
|
SlackClient slackClient = SlackClientFactory.defaultFactory().build(runtimeConfig);
|
||||||
|
|
||||||
|
ErrorReporter slackChannelErrorReporter = new SlackChannelErrorReporter(slackClient, "general");
|
||||||
|
ErrorReporter slackUserErrorReporter = new SlackUserErrorReporter(slackClient, "testuser@baeldung.com");
|
||||||
|
|
||||||
|
ErrorChecker diskSpaceErrorChecker10pct = new DiskSpaceErrorChecker(slackChannelErrorReporter, 0.1);
|
||||||
|
ErrorChecker diskSpaceErrorChecker2pct = new DiskSpaceErrorChecker(slackUserErrorReporter, 0.02);
|
||||||
|
|
||||||
|
Timer timer = new Timer();
|
||||||
|
timer.scheduleAtFixedRate(new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
diskSpaceErrorChecker10pct.check();
|
||||||
|
}
|
||||||
|
}, 0, 5 * MINUTES);
|
||||||
|
timer.scheduleAtFixedRate(new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
diskSpaceErrorChecker2pct.check();
|
||||||
|
}
|
||||||
|
}, 0, 5 * MINUTES);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,30 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
import com.hubspot.slack.client.SlackClient;
|
||||||
|
import com.hubspot.slack.client.methods.params.chat.ChatPostMessageParams;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
public class SlackChannelErrorReporter implements ErrorReporter {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(SlackChannelErrorReporter.class);
|
||||||
|
|
||||||
|
private final SlackClient slackClient;
|
||||||
|
|
||||||
|
private final String channel;
|
||||||
|
|
||||||
|
public SlackChannelErrorReporter(SlackClient slackClient, String channel) {
|
||||||
|
this.slackClient = slackClient;
|
||||||
|
this.channel = channel;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void reportProblem(String problem) {
|
||||||
|
LOG.debug("Sending message to channel {}: {}", channel, problem);
|
||||||
|
slackClient.postMessage(
|
||||||
|
ChatPostMessageParams.builder()
|
||||||
|
.setText(problem)
|
||||||
|
.setChannelId(channel)
|
||||||
|
.build()
|
||||||
|
).join().unwrapOrElseThrow();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,52 @@
|
||||||
|
package com.baeldung.examples.slack;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import com.hubspot.slack.client.SlackClient;
|
||||||
|
import com.hubspot.slack.client.methods.params.chat.ChatPostMessageParams;
|
||||||
|
import com.hubspot.slack.client.methods.params.conversations.ConversationCreateParams;
|
||||||
|
import com.hubspot.slack.client.methods.params.im.ImOpenParams;
|
||||||
|
import com.hubspot.slack.client.methods.params.users.UserEmailParams;
|
||||||
|
import com.hubspot.slack.client.methods.params.users.UsersInfoParams;
|
||||||
|
import com.hubspot.slack.client.models.response.im.ImOpenResponse;
|
||||||
|
import com.hubspot.slack.client.models.response.users.UsersInfoResponse;
|
||||||
|
import com.hubspot.slack.client.models.users.SlackUser;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
public class SlackUserErrorReporter implements ErrorReporter {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(SlackUserErrorReporter.class);
|
||||||
|
|
||||||
|
private final SlackClient slackClient;
|
||||||
|
|
||||||
|
private final String user;
|
||||||
|
|
||||||
|
public SlackUserErrorReporter(SlackClient slackClient, String user) {
|
||||||
|
this.slackClient = slackClient;
|
||||||
|
this.user = user;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void reportProblem(String problem) {
|
||||||
|
LOG.debug("Sending message to user {}: {}", user, problem);
|
||||||
|
UsersInfoResponse usersInfoResponse = slackClient
|
||||||
|
.lookupUserByEmail(UserEmailParams.builder()
|
||||||
|
.setEmail(user)
|
||||||
|
.build()
|
||||||
|
).join().unwrapOrElseThrow();
|
||||||
|
|
||||||
|
ImOpenResponse imOpenResponse = slackClient.openIm(ImOpenParams.builder()
|
||||||
|
.setUserId(usersInfoResponse.getUser().getId())
|
||||||
|
.build()
|
||||||
|
).join().unwrapOrElseThrow();
|
||||||
|
|
||||||
|
imOpenResponse.getChannel().ifPresent(channel -> {
|
||||||
|
slackClient.postMessage(
|
||||||
|
ChatPostMessageParams.builder()
|
||||||
|
.setText(problem)
|
||||||
|
.setChannelId(channel.getId())
|
||||||
|
.build()
|
||||||
|
).join().unwrapOrElseThrow();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<configuration>
|
||||||
|
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
||||||
|
<encoder>
|
||||||
|
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
|
||||||
|
</pattern>
|
||||||
|
</encoder>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<root level="DEBUG">
|
||||||
|
<appender-ref ref="STDOUT" />
|
||||||
|
</root>
|
||||||
|
</configuration>
|
Loading…
Reference in New Issue