Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Change @reviewer functionality from status to tag #331

Merged
merged 3 commits into from
Jan 17, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 2 additions & 3 deletions api/utilities/coda_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,9 @@ class QuestionRow(TypedDict):
# Status of question in coda table
QuestionStatus = Literal[
"Bulletpoint sketch",
"Duplicate",
"Dormant",
"In progress",
"In review",
"Unlisted"
"Live on site",
"Marked for deletion",
"Not started",
Expand All @@ -85,5 +84,5 @@ class QuestionRow(TypedDict):
REVIEW_STATUSES: set[QuestionStatus] = {
"Bulletpoint sketch",
"In progress",
"In review",
"Unlisted",
}
23 changes: 14 additions & 9 deletions modules/question_setter.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
Review request, @reviewer, @feedback, @feedback-sketch
Request a review on an answer you wrote/edited
On Rob Miles's Discord server, an `@editor` can ask other `@editor`s and `@reviewer`s to give them feedback or review their changes to AI Safety Info questions. You just put one or more links to appropriate GDocs and mention one of: `@reviewer`, `@feedback`, or `@feedback-sketch`. Stampy will spot this and update their statuses in the coda table with answers appropriately.
`@reviewer <gdoc-link(s)>` - change status to `In review`
`@reviewer <gdoc-link(s)>` - tag the article as `In review`
`@feedback <gdoc-link(s)>` - change status to `In progress`
`@unlisted <gdoc-link(s)>` - change status to `Unlisted`
`@feedback-sketch <gdoc-link(s)>` - change status to `Bulletpoint sketch`
Expand Down Expand Up @@ -71,7 +71,7 @@

GDocLinks = list[str]
MsgRefId = str
ReviewStatus = Literal["In review", "Bulletpoint sketch", "In progress", "Unlisted"]
ReviewStatus = Literal["Bulletpoint sketch", "In progress", "Unlisted"]
MarkingStatus = Literal["Marked for deletion", "Duplicate"]
EditAction = Literal["add", "remove", "clear"]

Expand Down Expand Up @@ -183,9 +183,20 @@ def parse_review_request(self, message: ServiceMessage) -> Optional[Response]:
"""
text = message.clean_content

# try parsing gdoc links and questions that have these gdoc links
# if you fail, assume this is not a review request
if not (gdoc_links := parse_gdoc_links(text)):
return
self.msg_id2gdoc_links[message.id] = gdoc_links

# get new status for questions
if "@reviewer" in text:
status = "In review"
query = ("GDocLinks", gdoc_links)
return Response(
confidence=10,
callback=self.cb_edit_tag,
args=[query, "in-review", message, "add"],
)
elif "@feedback-sketch" in text:
status = "Bulletpoint sketch"
elif "@feedback" in text:
Expand All @@ -195,12 +206,6 @@ def parse_review_request(self, message: ServiceMessage) -> Optional[Response]:
else: # if neither of these three roles is mentioned, this is not a review request
return

# try parsing gdoc links and questions that have these gdoc links
# if you fail, assume this is not a review request
if not (gdoc_links := parse_gdoc_links(text)):
return
self.msg_id2gdoc_links[message.id] = gdoc_links

return Response(
confidence=10,
callback=self.cb_review_request,
Expand Down
Loading