Skip to content

Commit 4208c9e

Browse files
committed
1.0
1 parent b292e04 commit 4208c9e

File tree

8 files changed

+377
-0
lines changed

8 files changed

+377
-0
lines changed

.gitignore

+113
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,113 @@
1+
# User-specific stuff
2+
.idea/
3+
4+
*.iml
5+
*.ipr
6+
*.iws
7+
8+
# IntelliJ
9+
out/
10+
11+
# Compiled class file
12+
*.class
13+
14+
# Log file
15+
*.log
16+
17+
# BlueJ files
18+
*.ctxt
19+
20+
# Package Files #
21+
*.jar
22+
*.war
23+
*.nar
24+
*.ear
25+
*.zip
26+
*.tar.gz
27+
*.rar
28+
29+
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
30+
hs_err_pid*
31+
32+
*~
33+
34+
# temporary files which can be created if a process still has a handle open of a deleted file
35+
.fuse_hidden*
36+
37+
# KDE directory preferences
38+
.directory
39+
40+
# Linux trash folder which might appear on any partition or disk
41+
.Trash-*
42+
43+
# .nfs files are created when an open file is removed but is still being accessed
44+
.nfs*
45+
46+
# General
47+
.DS_Store
48+
.AppleDouble
49+
.LSOverride
50+
51+
# Icon must end with two \r
52+
Icon
53+
54+
# Thumbnails
55+
._*
56+
57+
# Files that might appear in the root of a volume
58+
.DocumentRevisions-V100
59+
.fseventsd
60+
.Spotlight-V100
61+
.TemporaryItems
62+
.Trashes
63+
.VolumeIcon.icns
64+
.com.apple.timemachine.donotpresent
65+
66+
# Directories potentially created on remote AFP share
67+
.AppleDB
68+
.AppleDesktop
69+
Network Trash Folder
70+
Temporary Items
71+
.apdisk
72+
73+
# Windows thumbnail cache files
74+
Thumbs.db
75+
Thumbs.db:encryptable
76+
ehthumbs.db
77+
ehthumbs_vista.db
78+
79+
# Dump file
80+
*.stackdump
81+
82+
# Folder config file
83+
[Dd]esktop.ini
84+
85+
# Recycle Bin used on file shares
86+
$RECYCLE.BIN/
87+
88+
# Windows Installer files
89+
*.cab
90+
*.msi
91+
*.msix
92+
*.msm
93+
*.msp
94+
95+
# Windows shortcuts
96+
*.lnk
97+
98+
target/
99+
100+
pom.xml.tag
101+
pom.xml.releaseBackup
102+
pom.xml.versionsBackup
103+
pom.xml.next
104+
105+
release.properties
106+
dependency-reduced-pom.xml
107+
buildNumber.properties
108+
.mvn/timing.properties
109+
.mvn/wrapper/maven-wrapper.jar
110+
.flattened-pom.xml
111+
112+
# Common working directory
113+
run/

pom.xml

