org.spongepowered.api.service.economy.account.Account Maven / Gradle / Ivy
/*
* This file is part of SpongeAPI, licensed under the MIT License (MIT).
*
* Copyright (c) SpongePowered
* Copyright (c) contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package org.spongepowered.api.service.economy.account;
import net.kyori.adventure.text.Component;
import org.spongepowered.api.entity.Entity;
import org.spongepowered.api.entity.living.player.User;
import org.spongepowered.api.event.Cause;
import org.spongepowered.api.profile.GameProfile;
import org.spongepowered.api.service.context.Context;
import org.spongepowered.api.service.context.Contextual;
import org.spongepowered.api.service.economy.Currency;
import org.spongepowered.api.service.economy.EconomyService;
import org.spongepowered.api.service.economy.transaction.TransactionResult;
import org.spongepowered.api.service.economy.transaction.TransferResult;
import java.math.BigDecimal;
import java.util.Map;
import java.util.Set;
import java.util.UUID;
/**
* Represents an account, which stores amounts of various {@link Currency currencies}.
*
* Accounts come in two varieties: {@link UniqueAccount user accounts}
* and {@link VirtualAccount} virtual accounts.
*
* Unique accounts are bound to a {@link UUID}, usually of a particular
* {@link User}'s {@link GameProfile}.
*
* Virtual accounts are identified by a String identifier, which may have any
* value. They are not tied to any {@link Entity}, player or otherwise. Virtual
* accounts may be used for purposes such as bank accounts, non-player
* {@link Entity} accounts, or other things.
*/
public interface Account extends Contextual {
/**
* Gets the display name for this account.
*
* This should be used by plugins to get a human-readable name for an
* account, regardless of the specific type ({@link UniqueAccount} or
* {@link VirtualAccount}).
*
* Its contents are dependent on the provider of {@link EconomyService}.
* For example, an economy plugin could allow players to configure the
* display name of their account
.
*
* @return The display name for this account
*/
Component displayName();
/**
* Gets the default balance of this account for the specified
* {@link Currency}.
*
* The default balance is used when the balance is retrieved for the
* first time for a given {@link Currency} on this account, or if no
* balance is available for the {@link Context}s used when retrieving
* a balance.
*
* @param currency the currency to get the default balance for.
* @return The default balance for the specified {@link Currency}.
*/
BigDecimal defaultBalance(Currency currency);
/**
* Returns whether this account has a set balance for the specified
* {@link Currency}, with the specified {@link Context}s.
*
* If this method returns false
, then
* {@link #defaultBalance(Currency)} will be used when
* retrieving a balance for the specified {@link Currency} with
* the specified {@link Context}s.
*
* @param currency The {@link Currency} to determine if a balance is set for
* @param contexts The {@link Context}s to use with the {@link Currency}
* @return Whether this account has a set balance for the specified
* {@link Currency} and {@link Context}s
*/
boolean hasBalance(Currency currency, Set contexts);
/**
* Returns whether this account has a set balance for the specified
* {@link Currency}, with context from the specified {@link Cause}s.
*
* If this method returns false
, then
* {@link #defaultBalance(Currency)} will be used when
* retrieving a balance for the specified {@link Currency} with
* the specified {@link Context}s.
*
* @param currency The {@link Currency} to determine if a balance is set for
* @param cause The {@link Cause} to use to compute context for
* this {@link Currency}
* @return Whether this account has a set balance for the specified
* {@link Currency} and {@link Context}s
*/
boolean hasBalance(Currency currency, Cause cause);
/**
* Returns whether this account has a set balance for the specified
* {@link Currency}, with the current active cause.
*
* If this method returns false
, then
* {@link #defaultBalance(Currency)} will be used when retrieving
* a balance for the specifid {@link Currency} with
* the current active cause
.
*
* @param currency The {@link Currency} to determine if a balance is set for.
* @return Whether this account has a set balance for the specified
* {@link Currency} and current active cause.
*/
default boolean hasBalance(Currency currency) {
return this.hasBalance(currency, this.contextCause());
}
/**
* Returns a {@link BigDecimal} representative of the balance stored within this
* {@link Account} for the {@link Currency} given and the set of {@link Context}s.
*
* The default result when the account does not have a balance of the
* given {@link Currency} will be {@link #defaultBalance(Currency)}.
*
* The balance may be unavailable depending on the set of
* {@link Context}s used.
*
* @param currency a {@link Currency} to check the balance of
* @param contexts a set of Contexts to check the balance against
* @return The value for the specified {@link Currency} with
* the specified {@link Context}s.
*/
BigDecimal balance(Currency currency, Set contexts);
/**
* Returns a {@link BigDecimal} representative of the balance stored within this
* {@link Account} for the {@link Currency} given and the set of {@link Context}s.
*
* The default result when the account does not have a balance of the
* given {@link Currency} will be {@link #defaultBalance(Currency)}.
*
* The balance may be unavailable depending on the set of
* {@link Context}s used.
*
* @param currency a {@link Currency} to check the balance of
* @param cause a cause used for deriving context to check the balance against
* @return The value for the specified {@link Currency} with
* the specified {@link Cause}.
*/
BigDecimal balance(Currency currency, Cause cause);
/**
* Returns a {@link BigDecimal} representative of the balance stored
* within this {@link Account} for the {@link Currency} given, with
* the current active cause.
*
* The default result when the account does not have a balance of the
* given {@link Currency} will be {@link #defaultBalance(Currency)}.
*
* @param currency a {@link Currency} to check the balance of
* @return the value for the specified {@link Currency}.
*/
default BigDecimal balance(final Currency currency) {
return this.balance(currency, this.contextCause());
}
/**
* Returns a {@link Map} of all currently set balances the account holds
* within the set of {@link Context}s.
*
* Amounts may differ depending on the {@link Context}s specified and
* the implementation. The set of {@link Context}s may be empty.
*
* {@link Currency} amounts which are 0 may or may not be included in
* the returned mapping.
*
* Changes to the returned {@link Map} will not be reflected in
* the underlying {@link Account}. See
* {@link #setBalance(Currency, BigDecimal, Cause)} to set values.
*
* @param contexts the set of {@link Context}s to use with the
* specified amounts
* @return A {@link Map} of {@link Currency} to {@link BigDecimal} amounts
* that this account holds
*/
Map balances(Set contexts);
/**
* Returns a {@link Map} of all currently set balances the account holds
* within the set of {@link Context}s.
*
* Amounts may differ depending on the {@link Cause} specified and
* the implementation. The set of {@link Context}s may be empty.
*
* {@link Currency} amounts which are 0 may or may not be included in
* the returned mapping.
*
* Changes to the returned {@link Map} will not be reflected in
* the underlying {@link Account}. See
* {@link #setBalance(Currency, BigDecimal, Cause)} to set values.
*
* @param cause the set of {@link Context}s to use with the
* specified amounts
* @return A {@link Map} of {@link Currency} to {@link BigDecimal} amounts
* that this account holds
*/
Map balances(Cause cause);
/**
* Returns a {@link Map} of all currently set balances the account holds
* within the current active {@link Context}.
*
* Amounts may differ depending on the {@link Context}s specified and
* the implementation. The set of {@link Context}s may be empty.
*
* {@link Currency} amounts which are 0 may or may not be included in
* the returned mapping.
*
* Changes to the returned {@link Map} will not be reflected in
* the underlying {@link Account} and may result in runtime exceptions
* depending on implementation. See
* {@link #setBalance(Currency, BigDecimal, Cause)} to set values.
*
* @return A {@link Map} of {@link Currency} to {@link BigDecimal} amounts
* that this account holds
*/
default Map balances() {
return this.balances(this.contextCause());
}
/**
* Sets the balance for this account to the specified amount for
* the specified {@link Currency}, with the specified set of {@link Context}s.
*
* Negative balances may or may not be supported depending on
* the {@link Currency} specified and the implementation.
*
* @param currency The {@link Currency} to set the balance for
* @param amount The amount to set for the specified {@link Currency}
* @param contexts The set of {@link Context}s to use with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult setBalance(Currency currency, BigDecimal amount, Set contexts);
/**
* Sets the balance for this account to the specified amount for
* the specified {@link Currency}, with the specified {@link Cause}.
*
* Negative balances may or may not be supported depending on
* the {@link Currency} specified and the implementation.
*
* @param currency The {@link Currency} to set the balance for
* @param amount The amount to set for the specified {@link Currency}
* @param cause The cause used to computer context to use with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult setBalance(Currency currency, BigDecimal amount, Cause cause);
/**
* Sets the balance for this account to the specified amount for the
* specified {@link Currency}, with the current active {@link Context}s.
*
* Negative balances may or may not be supported depending on
* the {@link Currency} specified and the implementation.
*
* @param currency The {@link Currency} to set the balance for
* @param amount The amount to set for the specified {@link Currency}
* @return The result of the transaction
*/
default TransactionResult setBalance(Currency currency, BigDecimal amount) {
return this.setBalance(currency, amount, this.contextCause());
}
/**
* Resets the balances for all {@link Currency}s used on this account
* to their default values ({@link #defaultBalance(Currency)}),
* using the specified {@link Context}s.
*
* @param contexts the {@link Context}s to use when resetting the balances.
* @return A map of {@link Currency} to {@link TransactionResult}. Each
* entry represents the result of resetting a particular currency.
*/
Map resetBalances(Set contexts);
/**
* Resets the balances for all {@link Currency}s used on this account
* to their default values ({@link #defaultBalance(Currency)}),
* using the specified {@link Cause}s.
*
* @param cause the cause to computer context to use when resetting the balances.
* @return A map of {@link Currency} to {@link TransactionResult}. Each
* entry represents the result of resetting a particular currency.
*/
Map resetBalances(Cause cause);
/**
* Resets the balances for all {@link Currency}s used on this account to
* their default values ({@link #defaultBalance(Currency)}), using
* the current active {@link Context}.
*
* @return A map of {@link Currency} to {@link TransactionResult}. Each
* entry represents the result of resetting a particular currency
*/
default Map resetBalances() {
return this.resetBalances(this.contextCause());
}
/**
* Resets the balance for the specified {@link Currency} to its default
* value ({@link #defaultBalance(Currency)}), using
* the specified {@link Context}s.
*
* @param currency The {@link Currency} to reset the balance for
* @param contexts The {@link Context}s to use when resetting the balance
*
* @return The result of the transaction
*/
TransactionResult resetBalance(Currency currency, Set contexts);
/**
* Resets the balance for the specified {@link Currency} to its default
* value ({@link #defaultBalance(Currency)}), using context from
* the specified {@link Cause}.
*
* @param currency The {@link Currency} to reset the balance for
* @param cause The cause to use to compute context when resetting
* the balance
*
* @return The result of the transaction
*/
TransactionResult resetBalance(Currency currency, Cause cause);
/**
* Resets the balance for the specified {@link Currency} to its default
* value ({@link #defaultBalance(Currency)}),
* using the current active {@link Context}s.
*
* @param currency The {@link Currency} to reset the balance for
* @return The result of the transaction
*/
default TransactionResult resetBalance(Currency currency) {
return this.resetBalance(currency, this.contextCause());
}
/**
* Deposits the specified amount of the specified {@link Currency} to
* this account, using the specified {@link Context}s.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @param contexts the {@link Context}s to use with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult deposit(Currency currency, BigDecimal amount, Set contexts);
/**
* Deposits the specified amount of the specified {@link Currency} to
* this account, using the specified {@link Cause}.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @param cause the cause to use to compute context with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult deposit(Currency currency, BigDecimal amount, Cause cause);
/**
* Deposits the given amount of the specified {@link Currency} to
* this account, using the current active {@link Context}s.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @return The result of the transaction
*/
default TransactionResult deposit(Currency currency, BigDecimal amount) {
return this.deposit(currency, amount, this.contextCause());
}
/**
* Withdraws the specified amount of the specified {@link Currency} from
* this account, using the specified {@link Context}s.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @param contexts The {@link Context}s to use with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult withdraw(Currency currency, BigDecimal amount, Set contexts);
/**
* Withdraws the specified amount of the specified {@link Currency} from
* this account, using the specified {@link Cause}.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @param cause The cause to use to compute context with the
* specified {@link Currency}
* @return The result of the transaction
*/
TransactionResult withdraw(Currency currency, BigDecimal amount, Cause cause);
/**
* Withdraws the specified amount of the specified {@link Currency} from
* this account, using the current active {@link Context}s.
*
* @param currency The {@link Currency} to deposit the specified amount for
* @param amount The amount to deposit for the specified {@link Currency}
* @return The result of the transaction
*/
default TransactionResult withdraw(Currency currency, BigDecimal amount) {
return this.withdraw(currency, amount, this.contextCause());
}
/**
* Transfers the specified amount of the specified {@link Currency}
* from this account the destination account,
* using the specified {@link Context}s.
*
* This operation is a merged {@link #withdraw(Currency, BigDecimal, Cause)}
* from this account with a {@link #deposit(Currency, BigDecimal, Cause)}
* into the specified account.
*
* @param to the Account to transfer the amounts to.
* @param currency The {@link Currency} to transfer the specified amount for
* @param amount The amount to transfer for the specified {@link Currency}
* @param contexts The {@link Context}s to use with the
* specified {@link Currency} and account
* @return A {@link TransferResult} representative of the effects of
* the operation
*/
TransferResult transfer(Account to, Currency currency, BigDecimal amount, Set contexts);
/**
* Transfers the specified amount of the specified {@link Currency}
* from this account the destination account,
* using the specified {@link Cause}.
*
* This operation is a merged {@link #withdraw(Currency, BigDecimal, Cause)}
* from this account with a {@link #deposit(Currency, BigDecimal, Cause)}
* into the specified account.
*
* @param to the Account to transfer the amounts to.
* @param currency The {@link Currency} to transfer the specified amount for
* @param amount The amount to transfer for the specified {@link Currency}
* @param cause The cause to use with the
* specified {@link Currency} and account
* @return A {@link TransferResult} representative of the effects of
* the operation
*/
TransferResult transfer(Account to, Currency currency, BigDecimal amount, Cause cause);
/**
* Transfers the specified amount of the specified {@link Currency}
* from this account the destination account,
* using the current active {@link Context}s.
*
* This operation is a merged {@link #withdraw(Currency, BigDecimal, Cause)}
* from this account with a {@link #deposit(Currency, BigDecimal, Cause)}
* into the specified account.
*
* @param to the Account to transfer the amounts to.
* @param currency The {@link Currency} to transfer the specified amount for
* @param amount The amount to transfer for the specified {@link Currency}
* @return A {@link TransferResult} representative of the effects of the
* operation
*/
default TransferResult transfer(Account to, Currency currency, BigDecimal amount) {
return this.transfer(to, currency, amount, this.contextCause());
}
}