2014-02-03 22:16:14 -07:00
|
|
|
package org.bukkit;
|
|
|
|
|
2019-03-13 17:42:57 +11:00
|
|
|
import org.jetbrains.annotations.NotNull;
|
|
|
|
import org.jetbrains.annotations.Nullable;
|
|
|
|
|
2014-02-03 22:16:14 -07:00
|
|
|
import java.util.Date;
|
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* A single entry from a ban list. This may represent either a player ban or
|
|
|
|
* an IP ban.
|
|
|
|
* <p>
|
2014-02-03 22:16:14 -07:00
|
|
|
* Ban entries include the following properties:
|
2014-03-24 13:20:52 -05:00
|
|
|
* <table border=1>
|
2014-11-30 21:09:01 +00:00
|
|
|
* <caption>Property information</caption>
|
2014-03-24 13:20:52 -05:00
|
|
|
* <tr>
|
|
|
|
* <th>Property</th>
|
|
|
|
* <th>Description</th>
|
|
|
|
* </tr><tr>
|
|
|
|
* <td>Target Name / IP Address</td>
|
|
|
|
* <td>The target name or IP address</td>
|
|
|
|
* </tr><tr>
|
|
|
|
* <td>Creation Date</td>
|
|
|
|
* <td>The creation date of the ban</td>
|
|
|
|
* </tr><tr>
|
|
|
|
* <td>Source</td>
|
|
|
|
* <td>The source of the ban, such as a player, console, plugin, etc</td>
|
|
|
|
* </tr><tr>
|
|
|
|
* <td>Expiration Date</td>
|
|
|
|
* <td>The expiration date of the ban</td>
|
|
|
|
* </tr><tr>
|
|
|
|
* <td>Reason</td>
|
|
|
|
* <td>The reason for the ban</td>
|
|
|
|
* </tr>
|
|
|
|
* </table>
|
|
|
|
* <p>
|
|
|
|
* Unsaved information is not automatically written to the implementation's
|
|
|
|
* ban list, instead, the {@link #save()} method must be called to write the
|
|
|
|
* changes to the ban list. If this ban entry has expired (such as from an
|
|
|
|
* unban) and is no longer found in the list, the {@link #save()} call will
|
|
|
|
* re-add it to the list, therefore banning the victim specified.
|
|
|
|
* <p>
|
|
|
|
* Likewise, changes to the associated {@link BanList} or other entries may or
|
|
|
|
* may not be reflected in this entry.
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
|
|
|
public interface BanEntry {
|
2014-03-24 13:20:52 -05:00
|
|
|
|
2014-02-03 22:16:14 -07:00
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Gets the target involved. This may be in the form of an IP or a player
|
|
|
|
* name.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @return the target name or IP address
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
@NotNull
|
2014-02-03 22:16:14 -07:00
|
|
|
public String getTarget();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the date this ban entry was created.
|
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @return the creation date
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
@NotNull
|
2014-02-03 22:16:14 -07:00
|
|
|
public Date getCreated();
|
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Sets the date this ban entry was created.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @param created the new created date, cannot be null
|
|
|
|
* @see #save() saving changes
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
public void setCreated(@NotNull Date created);
|
2014-02-03 22:16:14 -07:00
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Gets the source of this ban.
|
|
|
|
* <p>
|
|
|
|
* Note: A source is considered any String, although this is generally a
|
|
|
|
* player name.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @return the source of the ban
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
@NotNull
|
2014-02-03 22:16:14 -07:00
|
|
|
public String getSource();
|
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Sets the source of this ban.
|
|
|
|
* <p>
|
|
|
|
* Note: A source is considered any String, although this is generally a
|
|
|
|
* player name.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @param source the new source where null values become empty strings
|
|
|
|
* @see #save() saving changes
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
public void setSource(@NotNull String source);
|
2014-02-03 22:16:14 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the date this ban expires on, or null for no defined end date.
|
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @return the expiration date
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
@Nullable
|
2014-02-03 22:16:14 -07:00
|
|
|
public Date getExpiration();
|
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Sets the date this ban expires on. Null values are considered
|
|
|
|
* "infinite" bans.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @param expiration the new expiration date, or null to indicate an
|
|
|
|
* eternity
|
|
|
|
* @see #save() saving changes
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
public void setExpiration(@Nullable Date expiration);
|
2014-02-03 22:16:14 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the reason for this ban.
|
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @return the ban reason, or null if not set
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
@Nullable
|
2014-02-03 22:16:14 -07:00
|
|
|
public String getReason();
|
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Sets the reason for this ban. Reasons must not be null.
|
2014-02-03 22:16:14 -07:00
|
|
|
*
|
2014-03-24 13:20:52 -05:00
|
|
|
* @param reason the new reason, null values assume the implementation
|
|
|
|
* default
|
|
|
|
* @see #save() saving changes
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
2019-03-13 17:42:57 +11:00
|
|
|
public void setReason(@Nullable String reason);
|
2014-02-03 22:16:14 -07:00
|
|
|
|
|
|
|
/**
|
2014-03-24 13:20:52 -05:00
|
|
|
* Saves the ban entry, overwriting any previous data in the ban list.
|
|
|
|
* <p>
|
|
|
|
* Saving the ban entry of an unbanned player will cause the player to be
|
|
|
|
* banned once again.
|
2014-02-03 22:16:14 -07:00
|
|
|
*/
|
|
|
|
public void save();
|
|
|
|
}
|