add notifications and push instructions
parent
e9fbaa2fc5
commit
38c5bab42d
@ -0,0 +1,108 @@
|
|||||||
|
import json
|
||||||
|
import os
|
||||||
|
from typing import Dict, List, Tuple
|
||||||
|
|
||||||
|
from pykeybase.chat import KeybaseChat
|
||||||
|
|
||||||
|
DRONE_ENV_VARS = {"CI",
|
||||||
|
"DRONE",
|
||||||
|
"DRONE_BRANCH",
|
||||||
|
"DRONE_BUILD_ACTION",
|
||||||
|
"DRONE_BUILD_CREATED",
|
||||||
|
"DRONE_BUILD_EVENT",
|
||||||
|
"DRONE_BUILD_FINISHED",
|
||||||
|
"DRONE_BUILD_NUMBER",
|
||||||
|
"DRONE_BUILD_PARENT",
|
||||||
|
"DRONE_BUILD_STARTED",
|
||||||
|
"DRONE_BUILD_STATUS",
|
||||||
|
"DRONE_CALVER",
|
||||||
|
"DRONE_COMMIT",
|
||||||
|
"DRONE_COMMIT_AFTER",
|
||||||
|
"DRONE_COMMIT_AUTHOR",
|
||||||
|
"DRONE_COMMIT_AUTHOR_AVATAR",
|
||||||
|
"DRONE_COMMIT_AUTHOR_EMAIL",
|
||||||
|
"DRONE_COMMIT_AUTHOR_NAME",
|
||||||
|
"DRONE_COMMIT_BEFORE",
|
||||||
|
"DRONE_COMMIT_BRANCH",
|
||||||
|
"DRONE_COMMIT_LINK",
|
||||||
|
"DRONE_COMMIT_MESSAGE",
|
||||||
|
"DRONE_COMMIT_REF",
|
||||||
|
"DRONE_COMMIT_SHA",
|
||||||
|
"DRONE_DEPLOY_TO",
|
||||||
|
"DRONE_FAILED_STAGES",
|
||||||
|
"DRONE_FAILED_STEPS",
|
||||||
|
"DRONE_GIT_HTTP_URL",
|
||||||
|
"DRONE_GIT_SSH_URL",
|
||||||
|
"DRONE_PULL_REQUEST",
|
||||||
|
"DRONE_REMOTE_URL",
|
||||||
|
"DRONE_REPO",
|
||||||
|
"DRONE_REPO_BRANCH",
|
||||||
|
"DRONE_REPO_LINK",
|
||||||
|
"DRONE_REPO_NAME",
|
||||||
|
"DRONE_REPO_NAMESPACE",
|
||||||
|
"DRONE_REPO_OWNER",
|
||||||
|
"DRONE_REPO_PRIVATE",
|
||||||
|
"DRONE_REPO_SCM",
|
||||||
|
"DRONE_REPO_VISIBILITY",
|
||||||
|
"DRONE_SEMVER",
|
||||||
|
"DRONE_SEMVER_BUILD",
|
||||||
|
"DRONE_SEMVER_ERROR",
|
||||||
|
"DRONE_SEMVER_MAJOR",
|
||||||
|
"DRONE_SEMVER_MINOR",
|
||||||
|
"DRONE_SEMVER_PATCH",
|
||||||
|
"DRONE_SEMVER_PRERELEASE",
|
||||||
|
"DRONE_SEMVER_SHORT",
|
||||||
|
"DRONE_SOURCE_BRANCH",
|
||||||
|
"DRONE_STAGE_ARCH",
|
||||||
|
"DRONE_STAGE_DEPENDS_ON",
|
||||||
|
"DRONE_STAGE_FINISHED",
|
||||||
|
"DRONE_STAGE_KIND",
|
||||||
|
"DRONE_STAGE_MACHINE",
|
||||||
|
"DRONE_STAGE_NAME",
|
||||||
|
"DRONE_STAGE_NUMBER",
|
||||||
|
"DRONE_STAGE_OS",
|
||||||
|
"DRONE_STAGE_STARTED",
|
||||||
|
"DRONE_STAGE_STATUS",
|
||||||
|
"DRONE_STAGE_TYPE",
|
||||||
|
"DRONE_STAGE_VARIANT",
|
||||||
|
"DRONE_STEP_NAME",
|
||||||
|
"DRONE_STEP_NUMBER",
|
||||||
|
"DRONE_SYSTEM_HOST",
|
||||||
|
"DRONE_SYSTEM_HOSTNAME",
|
||||||
|
"DRONE_SYSTEM_PROTO",
|
||||||
|
"DRONE_SYSTEM_VERSION",
|
||||||
|
"DRONE_TAG",
|
||||||
|
"DRONE_TARGET_BRANCH"}
|
||||||
|
|
||||||
|
|
||||||
|
def build_drone_env_dict() -> Dict[str, str]:
|
||||||
|
return {key: os.environ.get(key, "") for key in DRONE_ENV_VARS}
|
||||||
|
|
||||||
|
|
||||||
|
def build_keybase_teams() -> List[Tuple[str, str]]:
|
||||||
|
keybase_teams = []
|
||||||
|
teams_list = os.environ.get("KEYBASE_TEAMS", "").split(",")
|
||||||
|
for team in teams_list:
|
||||||
|
keybase_teams.append(tuple(team.split(".")))
|
||||||
|
|
||||||
|
if not keybase_teams:
|
||||||
|
keybase_teams = [("", "")]
|
||||||
|
|
||||||
|
return keybase_teams
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
# Teams to notify format "<team>.<channel>,<team>.<channel>"
|
||||||
|
keybase_teams = build_keybase_teams()
|
||||||
|
keybase_chat = KeybaseChat()
|
||||||
|
env_map = build_drone_env_dict()
|
||||||
|
msg = json.dumps(env_map, indent=4)
|
||||||
|
|
||||||
|
print(msg)
|
||||||
|
|
||||||
|
for team in keybase_teams:
|
||||||
|
keybase_chat.send_team_message(team=team[0], message=msg, channel=team[1])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
@ -0,0 +1,122 @@
|
|||||||
|
"""sobelbot: techchat bot
|
||||||
|
TODO:
|
||||||
|
* add more commands
|
||||||
|
* config file
|
||||||
|
* setup.py
|
||||||
|
"""
|
||||||
|
import os
|
||||||
|
import random
|
||||||
|
import time
|
||||||
|
import yaml
|
||||||
|
from shlex import split
|
||||||
|
from pykeybase import KeybaseChat, KeybaseBot, KeybaseTeam
|
||||||
|
|
||||||
|
# Check env for conf
|
||||||
|
conf_file = os.getenv('SOBEL_CONF')
|
||||||
|
if not conf_file:
|
||||||
|
print('ERROR: ENV var SOBEL_CONF not found')
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
# Read in conf yaml file
|
||||||
|
with open(conf_file) as cfile:
|
||||||
|
conf = yaml.load(cfile)
|
||||||
|
|
||||||
|
# Team channels to monitor
|
||||||
|
channels = conf['channels']
|
||||||
|
|
||||||
|
kb = KeybaseChat()
|
||||||
|
bot = KeybaseBot(kb, channels, help_command=r'^\.help$', help_trigger='.help')
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command(r'^\.member\sadd\s\w+', help_trigger='.member add <user>')
|
||||||
|
def add_member(message_data):
|
||||||
|
"""Add a member to the current team"""
|
||||||
|
try:
|
||||||
|
kbt = KeybaseTeam()
|
||||||
|
req = kbt.add_members(
|
||||||
|
message_data['team'],
|
||||||
|
[{
|
||||||
|
'username': message_data['body'].split()[-1].strip(),
|
||||||
|
'role': 'reader'
|
||||||
|
}]
|
||||||
|
)
|
||||||
|
except Exception as err:
|
||||||
|
resp = "error adding user"
|
||||||
|
if req.get('error'):
|
||||||
|
if 'admin' in req['error']['message']:
|
||||||
|
resp = 'Error: I do not have the proper rights'
|
||||||
|
elif 'already' in req['error']['message']:
|
||||||
|
resp = 'Error: user is already a member'
|
||||||
|
else:
|
||||||
|
resp = 'member added'
|
||||||
|
|
||||||
|
return bot.respond(resp, message_data, at_mention=True)
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command(r'^\.member\sremove\s\w+', help_trigger='.member remove <user>')
|
||||||
|
def remove_member(message_data):
|
||||||
|
"""Remove a member from the current team"""
|
||||||
|
try:
|
||||||
|
kbt = KeybaseTeam()
|
||||||
|
req = kbt.remove_member(
|
||||||
|
message_data['team'],
|
||||||
|
message_data['body'].split()[-1].strip()
|
||||||
|
)
|
||||||
|
except Exception as err:
|
||||||
|
resp['error'] = "error removing user"
|
||||||
|
if req.get('error'):
|
||||||
|
if 'admin' in req['error']['message']:
|
||||||
|
resp = 'Error: I do not have the proper rights'
|
||||||
|
elif 'is not' in req['error']['message']:
|
||||||
|
resp = 'Error: user is not a member'
|
||||||
|
else:
|
||||||
|
resp = 'member removed'
|
||||||
|
|
||||||
|
return bot.respond(resp, message_data, at_mention=True)
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command(r'\b(fuck|shit|ass|pussy|bitch)\b', show_help=False)
|
||||||
|
def swear_cmd(message_data):
|
||||||
|
"""Respond to swear words"""
|
||||||
|
response_text = "Please dont use that kind of language in here."
|
||||||
|
return bot.respond(response_text, message_data, at_mention=True)
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command(r'^\.roll', help_trigger='.roll <dice> <sides>')
|
||||||
|
def roll_cmd(message_data):
|
||||||
|
'''Roll <dice> amount of <side>-sided dice. If <dice> and <sides> are not
|
||||||
|
provided, default is to roll 2 6-sided dice. If <dice> and <sides> are
|
||||||
|
provided, <dice> must be between 1 and 10, and <sides> must be between 2
|
||||||
|
and 100.'''
|
||||||
|
try:
|
||||||
|
num_of_dice = int(split(message_data['body'])[1])
|
||||||
|
num_of_sides = int(split(message_data['body'])[2]) + 1
|
||||||
|
except ValueError:
|
||||||
|
num_of_dice = 0
|
||||||
|
num_of_sides = 0
|
||||||
|
except IndexError:
|
||||||
|
num_of_dice = 2
|
||||||
|
num_of_sides = 7
|
||||||
|
if (num_of_dice not in range(1, 11) or
|
||||||
|
num_of_sides not in range(2, 102)):
|
||||||
|
response_text = '`<dice>` must be a number from 1 to 10, and ' \
|
||||||
|
'`<sides>` must be a number from 2 to 100'
|
||||||
|
return bot.respond(response_text, message_data, at_mention=True)
|
||||||
|
dice = []
|
||||||
|
for _ in range(num_of_dice):
|
||||||
|
dice.append(random.choice(range(1, num_of_sides)))
|
||||||
|
response_text = 'You rolled a '
|
||||||
|
if len(dice) > 1:
|
||||||
|
for n in dice[0:-1]:
|
||||||
|
response_text += '`{}`, '.format(n)
|
||||||
|
response_text += 'and `{}`, for a total of `{}`.'.format(dice[-1],
|
||||||
|
sum(dice))
|
||||||
|
else:
|
||||||
|
response_text += '`{}`.'.format(dice[0])
|
||||||
|
return bot.respond(response_text, message_data, at_mention=True)
|
||||||
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
bot.run(respond=True)
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
exit(0)
|
@ -1 +1,3 @@
|
|||||||
pykeybasebot
|
pykeybasebot
|
||||||
|
pykeybase
|
||||||
|
pyyaml
|
Loading…
Reference in New Issue