+86
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,86 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<modelVersion>4.0.0</modelVersion>
6+
7+
<groupId>me.dayofpay</groupId>
8+
<artifactId>welcomemessage</artifactId>
9+
<version>1.0-SNAPSHOT</version>
10+
<packaging>jar</packaging>
11+
12+
<name>WelcomeMessage</name>
13+
14+
<description>A plugin which sends welcome message when somebody joins the server</description>
15+
<properties>
16+
<java.version>1.8</java.version>
17+
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
18+
</properties>
19+
<url>https://v-devs.online</url>
20+
21+
<build>
22+
<plugins>
23+
<plugin>
24+
<groupId>org.apache.maven.plugins</groupId>
25+
<artifactId>maven-compiler-plugin</artifactId>
26+
<version>3.8.1</version>
27+
<configuration>
28+
<source>${java.version}</source>
29+
<target>${java.version}</target>
30+
</configuration>
31+
</plugin>
32+
<plugin>
33+
<groupId>org.apache.maven.plugins</groupId>
34+
<artifactId>maven-shade-plugin</artifactId>
35+
<version>3.2.4</version>
36+
<executions>
37+
<execution>
38+
<phase>package</phase>
39+
<goals>
40+
<goal>shade</goal>
41+
</goals>
42+
<configuration>
43+
<createDependencyReducedPom>false</createDependencyReducedPom>
44+
</configuration>
45+
</execution>
46+
</executions>
47+
</plugin>
48+
</plugins>
49+
<resources>
50+
<resource>
51+
<directory>src/main/resources</directory>
52+
<filtering>true</filtering>
53+
</resource>
54+
</resources>
55+
</build>
56+
57+
<repositories>
58+
<repository>
59+
<id>spigotmc-repo</id>
60+
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
61+
</repository>
62+
<repository>
63+
<id>placeholderapi</id>
64+
<url>https://repo.extendedclip.com/content/repositories/placeholderapi/</url>
65+
</repository>
66+
<repository>
67+
<id>sonatype</id>
68+
<url>https://oss.sonatype.org/content/groups/public/</url>
69+
</repository>
70+
</repositories>
71+
72+
<dependencies>
73+
<dependency>
74+
<groupId>org.spigotmc</groupId>
75+
<artifactId>spigot-api</artifactId>
76+
<version>1.12-R0.1-SNAPSHOT</version>
77+
<scope>provided</scope>
78+
</dependency>
79+
<dependency>
80+
<groupId>me.clip</groupId>
81+
<artifactId>placeholderapi</artifactId>
82+
<version>2.11.1</version>
83+
<scope>provided</scope>
84+
</dependency>
85+
</dependencies>
86+
</project>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
package me.dayofpay.welcomemessage;
2+
3+
import org.bukkit.Bukkit;
4+
import org.bukkit.ChatColor;
5+
import org.bukkit.event.EventHandler;
6+
import org.bukkit.event.EventPriority;
7+
import org.bukkit.event.Listener;
8+
import org.bukkit.event.player.PlayerJoinEvent;
9+
import org.bukkit.event.player.PlayerQuitEvent;
10+
import org.bukkit.plugin.java.JavaPlugin;
11+
import me.clip.placeholderapi.PlaceholderAPI;
12+
13+
public class Events implements Listener {
14+
private static Events plugin;
15+
@EventHandler(priority = EventPriority.HIGHEST)
16+
public void onLeave(PlayerQuitEvent leaveEvent){
17+
if(Welcomemessage.getInstance().getConfig().getBoolean("globalAnnounce") == true){
18+
String leaveMessage = Welcomemessage.getInstance().getConfig().getString("globalLeaveMessage");
19+
leaveMessage = PlaceholderAPI.setPlaceholders(leaveEvent.getPlayer(),leaveMessage);
20+
Welcomemessage.getInstance().getServer().broadcastMessage(ChatColor.translateAlternateColorCodes('&',leaveMessage));
21+
}
22+
else{
23+
24+
}
25+
}
26+
@EventHandler(priority = EventPriority.HIGHEST)
27+
public void onJoin(PlayerJoinEvent joinEvent) {
28+
if(Welcomemessage.getInstance().getConfig().getBoolean("globalAnnounce") == true){
29+
String joinMessage = Welcomemessage.getInstance().getConfig().getString("globalJoinMessage");
30+
joinMessage = PlaceholderAPI.setPlaceholders(joinEvent.getPlayer(),joinMessage);
31+
Welcomemessage.getInstance().getServer().broadcastMessage(ChatColor.translateAlternateColorCodes('&',joinMessage));
32+
}
33+
else{
34+
35+
}
36+
if(Welcomemessage.getInstance().getConfig().getBoolean("enableSpecialMessage") == true && joinEvent.getPlayer().hasPermission(Welcomemessage.getInstance().getConfig().getString("specialMessagePermission"))){
37+
String specialMessage = Welcomemessage.getInstance().getConfig().getString("specialMessage");
38+
specialMessage = PlaceholderAPI.setPlaceholders(joinEvent.getPlayer(),specialMessage);
39+
Welcomemessage.getInstance().getServer().broadcastMessage(ChatColor.translateAlternateColorCodes('&',specialMessage));
40+
}else{
41+
42+
}
43+
if(Welcomemessage.getInstance().getConfig().getBoolean("logConsole") == true){
44+
Welcomemessage.getInstance().getServer().getConsoleSender().sendMessage(ChatColor.GREEN + joinEvent.getPlayer().getName() + " Joined the server ");
45+
}
46+
else{
47+
48+
}
49+
for (String msg : Welcomemessage.getInstance().getConfig().getStringList("message")) {
50+
String joinText = msg;
51+
joinText = PlaceholderAPI.setPlaceholders(joinEvent.getPlayer(), joinText);
52+
53+
joinEvent.getPlayer().sendMessage(joinText);
54+
}
55+
}
56+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
package me.dayofpay.welcomemessage;
2+
3+
public class Info {
4+
public static String getVersion = "1.0";
5+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
package me.dayofpay.welcomemessage;
2+
import org.bukkit.OfflinePlayer;
3+
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
4+
5+
public class Placeholders extends PlaceholderExpansion {
6+
private Events plugin; // This instance is assigned in canRegister()
7+
@Override
8+
public String getAuthor() {
9+
return "dayofpay";
10+
}
11+
12+
@Override
13+
public String getIdentifier() {
14+
return "welcomemessage";
15+
}
16+
17+
@Override
18+
public String getVersion() {
19+
return "1.0.0";
20+
}
21+
@Override
22+
public String onRequest(OfflinePlayer player, String params) {
23+
24+
if(params.equalsIgnoreCase("name")) {
25+
return player.getName();
26+
}
27+
28+
29+
return null; // Placeholder is unknown by the Expansion
30+
}
31+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
package me.dayofpay.welcomemessage;
2+
3+
import org.bukkit.Bukkit;
4+
import org.bukkit.ChatColor;
5+
import org.bukkit.command.Command;
6+
import org.bukkit.command.CommandSender;
7+
import org.bukkit.configuration.file.FileConfiguration;
8+
import org.bukkit.event.Listener;
9+
import org.bukkit.plugin.java.JavaPlugin;
10+
11+
import java.io.File;
12+
13+
public final class Welcomemessage extends JavaPlugin implements Listener {
14+
private static Welcomemessage plugin;
15+
File cfile;
16+
FileConfiguration config;
17+
@Override
18+
public void onEnable() {
19+
this.config = this.getConfig();
20+
this.config.options().copyDefaults(true);
21+
this.saveConfig();
22+
this.cfile = new File(this.getDataFolder(), "config.yml");
23+
plugin = this;
24+
getServer().getConsoleSender().sendMessage(ChatColor.GREEN + "[WelcomeMessage] Loaded Successfully ...");
25+
if (Bukkit.getPluginManager().getPlugin("PlaceholderAPI") != null) {
26+
new Placeholders().register();
27+
getServer().getConsoleSender().sendMessage(ChatColor.GREEN + "[WelcomeMessage] PlaceHolderAPI Loaded ...");
28+
Bukkit.getPluginManager().registerEvents(new Events(), this);
29+
}else{
30+
getLogger().warning(ChatColor.RED + "[WelcomeMessage] Could not find PlaceHolderAPI");
31+
}
32+
}
33+
@Override
34+
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
35+
if (command.getName().equals("welcomemessage") && args.length < 1) {
36+
sender.sendMessage(ChatColor.translateAlternateColorCodes('&',"&4&l&OWelcome&e&l&oMessage &7| &b&OV" + Info.getVersion.toString()));
37+
}
38+
else if(command.getName().equals("welcomemessage") && args[0].toString().equals("reload") && sender.hasPermission(getConfig().getString("adminPermission"))){
39+
String pluginPrefix = getConfig().getString("pluginPrefix");
40+
String pluginResponse = getConfig().getString("reloadMessage");
41+
sender.sendMessage(ChatColor.translateAlternateColorCodes('&',pluginPrefix + pluginResponse));
42+
onDisable();
43+
onEnable();
44+
45+
}
46+
else if(command.getName().equals("welcomemessage") && args[0].toString().equals("reload") && !sender.hasPermission(getConfig().getString("adminPermission"))) {
47+
String pluginPrefix = getConfig().getString("pluginPrefix");
48+
String pluginResponse = getConfig().getString("noPermission");
49+
sender.sendMessage(ChatColor.translateAlternateColorCodes('&', pluginPrefix + pluginResponse));
50+
}
51+
return true;
52+
}
53+
@Override
54+
public void onDisable() {
55+
getServer().getConsoleSender().sendMessage(ChatColor.RED + "[WelcomeMessage] Disabled ...");
56+
}
57+
public static Welcomemessage getInstance () {
58+
return plugin;
59+
}
60+
}

src/main/resources/config.yml

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
message: ## The message which will be send to player when joining the server ( Supporting PlaceHolderAPI )
2+
- '&6&l&m&o-------------------'
3+
- '&c> &a&oHello, %player_name% in %server_name% !'
4+
- '&c> &a&oYour ping is: %player_ping% !'
5+
- '&6&l&m&o-------------------'
6+
logConsole: false ## This can be set to true or false, if is set to true the plugin will send message to the console when player joins / leaves the server
7+
pluginPrefix: '&7WelcomeMessage &c» &a' ## The plugin prefix
8+
reloadMessage: 'Reloaded Successfully' ## Reload message
9+
globalAnnounce: false ## Set to true if you want to announce in global chat message when someone joins/leaves the server
10+
globalJoinMessage: '&7[&6+&7]&a%player_name%&7[&6+&7]'
11+
globalLeaveMessage: '&7[&6-&7]&c%player_name%&7[&6-&7]'
12+
enableSpecialMessage: false ## if this is set to true, all players which have the specialMessagePermission will have separate special message
13+
specialMessagePermission: 'welcomemessage.special'
14+
adminPermission: 'welcomemessage.admin'
15+
noPermission: '&CSorry ! You Dont have enough permissions'
16+
specialMessage: '&6&oSpecial Player %player_name% joined the server !!'

src/main/resources/plugin.yml

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
name: WelcomeMessage
2+
version: '${project.version}'
3+
main: me.dayofpay.welcomemessage.Welcomemessage
4+
authors: [ dayofpay ]
5+
description: A plugin which sends welcome message when somebody joins the server
6+
website: https://v-devs.online
7+
softdepend: [PlaceholderAPI]
8+
commands:
9+
welcomemessage:
10+
description: Main plugin command

0 commit comments

Comments
 (0)