Add ban/unban commands

This commit is contained in:
moneromooo 2015-01-21 18:15:49 +00:00
parent efcfc84c69
commit 84f550a355
3 changed files with 73 additions and 3 deletions

View file

@ -17,7 +17,25 @@ import tipbot.coinspecs as coinspecs
from tipbot.command_manager import * from tipbot.command_manager import *
from utils import * from utils import *
def IsBetAmountValid(amount,minbet,maxbet,potential_loss,max_loss,max_loss_ratio): def IsBanned(link):
try:
banned = redis_hget('banned',link.identity())
if not banned:
return False, None
banned = float(banned)
now = time.time()
if banned < now:
redis_hdel('banned',link.identity())
return False, None
return True, 'You are banned for %s' % TimeToString(banned-now)
except Exception,e:
log_error('Failed to check bannishment for %s: %s' % (link.identity(),str(e)))
return False, None
def IsBetValid(link,amount,minbet,maxbet,potential_loss,max_loss,max_loss_ratio):
banned,reason = IsBanned(link)
if banned:
return False, reason
try: try:
amount = float(amount) amount = float(amount)
except Exception,e: except Exception,e:
@ -302,6 +320,44 @@ def ReserveBalance(link,cmd):
return return
link.send("Reserve balance set") link.send("Reserve balance set")
def Ban(link,cmd):
t = 3600
try:
sidentity = GetParam(cmd,1)
if sidentity:
sidentity=IdentityFromString(link,sidentity)
if sidentity!=link.identity() and not IsAdmin(link):
log_error('%s is not admin, cannot ban %s' % (link.identity(),sidentity))
link.send('Access denied')
return
else:
sidentity=link.identity()
banned = redis_hget('banned',sidentity)
now=time.time()
if banned and float(banned) > now+t:
link.send('%s is already banned for %s' % (NickFromIdentity(sidentity), TimeToString(banned-now)))
else:
redis_hset('banned',sidentity,now+t)
link.send('%s is banned for %s' % (NickFromIdentity(sidentity), TimeToString(t)))
except Exception,e:
log_error('Failed to ban %s: %s' % (sidentity,str(e)))
link.send('An error occured')
return
def Unban(link,cmd):
try:
sidentity=GetParam(cmd,1)
if not sidentity:
sidentity=link.identity()
sidentity=IdentityFromString(link,sidentity)
redis_hdel('banned',sidentity)
link.send('%s was unbanned' % (sidentity))
except Exception,e:
log_error('Failed to unban %s: %s' % (sidentity,str(e)))
link.send('An error occured')
return
RegisterCommand({ RegisterCommand({
'module': 'betting', 'module': 'betting',
'name': 'reserve_balance', 'name': 'reserve_balance',
@ -318,3 +374,17 @@ RegisterCommand({
'registered': True, 'registered': True,
'help': "get the house balance" 'help': "get the house balance"
}) })
RegisterCommand({
'module': 'betting',
'name': 'ban',
'function': Ban,
'registered': True,
'help': "ban yourself from playing for an hour"
})
RegisterCommand({
'module': 'betting',
'name': 'unban',
'function': Unban,
'admin': True,
'help': "unban someone from playing"
})

View file

@ -567,7 +567,7 @@ def Blackjack(link,cmd):
potential_loss = amount * 1.5 + sidebets["potential_loss"] / coinspecs.atomic_units potential_loss = amount * 1.5 + sidebets["potential_loss"] / coinspecs.atomic_units
potential_units_loss = long (potential_loss * coinspecs.atomic_units) potential_units_loss = long (potential_loss * coinspecs.atomic_units)
log_info('%s bets a total of %s, potential loss %s, side bets %s' % (identity, AmountToString(total_units_wagered), AmountToString(potential_units_loss), str(sidebets))) log_info('%s bets a total of %s, potential loss %s, side bets %s' % (identity, AmountToString(total_units_wagered), AmountToString(potential_units_loss), str(sidebets)))
valid,reason = IsBetAmountValid(total_amount_wagered,config.blackjack_min_bet,config.blackjack_max_bet,potential_loss,config.blackjack_max_loss,config.blackjack_max_loss_ratio) valid,reason = IsBetValid(link,total_amount_wagered,config.blackjack_min_bet,config.blackjack_max_bet,potential_loss,config.blackjack_max_loss,config.blackjack_max_loss_ratio)
if not valid: if not valid:
log_info("Dice: %s's bet refused: %s" % (identity, reason)) log_info("Dice: %s's bet refused: %s" % (identity, reason))
link.send("%s: %s" % (link.user.nick, reason)) link.send("%s: %s" % (link.user.nick, reason))

View file

@ -68,7 +68,7 @@ def Dice(link,cmd):
log_info("Dice: %s wants to bet %s at x%f, %s target" % (identity, AmountToString(units), multiplier, "under" if under else "over")) log_info("Dice: %s wants to bet %s at x%f, %s target" % (identity, AmountToString(units), multiplier, "under" if under else "over"))
potential_loss = amount * multiplier potential_loss = amount * multiplier
valid,reason = IsBetAmountValid(amount,config.dice_min_bet,config.dice_max_bet,potential_loss,config.dice_max_loss,config.dice_max_loss_ratio) valid,reason = IsBetValid(link,amount,config.dice_min_bet,config.dice_max_bet,potential_loss,config.dice_max_loss,config.dice_max_loss_ratio)
if not valid: if not valid:
log_info("Dice: %s's bet refused: %s" % (identity, reason)) log_info("Dice: %s's bet refused: %s" % (identity, reason))
link.send("%s: %s" % (link.user.nick, reason)) link.send("%s: %s" % (link.user.nick, reason))