def hpmanager(user): total_hp = (get_user_num_chats(user.id) + 10) * 10 if not is_user_gbanned(user.id): # Assign new var `new_hp` since we need `total_hp` in # end to calculate percentage. new_hp = total_hp # if no username decrease 25% of hp. if not user.username: new_hp -= no_by_per(total_hp, 25) try: dispatcher.bot.get_user_profile_photos(user.id).photos[0][-1] except IndexError: # no profile photo ==> -25% of hp new_hp -= no_by_per(total_hp, 25) # if no /setme exist ==> -20% of hp if not sql.get_user_me_info(user.id): new_hp -= no_by_per(total_hp, 20) # if no bio exsit ==> -10% of hp if not sql.get_user_bio(user.id): new_hp -= no_by_per(total_hp, 10) if is_user_afk(user.id): afkst = afk_reason(user.id) # if user is afk and no reason then decrease 7% # else if reason exist decrease 5% if not afkst: new_hp -= no_by_per(total_hp, 7) else: new_hp -= no_by_per(total_hp, 5) # fbanned users will have (2*number of fbans) less from max HP # Example: if HP is 100 but user has 5 diff fbans # Available HP is (2*5) = 10% less than Max HP # So.. 10% of 100HP = 90HP # Commenting out fban health decrease cause it wasnt working and isnt needed ig. #_, fbanlist = get_user_fbanlist(user.id) #new_hp -= no_by_per(total_hp, 2 * len(fbanlist)) # Bad status effects: # gbanned users will always have 5% HP from max HP # Example: If HP is 100 but gbanned # Available HP is 5% of 100 = 5HP else: new_hp = no_by_per(total_hp, 5) return { "earnedhp": int(new_hp), "totalhp": int(total_hp), "percentage": get_percentage(total_hp, new_hp) }
def __user_info__(user_id): is_afk = is_user_afk(user_id) text = "" if is_afk: since_afk = get_readable_time( (time.time() - float(REDIS.get(f'afk_time_{user_id}')))) text = "<i>This user is currently afk (away from keyboard).</i>" text += f"\n<i>Since: {since_afk}</i>" else: text = "<i>This user is currently isn't afk (away from keyboard).</i>" return text
def check_afk(update, context, user_id, fst_name, userc_id): if is_user_afk(user_id): reason = afk_reason(user_id) since_afk = get_readable_time( (time.time() - float(REDIS.get(f'afk_time_{user_id}')))) if reason == "none": if int(userc_id) == int(user_id): return res = "{} is AFK!\nSince: {}".format(fst_name, since_afk) update.effective_message.reply_text(res) else: if int(userc_id) == int(user_id): return res = "{} is AFK! Says it's because of:\n{}\nSince: {}".format( fst_name, reason, since_afk) update.effective_message.reply_text(res)
def no_longer_afk(update, context): user = update.effective_user message = update.effective_message if not user: # ignore channels return if not is_user_afk(user.id): #Check if user is afk or not return end_afk_time = get_readable_time( (time.time() - float(REDIS.get(f'afk_time_{user.id}')))) REDIS.delete(f'afk_time_{user.id}') res = end_afk(user.id) if res: if message.new_chat_members: #dont say msg return firstname = update.effective_user.first_name try: message.reply_text( "{} is no longer AFK!\nTime you were AFK for: {}".format( firstname, end_afk_time)) except Exception: return
def info(update: Update, context: CallbackContext): bot, args = context.bot, context.args message = update.effective_message chat = update.effective_chat user_id = extract_user(update.effective_message, args) if user_id: user = bot.get_chat(user_id) elif not message.reply_to_message and not args: user = message.from_user elif not message.reply_to_message and ( not args or (len(args) >= 1 and not args[0].startswith("@") and not args[0].isdigit() and not message.parse_entities([MessageEntity.TEXT_MENTION]))): message.reply_text("I can't extract a user from this.") return else: return rep = message.reply_text("<code>Cutie Cutie! fetching user info...</code>", parse_mode=ParseMode.HTML) text = (f"╒═══「<b> Appraisal results:</b> 」\n" f"ID: <code>{user.id}</code>\n" f"First Name: {html.escape(user.first_name)}") if user.last_name: text += f"\nLast Name: {html.escape(user.last_name)}" if user.username: text += f"\nUsername: @{html.escape(user.username)}" text += f"\nPermalink: {mention_html(user.id, 'link')}" if chat.type != "private" and user_id != bot.id: _stext = "\nPresence: <code>{}</code>" afk_st = is_user_afk(user.id) if afk_st: text += _stext.format("AFK") else: status = status = bot.get_chat_member(chat.id, user.id).status if status: if status in {"left", "kicked"}: text += _stext.format("Not here") elif status == "member": text += _stext.format("Detected") elif status in {"administrator", "creator"}: text += _stext.format("Admin") if user_id not in [bot.id, 777000, 1087968824]: userhp = hpmanager(user) text += f"\n\n<b>Health:</b> <code>{userhp['earnedhp']}/{userhp['totalhp']}</code>\n[<i>{make_bar(int(userhp['percentage']))} </i>{userhp['percentage']}%]" try: spamwtc = sw.get_ban(int(user.id)) if spamwtc: text += "\n\n<b>This person is Spamwatched!</b>" text += f"\nReason: <pre>{spamwtc.reason}</pre>" text += "\nAppeal at @SpamWatchSupport" else: pass except: pass # don't crash if api is down somehow... disaster_level_present = False if user.id == OWNER_ID: text += "\n\nThe Disaster level of this person is 'God'." disaster_level_present = True elif user.id in DEV_USERS: text += "\n\nThis user is member of 'Bot Lab'." disaster_level_present = True elif user.id in DRAGONS: text += "\n\nThe Disaster level of this person is 'Dragon'." disaster_level_present = True elif user.id in DEMONS: text += "\n\nThe Disaster level of this person is 'Demon'." disaster_level_present = True elif user.id in TIGERS: text += "\n\nThe Disaster level of this person is 'Tiger'." disaster_level_present = True elif user.id in WOLVES: text += "\n\nThe Disaster level of this person is 'Wolf'." disaster_level_present = True if disaster_level_present: text += ' [<a href="https://t.me/BotLabUpdates/33">?</a>]'.format( bot.username) try: user_member = chat.get_member(user.id) if user_member.status == 'administrator': result = requests.post( f"https://api.telegram.org/bot{TOKEN}/getChatMember?chat_id={chat.id}&user_id={user.id}" ) result = result.json()["result"] if "custom_title" in result.keys(): custom_title = result['custom_title'] text += f"\n\nTitle:\n<b>{custom_title}</b>" except BadRequest: pass for mod in USER_INFO: try: mod_info = mod.__user_info__(user.id).strip() except TypeError: mod_info = mod.__user_info__(user.id, chat.id).strip() if mod_info: text += "\n\n" + mod_info if INFOPIC: try: profile = context.bot.get_user_profile_photos( user.id).photos[0][-1] _file = bot.get_file(profile["file_id"]) _file.download(f"{user.id}.png") message.reply_document(document=open(f"{user.id}.png", "rb"), caption=(text), parse_mode=ParseMode.HTML, disable_web_page_preview=True) os.remove(f"{user.id}.png") # Incase user don't have profile pic, send normal text except IndexError: message.reply_text(text, parse_mode=ParseMode.HTML, disable_web_page_preview=True) else: message.reply_text(text, parse_mode=ParseMode.HTML, disable_web_page_preview=True) rep.delete()