Economy rewrite (#313)

Server based accounts and settings. Added global leaderboard.
Bank class has been redone with hooks for 3rd party cogs.
The old ones have been removed, there was no way to keep backwards compatibility.
Since the bank.json format changed, once a user registers a bank account on a server if they're already present in the old format they'll keep their old balance.
This commit is contained in:
Twentysix 2016-06-23 22:58:44 +02:00 committed by GitHub
parent 6abc92db11
commit fd89c6870d

View File

@ -1,6 +1,8 @@
import discord import discord
from discord.ext import commands from discord.ext import commands
from .utils.dataIO import fileIO from cogs.utils.dataIO import dataIO, fileIO
from collections import namedtuple, defaultdict
from datetime import datetime
from random import randint from random import randint
from copy import deepcopy from copy import deepcopy
from .utils import checks from .utils import checks
@ -9,6 +11,8 @@ import os
import time import time
import logging import logging
default_settings = {"PAYDAY_TIME" : 300, "PAYDAY_CREDITS" : 120, "SLOT_MIN" : 5, "SLOT_MAX" : 100, "SLOT_TIME" : 0}
slot_payouts = """Slot machine payouts: slot_payouts = """Slot machine payouts:
:two: :two: :six: Bet * 5000 :two: :two: :six: Bet * 5000
:four_leaf_clover: :four_leaf_clover: :four_leaf_clover: +1000 :four_leaf_clover: :four_leaf_clover: :four_leaf_clover: +1000
@ -19,17 +23,182 @@ slot_payouts = """Slot machine payouts:
Three symbols: +500 Three symbols: +500
Two symbols: Bet * 2""" Two symbols: Bet * 2"""
class AccountAlreadyExists(Exception):
pass
class NoAccount(Exception):
pass
class InsufficientBalance(Exception):
pass
class NegativeValue(Exception):
pass
class SameSenderAndReceiver(Exception):
pass
class Bank:
def __init__(self, bot):
self.accounts = dataIO.load_json("data/economy/bank.json")
self.bot = bot
def create_account(self, user):
server = user.server
if not self.account_exists(user):
if server.id not in self.accounts:
self.accounts[server.id] = {}
if user.id in self.accounts: # Legacy account
balance = self.accounts[user.id]["balance"]
else:
balance = 0
timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
account = {"name" : user.name, "balance" : balance,
"created_at" : timestamp}
self.accounts[server.id][user.id] = account
self._save_bank()
return self.get_account(user)
else:
raise AccountAlreadyExists
def account_exists(self, user):
try:
self._get_account(user)
except NoAccount:
return False
return True
def widthdraw_credits(self, user, amount):
server = user.server
if amount < 0:
raise NegativeValue
account = self._get_account(user)
if account["balance"] >= amount:
account["balance"] -= amount
self.accounts[server.id][user.id] = account
self._save_bank()
else:
raise InsufficientBalance
def deposit_credits(self, user, amount):
server = user.server
if amount < 0:
raise NegativeValue
account = self._get_account(user)
account["balance"] += amount
self.accounts[server.id][user.id] = account
self._save_bank()
def set_credits(self, user, amount):
server = user.server
if amount < 0:
raise NegativeValue
account = self._get_account(user)
account["balance"] = amount
self.accounts[server.id][user.id] = account
self._save_bank()
def transfer_money(self, sender, receiver, amount):
server = sender.server
if amount < 0:
raise NegativeValue
if sender.id == receiver.id:
raise SameSenderAndReceiver
if self.account_exists(sender) and self.account_exists(receiver):
sender_acc = self._get_account(sender)
if sender_acc["balance"] < amount:
raise InsufficientBalance
self.widthdraw_credits(sender, amount)
self.deposit_credits(receiver, amount)
else:
raise NoAccount
def can_spend(self, user, amount):
account = self._get_account(user)
if account["balance"] >= amount:
return True
else:
return False
def wipe_bank(self, server):
self.accounts[server.id] = {}
self._save_bank()
def get_server_accounts(self, server):
if server.id in self.accounts:
raw_server_accounts = deepcopy(self.accounts[server.id])
accounts = []
for k, v in raw_server_accounts.items():
v["id"] = k
v["server"] = server
acc = self._create_account_obj(v)
accounts.append(acc)
return accounts
else:
return []
def get_all_accounts(self):
accounts = []
for server_id, v in self.accounts.items():
server = self.bot.get_server(server_id)
if server is None:# Servers that have since been left will be ignored
continue # Same for users_id from the old bank format
raw_server_accounts = deepcopy(self.accounts[server.id])
for k, v in raw_server_accounts.items():
v["id"] = k
v["server"] = server
acc = self._create_account_obj(v)
accounts.append(acc)
return accounts
def get_balance(self, user):
account = self._get_account(user)
return account["balance"]
def get_account(self, user):
acc = self._get_account(user)
acc["id"] = user.id
acc["server"] = user.server
return self._create_account_obj(acc)
def _create_account_obj(self, account):
Account = namedtuple("Account", "id name "
"balance created_at server")
return Account(
id = account["id"],
name = account["name"],
balance = account["balance"],
created_at = datetime.strptime(account["created_at"], "%Y-%m-%d %H:%M:%S"),
server = account["server"])
def _save_bank(self):
dataIO.save_json("data/economy/bank.json", self.accounts)
def _get_account(self, user):
server = user.server
try:
return deepcopy(self.accounts[server.id][user.id])
except KeyError:
raise NoAccount
class Economy: class Economy:
"""Economy """Economy
Get rich and have fun with imaginary currency!""" Get rich and have fun with imaginary currency!"""
def __init__(self, bot): def __init__(self, bot):
global default_settings
self.bot = bot self.bot = bot
self.bank = fileIO("data/economy/bank.json", "load") self.bank = Bank(bot)
self.settings = fileIO("data/economy/settings.json", "load") self.settings = fileIO("data/economy/settings.json", "load")
self.payday_register = {} if "PAYDAY_TIME" in self.settings: #old format
self.slot_register = {} default_settings = self.settings
self.settings = {}
self.settings = defaultdict(lambda: default_settings, self.settings)
self.payday_register = defaultdict(dict)
self.slot_register = defaultdict(dict)
@commands.group(name="bank", pass_context=True) @commands.group(name="bank", pass_context=True)
async def _bank(self, ctx): async def _bank(self, ctx):
@ -41,11 +210,11 @@ class Economy:
async def register(self, ctx): async def register(self, ctx):
"""Registers an account at the Twentysix bank""" """Registers an account at the Twentysix bank"""
user = ctx.message.author user = ctx.message.author
if user.id not in self.bank: try:
self.bank[user.id] = {"name" : user.name, "balance" : 100} account = self.bank.create_account(user)
fileIO("data/economy/bank.json", "save", self.bank) await self.bot.say("{} Account opened. Current balance: {}".format(user.mention,
await self.bot.say("{} Account opened. Current balance: {}".format(user.mention, str(self.check_balance(user.id)))) account.balance))
else: except AccountAlreadyExists:
await self.bot.say("{} You already have an account at the Twentysix bank.".format(user.mention)) await self.bot.say("{} You already have an account at the Twentysix bank.".format(user.mention))
@_bank.command(pass_context=True) @_bank.command(pass_context=True)
@ -55,36 +224,33 @@ class Economy:
Defaults to yours.""" Defaults to yours."""
if not user: if not user:
user = ctx.message.author user = ctx.message.author
if self.account_check(user.id): try:
await self.bot.say("{} Your balance is: {}".format(user.mention, str(self.check_balance(user.id)))) await self.bot.say("{} Your balance is: {}".format(user.mention, self.bank.get_balance(user)))
else: except NoAccount:
await self.bot.say("{} You don't have an account at the Twentysix bank. Type {}bank register to open one.".format(user.mention, ctx.prefix)) await self.bot.say("{} You don't have an account at the Twentysix bank."
" Type {}bank register to open one.".format(user.mention, ctx.prefix))
else: else:
if self.account_check(user.id): try:
balance = self.check_balance(user.id) await self.bot.say("{}'s balance is {}".format(user.name, self.bank.get_balance(user)))
await self.bot.say("{}'s balance is {}".format(user.name, str(balance))) except NoAccount:
else:
await self.bot.say("That user has no bank account.") await self.bot.say("That user has no bank account.")
@_bank.command(pass_context=True) @_bank.command(pass_context=True)
async def transfer(self, ctx, user : discord.Member, sum : int): async def transfer(self, ctx, user : discord.Member, sum : int):
"""Transfer credits to other users""" """Transfer credits to other users"""
author = ctx.message.author author = ctx.message.author
if author == user: try:
await self.bot.say("You can't transfer money to yourself.") self.bank.transfer_money(author, user, sum)
return logger.info("{}({}) transferred {} credits to {}({})".format(
if sum < 1: author.name, author.id, sum, user.name, user.id))
await self.bot.say("{} credits have been transferred to {}'s account.".format(sum, user.name))
except NegativeValue:
await self.bot.say("You need to transfer at least 1 credit.") await self.bot.say("You need to transfer at least 1 credit.")
return except SameSenderAndReceiver:
if self.account_check(user.id): await self.bot.say("You can't transfer money to yourself.")
if self.enough_money(author.id, sum): except InsufficientBalance:
self.withdraw_money(author.id, sum) await self.bot.say("You don't have that sum in your bank account.")
self.add_money(user.id, sum) except NoAccount:
logger.info("{}({}) transferred {} credits to {}({})".format(author.name, author.id, str(sum), user.name, user.id))
await self.bot.say("{} credits have been transferred to {}'s account.".format(str(sum), user.name))
else:
await self.bot.say("You don't have that sum in your bank account.")
else:
await self.bot.say("That user has no bank account.") await self.bot.say("That user has no bank account.")
@_bank.command(name="set", pass_context=True) @_bank.command(name="set", pass_context=True)
@ -94,51 +260,62 @@ class Economy:
Admin/owner restricted.""" Admin/owner restricted."""
author = ctx.message.author author = ctx.message.author
done = self.set_money(user.id, sum) try:
if done: self.bank.set_credits(user, sum)
logger.info("{}({}) set {} credits to {} ({})".format(author.name, author.id, str(sum), user.name, user.id)) logger.info("{}({}) set {} credits to {} ({})".format(author.name, author.id, str(sum), user.name, user.id))
await self.bot.say("{}'s credits have been set to {}".format(user.name, str(sum))) await self.bot.say("{}'s credits have been set to {}".format(user.name, str(sum)))
else: except NoAccount:
await self.bot.say("User has no bank account.") await self.bot.say("User has no bank account.")
@commands.command(pass_context=True, no_pm=True) @commands.command(pass_context=True, no_pm=True)
async def payday(self, ctx): async def payday(self, ctx): # TODO
"""Get some free credits""" """Get some free credits"""
author = ctx.message.author author = ctx.message.author
server = author.server
id = author.id id = author.id
if self.account_check(id): if self.bank.account_exists(author):
if id in self.payday_register: if id in self.payday_register[server.id]:
seconds = abs(self.payday_register[id] - int(time.perf_counter())) seconds = abs(self.payday_register[server.id][id] - int(time.perf_counter()))
if seconds >= self.settings["PAYDAY_TIME"]: if seconds >= self.settings[server.id]["PAYDAY_TIME"]:
self.add_money(id, self.settings["PAYDAY_CREDITS"]) self.bank.deposit_credits(author, self.settings[server.id]["PAYDAY_CREDITS"])
self.payday_register[id] = int(time.perf_counter()) self.payday_register[server.id][id] = int(time.perf_counter())
await self.bot.say("{} Here, take some credits. Enjoy! (+{} credits!)".format(author.mention, str(self.settings["PAYDAY_CREDITS"]))) await self.bot.say("{} Here, take some credits. Enjoy! (+{} credits!)".format(author.mention, str(self.settings[server.id]["PAYDAY_CREDITS"])))
else: else:
await self.bot.say("{} Too soon. For your next payday you have to wait {}.".format(author.mention, self.display_time(self.settings["PAYDAY_TIME"] - seconds))) await self.bot.say("{} Too soon. For your next payday you have to wait {}.".format(author.mention, self.display_time(self.settings[server.id]["PAYDAY_TIME"] - seconds)))
else: else:
self.payday_register[id] = int(time.perf_counter()) self.payday_register[server.id][id] = int(time.perf_counter())
self.add_money(id, self.settings["PAYDAY_CREDITS"]) self.bank.deposit_credits(author, self.settings[server.id]["PAYDAY_CREDITS"])
await self.bot.say("{} Here, take some credits. Enjoy! (+{} credits!)".format(author.mention, str(self.settings["PAYDAY_CREDITS"]))) await self.bot.say("{} Here, take some credits. Enjoy! (+{} credits!)".format(author.mention, str(self.settings[server.id]["PAYDAY_CREDITS"])))
else: else:
await self.bot.say("{} You need an account to receive credits. Type {}bank register to open one.".format(author.mention, ctx.prefix)) await self.bot.say("{} You need an account to receive credits. Type {}bank register to open one.".format(author.mention, ctx.prefix))
@commands.command() @commands.group(pass_context=True)
async def leaderboard(self, top : int=10): async def leaderboard(self, ctx):
"""Prints out the leaderboard """Server / global leaderboard
Defaults to server"""
if ctx.invoked_subcommand is None:
await ctx.invoke(self._server_leaderboard)
@leaderboard.command(name="server", pass_context=True)
async def _server_leaderboard(self, ctx, top : int=10):
"""Prints out the server's leaderboard
Defaults to top 10""" #Originally coded by Airenkun - edited by irdumb Defaults to top 10""" #Originally coded by Airenkun - edited by irdumb
server = ctx.message.server
if top < 1: if top < 1:
top = 10 top = 10
bank_sorted = sorted(self.bank.items(), key=lambda x: x[1]["balance"], reverse=True) bank_sorted = sorted(self.bank.get_server_accounts(server),
key=lambda x: x.balance, reverse=True)
if len(bank_sorted) < top: if len(bank_sorted) < top:
top = len(bank_sorted) top = len(bank_sorted)
topten = bank_sorted[:top] topten = bank_sorted[:top]
highscore = "" highscore = ""
place = 1 place = 1
for id in topten: for acc in topten:
highscore += str(place).ljust(len(str(top))+1) highscore += str(place).ljust(len(str(top))+1)
highscore += (id[1]["name"]+" ").ljust(23-len(str(id[1]["balance"]))) highscore += (acc.name+" ").ljust(23-len(str(acc.balance)))
highscore += str(id[1]["balance"]) + "\n" highscore += str(acc.balance) + "\n"
place += 1 place += 1
if highscore: if highscore:
if len(highscore) < 1985: if len(highscore) < 1985:
@ -148,31 +325,69 @@ class Economy:
else: else:
await self.bot.say("There are no accounts in the bank.") await self.bot.say("There are no accounts in the bank.")
@commands.command(pass_context=True) @leaderboard.command(name="global")
async def payouts(self, ctx): async def _global_leaderboard(self, top : int=10):
"""Prints out the global leaderboard
Defaults to top 10"""
if top < 1:
top = 10
bank_sorted = sorted(self.bank.get_all_accounts(),
key=lambda x: x.balance, reverse=True)
unique_accounts = []
for acc in bank_sorted:
if not self.already_in_list(unique_accounts, acc):
unique_accounts.append(acc)
if len(unique_accounts) < top:
top = len(unique_accounts)
topten = unique_accounts[:top]
highscore = ""
place = 1
for acc in topten:
highscore += str(place).ljust(len(str(top))+1)
highscore += ("{} |{}| ".format(acc.name, acc.server.name)).ljust(23-len(str(acc.balance)))
highscore += str(acc.balance) + "\n"
place += 1
if highscore:
if len(highscore) < 1985:
await self.bot.say("```py\n"+highscore+"```")
else:
await self.bot.say("The leaderboard is too big to be displayed. Try with a lower <top> parameter.")
else:
await self.bot.say("There are no accounts in the bank.")
def already_in_list(self, accounts, user):
for acc in accounts:
if user.id == acc.id:
return True
return False
@commands.command()
async def payouts(self):
"""Shows slot machine payouts""" """Shows slot machine payouts"""
await self.bot.send_message(ctx.message.author, slot_payouts) await self.bot.whisper(slot_payouts)
@commands.command(pass_context=True, no_pm=True) @commands.command(pass_context=True, no_pm=True)
async def slot(self, ctx, bid : int): async def slot(self, ctx, bid : int):
"""Play the slot machine""" """Play the slot machine"""
author = ctx.message.author author = ctx.message.author
if not self.account_check(author.id): server = author.server
if not self.bank.account_exists(author):
await self.bot.say("{} You need an account to use the slot machine. Type {}bank register to open one.".format(author.mention, ctx.prefix)) await self.bot.say("{} You need an account to use the slot machine. Type {}bank register to open one.".format(author.mention, ctx.prefix))
return return
if self.enough_money(author.id, bid): if self.bank.can_spend(author, bid):
if bid >= self.settings["SLOT_MIN"] and bid <= self.settings["SLOT_MAX"]: if bid >= self.settings[server.id]["SLOT_MIN"] and bid <= self.settings[server.id]["SLOT_MAX"]:
if author.id in self.slot_register: if author.id in self.slot_register:
if abs(self.slot_register[author.id] - int(time.perf_counter())) >= self.settings["SLOT_TIME"]: if abs(self.slot_register[author.id] - int(time.perf_counter())) >= self.settings[server.id]["SLOT_TIME"]:
self.slot_register[author.id] = int(time.perf_counter()) self.slot_register[author.id] = int(time.perf_counter())
await self.slot_machine(ctx.message, bid) await self.slot_machine(ctx.message, bid)
else: else:
await self.bot.say("Slot machine is still cooling off! Wait {} seconds between each pull".format(self.settings["SLOT_TIME"])) await self.bot.say("Slot machine is still cooling off! Wait {} seconds between each pull".format(self.settings[server.id]["SLOT_TIME"]))
else: else:
self.slot_register[author.id] = int(time.perf_counter()) self.slot_register[author.id] = int(time.perf_counter())
await self.slot_machine(ctx.message, bid) await self.slot_machine(ctx.message, bid)
else: else:
await self.bot.say("{0} Bid must be between {1} and {2}.".format(author.mention, self.settings["SLOT_MIN"], self.settings["SLOT_MAX"])) await self.bot.say("{0} Bid must be between {1} and {2}.".format(author.mention, self.settings[server.id]["SLOT_MIN"], self.settings[server.id]["SLOT_MAX"]))
else: else:
await self.bot.say("{0} You need an account with enough funds to play the slot machine.".format(author.mention)) await self.bot.say("{0} You need an account with enough funds to play the slot machine.".format(author.mention))
@ -214,104 +429,66 @@ class Economy:
await self.bot.send_message(message.channel, "{}{} Two symbols! Your bet is multiplied * 2! {}! ".format(display_reels, message.author.mention, str(bid))) await self.bot.send_message(message.channel, "{}{} Two symbols! Your bet is multiplied * 2! {}! ".format(display_reels, message.author.mention, str(bid)))
else: else:
await self.bot.send_message(message.channel, "{}{} Nothing! Lost bet. ".format(display_reels, message.author.mention)) await self.bot.send_message(message.channel, "{}{} Nothing! Lost bet. ".format(display_reels, message.author.mention))
self.withdraw_money(message.author.id, bid) self.bank.widthdraw_credits(message.author, bid)
await self.bot.send_message(message.channel, "Credits left: {}".format(str(self.check_balance(message.author.id)))) await self.bot.send_message(message.channel, "Credits left: {}".format(self.bank.get_balance(message.author)))
return True return True
self.add_money(message.author.id, bid) self.bank.deposit_credits(message.author, bid)
await self.bot.send_message(message.channel, "Current credits: {}".format(str(self.check_balance(message.author.id)))) await self.bot.send_message(message.channel, "Current credits: {}".format(self.bank.get_balance(message.author)))
@commands.group(pass_context=True, no_pm=True) @commands.group(pass_context=True, no_pm=True)
@checks.admin_or_permissions(manage_server=True) @checks.admin_or_permissions(manage_server=True)
async def economyset(self, ctx): async def economyset(self, ctx):
"""Changes economy module settings""" """Changes economy module settings"""
server = ctx.message.server
settings = self.settings[server.id]
if ctx.invoked_subcommand is None: if ctx.invoked_subcommand is None:
msg = "```" msg = "```"
for k, v in self.settings.items(): for k, v in settings.items():
msg += str(k) + ": " + str(v) + "\n" msg += "{}: {}\n".format(k, v)
msg += "\nType {}help economyset to see the list of commands.```".format(ctx.prefix) msg += "```"
await send_cmd_help(ctx)
await self.bot.say(msg) await self.bot.say(msg)
@economyset.command() @economyset.command(pass_context=True)
async def slotmin(self, bid : int): async def slotmin(self, ctx, bid : int):
"""Minimum slot machine bid""" """Minimum slot machine bid"""
self.settings["SLOT_MIN"] = bid server = ctx.message.server
self.settings[server.id]["SLOT_MIN"] = bid
await self.bot.say("Minimum bid is now " + str(bid) + " credits.") await self.bot.say("Minimum bid is now " + str(bid) + " credits.")
fileIO("data/economy/settings.json", "save", self.settings) fileIO("data/economy/settings.json", "save", self.settings)
@economyset.command() @economyset.command(pass_context=True)
async def slotmax(self, bid : int): async def slotmax(self, ctx, bid : int):
"""Maximum slot machine bid""" """Maximum slot machine bid"""
self.settings["SLOT_MAX"] = bid server = ctx.message.server
self.settings[server.id]["SLOT_MAX"] = bid
await self.bot.say("Maximum bid is now " + str(bid) + " credits.") await self.bot.say("Maximum bid is now " + str(bid) + " credits.")
fileIO("data/economy/settings.json", "save", self.settings) fileIO("data/economy/settings.json", "save", self.settings)
@economyset.command() @economyset.command(pass_context=True)
async def slottime(self, seconds : int): async def slottime(self, ctx, seconds : int):
"""Seconds between each slots use""" """Seconds between each slots use"""
self.settings["SLOT_TIME"] = seconds server = ctx.message.server
self.settings[server.id]["SLOT_TIME"] = seconds
await self.bot.say("Cooldown is now " + str(seconds) + " seconds.") await self.bot.say("Cooldown is now " + str(seconds) + " seconds.")
fileIO("data/economy/settings.json", "save", self.settings) fileIO("data/economy/settings.json", "save", self.settings)
@economyset.command() @economyset.command(pass_context=True)
async def paydaytime(self, seconds : int): async def paydaytime(self, ctx, seconds : int):
"""Seconds between each payday""" """Seconds between each payday"""
self.settings["PAYDAY_TIME"] = seconds server = ctx.message.server
self.settings[server.id]["PAYDAY_TIME"] = seconds
await self.bot.say("Value modified. At least " + str(seconds) + " seconds must pass between each payday.") await self.bot.say("Value modified. At least " + str(seconds) + " seconds must pass between each payday.")
fileIO("data/economy/settings.json", "save", self.settings) fileIO("data/economy/settings.json", "save", self.settings)
@economyset.command() @economyset.command(pass_context=True)
async def paydaycredits(self, credits : int): async def paydaycredits(self, ctx, credits : int):
"""Credits earned each payday""" """Credits earned each payday"""
self.settings["PAYDAY_CREDITS"] = credits server = ctx.message.server
self.settings[server.id]["PAYDAY_CREDITS"] = credits
await self.bot.say("Every payday will now give " + str(credits) + " credits.") await self.bot.say("Every payday will now give " + str(credits) + " credits.")
fileIO("data/economy/settings.json", "save", self.settings) fileIO("data/economy/settings.json", "save", self.settings)
def account_check(self, id):
if id in self.bank:
return True
else:
return False
def check_balance(self, id):
if self.account_check(id):
return self.bank[id]["balance"]
else:
return False
def add_money(self, id, amount):
if self.account_check(id):
self.bank[id]["balance"] = self.bank[id]["balance"] + int(amount)
fileIO("data/economy/bank.json", "save", self.bank)
else:
return False
def withdraw_money(self, id, amount):
if self.account_check(id):
if self.bank[id]["balance"] >= int(amount):
self.bank[id]["balance"] = self.bank[id]["balance"] - int(amount)
fileIO("data/economy/bank.json", "save", self.bank)
else:
return False
else:
return False
def enough_money(self, id, amount):
if self.account_check(id):
if self.bank[id]["balance"] >= int(amount):
return True
else:
return False
else:
return False
def set_money(self, id, amount):
if self.account_check(id):
self.bank[id]["balance"] = amount
fileIO("data/economy/bank.json", "save", self.bank)
return True
else:
return False
def display_time(self, seconds, granularity=2): # What would I ever do without stackoverflow? def display_time(self, seconds, granularity=2): # What would I ever do without stackoverflow?
intervals = ( # Source: http://stackoverflow.com/a/24542445 intervals = ( # Source: http://stackoverflow.com/a/24542445
('weeks', 604800), # 60 * 60 * 24 * 7 ('weeks', 604800), # 60 * 60 * 24 * 7
@ -338,20 +515,11 @@ def check_folders():
os.makedirs("data/economy") os.makedirs("data/economy")
def check_files(): def check_files():
settings = {"PAYDAY_TIME" : 300, "PAYDAY_CREDITS" : 120, "SLOT_MIN" : 5, "SLOT_MAX" : 100, "SLOT_TIME" : 0}
f = "data/economy/settings.json" f = "data/economy/settings.json"
if not fileIO(f, "check"): if not fileIO(f, "check"):
print("Creating default economy's settings.json...") print("Creating default economy's settings.json...")
fileIO(f, "save", settings) fileIO(f, "save", {})
else: #consistency check
current = fileIO(f, "load")
if current.keys() != settings.keys():
for key in settings.keys():
if key not in current.keys():
current[key] = settings[key]
print("Adding " + str(key) + " field to economy settings.json")
fileIO(f, "save", current)
f = "data/economy/bank.json" f = "data/economy/bank.json"
if not fileIO(f, "check"): if not fileIO(f, "check"):
@ -362,7 +530,7 @@ def setup(bot):
global logger global logger
check_folders() check_folders()
check_files() check_files()
logger = logging.getLogger("economy") logger = logging.getLogger("red.economy")
if logger.level == 0: # Prevents the logger from being loaded again in case of module reload if logger.level == 0: # Prevents the logger from being loaded again in case of module reload
logger.setLevel(logging.INFO) logger.setLevel(logging.INFO)
handler = logging.FileHandler(filename='data/economy/economy.log', encoding='utf-8', mode='a') handler = logging.FileHandler(filename='data/economy/economy.log', encoding='utf-8', mode='a')