test stuff
This commit is contained in:
parent
5a8b2f67ba
commit
d87def34ef
4 changed files with 114 additions and 2 deletions
18
pom.xml
18
pom.xml
|
|
@ -61,7 +61,11 @@
|
||||||
</repository>
|
</repository>
|
||||||
<repository>
|
<repository>
|
||||||
<id>brokkonaut</id>
|
<id>brokkonaut</id>
|
||||||
<url>https://www.iani.de/nexus/content/groups/public</url>
|
<url>https://www.iani.de/nexus/repository/maven-releases/</url>
|
||||||
|
</repository>
|
||||||
|
<repository>
|
||||||
|
<id>lunarakai</id>
|
||||||
|
<url>https://lunarakai.de/nexus/repository/maven-releases/</url>
|
||||||
</repository>
|
</repository>
|
||||||
</repositories>
|
</repositories>
|
||||||
|
|
||||||
|
|
@ -83,5 +87,17 @@
|
||||||
<artifactId>rssreader</artifactId>
|
<artifactId>rssreader</artifactId>
|
||||||
<version>3.6.0</version>
|
<version>3.6.0</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<!-- jsoup HTML parser library @ https://jsoup.org/ -->
|
||||||
|
<groupId>org.jsoup</groupId>
|
||||||
|
<artifactId>jsoup</artifactId>
|
||||||
|
<version>1.18.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>de.lunarakai</groupId>
|
||||||
|
<artifactId>LunarUtils</artifactId>
|
||||||
|
<version>0.0.1</version>
|
||||||
|
<classifier>lunarutils</classifier>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,15 @@
|
||||||
package de.lunarakai.cuberss;
|
package de.lunarakai.cuberss;
|
||||||
|
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.CommandRouter;
|
||||||
|
import de.lunarakai.cuberss.commands.TestRSSCommand;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
public final class CubeRSS extends JavaPlugin {
|
public final class CubeRSS extends JavaPlugin {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
// Plugin startup logic
|
CommandRouter commandRouter = new CommandRouter(getCommand("cuberss"));
|
||||||
|
commandRouter.addCommandMapping(new TestRSSCommand(this), "test");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,87 @@
|
||||||
|
package de.lunarakai.cuberss.commands;
|
||||||
|
|
||||||
|
import com.apptasticsoftware.rssreader.Item;
|
||||||
|
import com.apptasticsoftware.rssreader.RssReader;
|
||||||
|
import de.iani.cubesideutils.NamedChatColor;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.SubCommand;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.exceptions.DisallowsCommandBlockException;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.exceptions.IllegalSyntaxException;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.exceptions.InternalCommandException;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.exceptions.NoPermissionException;
|
||||||
|
import de.iani.cubesideutils.bukkit.commands.exceptions.RequiresPlayerException;
|
||||||
|
import de.iani.cubesideutils.commands.ArgsParser;
|
||||||
|
import de.lunarakai.cuberss.CubeRSS;
|
||||||
|
import de.lunarakai.lunarutils.StringUtils;
|
||||||
|
import de.lunarakai.lunarutils.chat.MessageUtils;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.jsoup.Jsoup;
|
||||||
|
import org.jsoup.nodes.Document;
|
||||||
|
|
||||||
|
public class TestRSSCommand extends SubCommand {
|
||||||
|
|
||||||
|
private final CubeRSS plugin;
|
||||||
|
|
||||||
|
public TestRSSCommand(CubeRSS plugin) {
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getUsage() {
|
||||||
|
return "<url>";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean requiresPlayer() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command command, String s, String commandString, ArgsParser args) throws DisallowsCommandBlockException, RequiresPlayerException, NoPermissionException, IllegalSyntaxException, InternalCommandException {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.remaining() != 1) {
|
||||||
|
sender.sendMessage(NamedChatColor.DARK_RED + commandString + getUsage());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
String url = args.getNext().trim();
|
||||||
|
|
||||||
|
if(!StringUtils.isValidURL(url)) {
|
||||||
|
MessageUtils.sendSimpleWarningMessage(player, "please enter a valid URL");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
RssReader rssReader = new RssReader();
|
||||||
|
try {
|
||||||
|
List<Item> items = rssReader.addItemExtension("content:encoded", Item::setComments).read(url).toList();
|
||||||
|
|
||||||
|
Optional<String> title = items.getFirst().getTitle();
|
||||||
|
title.ifPresent(string -> sender.sendMessage(NamedChatColor.BLUE + string));
|
||||||
|
|
||||||
|
Optional<String> optionalAuthor = items.getFirst().getAuthor();
|
||||||
|
optionalAuthor.ifPresent(string -> sender.sendMessage(NamedChatColor.AQUA + string));
|
||||||
|
|
||||||
|
Optional<String> optionaltest = items.getFirst().getComments();
|
||||||
|
if(optionaltest.isPresent()) {
|
||||||
|
Document parsedTest = Jsoup.parse(optionaltest.get());
|
||||||
|
// todo: format html elements to readable string (for example new line at <ul><li>)
|
||||||
|
MessageUtils.sendSimpleInfoMessage(player, parsedTest.toString());
|
||||||
|
} else {
|
||||||
|
Optional<String> optionalDescription = items.getFirst().getDescription();
|
||||||
|
optionalDescription.ifPresent(string -> sender.sendMessage(NamedChatColor.GOLD + string));
|
||||||
|
}
|
||||||
|
|
||||||
|
Optional<String> optionalLink = items.getFirst().getGuid();
|
||||||
|
optionalLink.ifPresent(string -> sender.sendMessage(NamedChatColor.AQUA + string));
|
||||||
|
|
||||||
|
Optional<String> optionalDate = items.getFirst().getPubDate();
|
||||||
|
optionalDate.ifPresent(string -> sender.sendMessage(NamedChatColor.GRAY + string));
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -2,3 +2,9 @@ name: CubeRSS
|
||||||
version: '${project.version}'
|
version: '${project.version}'
|
||||||
main: de.lunarakai.cuberss.CubeRSS
|
main: de.lunarakai.cuberss.CubeRSS
|
||||||
api-version: '1.21'
|
api-version: '1.21'
|
||||||
|
depend:
|
||||||
|
- CubesideUtils
|
||||||
|
- LunarUtils
|
||||||
|
commands:
|
||||||
|
cuberss:
|
||||||
|
description: main command
|
||||||
Loading…
Add table
Add a link
Reference in a new issue