diff --git a/.idea/.gitignore b/.idea/.gitignore
new file mode 100644
index 0000000..26d3352
--- /dev/null
+++ b/.idea/.gitignore
@@ -0,0 +1,3 @@
+# Default ignored files
+/shelf/
+/workspace.xml
diff --git a/.idea/inspectionProfiles/profiles_settings.xml b/.idea/inspectionProfiles/profiles_settings.xml
new file mode 100644
index 0000000..105ce2d
--- /dev/null
+++ b/.idea/inspectionProfiles/profiles_settings.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
new file mode 100644
index 0000000..4a7bea9
--- /dev/null
+++ b/.idea/misc.xml
@@ -0,0 +1,4 @@
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 0000000..e9f32b6
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/rfc-bot.iml b/.idea/rfc-bot.iml
new file mode 100644
index 0000000..74d515a
--- /dev/null
+++ b/.idea/rfc-bot.iml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..94a25f7
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/bot.py b/bot.py
index 97d43d9..f6b3fcb 100644
--- a/bot.py
+++ b/bot.py
@@ -1,15 +1,21 @@
from github import Github
-import datetime
-import sys
+from datetime import datetime
g = Github(open(".access_token").read().strip())
+
def post_update(text):
repo = g.get_repo("crystalrfc-bot/status")
thread = repo.get_issue(1)
- thread.create_comment(text + "\nBeep Boop! (I'm a bot, and this action was performed automagically.)\nScan timestamp: `" + datetime.datetime.now().isoformat() + "`")
+ thread.create_comment(
+ text
+ + "\nBeep Boop! (I'm a bot, and this action was performed automagically.)\nScan timestamp: `"
+ + datetime.now().isoformat()
+ + "`"
+ )
+
-targets = ['crystal-linux/.github', 'crystal-linux-packages/.github']
+targets = ["crystal-linux/.github", "crystal-linux-packages/.github"]
status_text = ""
@@ -17,34 +23,46 @@ for tgt in targets:
repo = g.get_repo(tgt)
status_text += f"# Examining {repo.full_name}\n"
- core_team = g.get_organization('crystal-linux').get_team_by_slug('core-team')
+ core_team = g.get_organization("crystal-linux").get_team_by_slug("core-team")
+ trusted_contrib = g.get_organization("crystal-linux").get_team_by_slug(
+ "trusted-contribututors"
+ )
core_team_members = core_team.get_members()
- core_team_logins = []
+ trusted_contrib_members = trusted_contrib.get_members()
+
+ crystal_logins = []
for member in core_team_members:
- core_team_logins.append(member.login)
+ crystal_logins.append(member.login)
+
+ for member in trusted_contrib_members:
+ crystal_logins.append(member.login)
rfcs_passed = 0
for issue in repo.get_issues():
- if 'RFC' in issue.title:
+ if "RFC" in issue.title:
print(f"Working on: {issue.title}")
all_reactions = issue.get_reactions()
if all_reactions.totalCount != 0:
total_votes_for = 0
total_votes_against = 0
for reaction in all_reactions:
- if reaction.user.login in core_team_logins:
- #print(f"- {reaction.content}: by {reaction.user.login}")
+ if reaction.user.login in crystal_logins:
+ # print(f"- {reaction.content}: by {reaction.user.login}")
if reaction.content == "+1":
total_votes_for += 1
elif reaction.content == "-1":
total_votes_against += 1
print(f"Total votes for resolution: {str(total_votes_for)}")
print(f"Total votes against resolution: {str(total_votes_against)}")
- if (total_votes_for/len(core_team_logins)) > 0.5:
+ if (total_votes_for / len(crystal_logins)) > 0.5:
print("This RFC should be passed. Adding comment.")
if not issue.locked:
- issue.create_comment("This resolution has enough votes from Core Team mebers to be considered passed. Please close the issue once appropriate actions have been taken. - Beep Boop (I'm a bot, and this action was performed automagically)")
+ issue.create_comment(
+ "This resolution has enough votes to be considered passed. "
+ "Please close the issue once appropriate actions have been taken. "
+ "- Beep Boop (I'm a bot, and this action was performed automagically)"
+ )
issue.lock("resolved")
rfcs_passed += 1
status_text += f"* Suggested that {issue.title} be acted upon, as it has passed.\n"