1
0
Fork 0
mirror of https://gitlab.wikimedia.org/ladsgroup/Phabricator-maintenance-bot synced 2024-12-31 23:10:57 +01:00
Phabricator-maintenance-bot/project_grouper.py
2024-10-04 13:15:15 +00:00

333 lines
9.9 KiB
Python

"""
Adds tasks in configured projects to other configured projects
"""
from lib import Client
# To get it on a list run this on herald rule page
# const items = document.getElementsByClassName('herald-list-item')[0].getElementsByClassName('phui-handle')
# for (i in items) {console.log(items[i].text)};
rules = [
{
# H175 - see T136921
'add': 'Design',
'in': ['WMF-Design', 'WMDE-Design'],
},
{
# H232
'add': 'artificial-intelligence',
'in': ['editquality-modeling', 'draftquality-modeling', 'articlequality-modeling', 'revscoring'],
},
{
# H193 - see T146701
'add': 'accessibility',
'in': ['ios-app-feature-accessibility'],
},
{
# H174
'add': 'upstream',
'in': ['phabricator-upstream'],
},
{
# H24 - see T86536
'add': 'universallanguageselector',
'in': ['uls-compactlinks'],
},
{
# H15 - note that #producrement tasks are private -> rule can't be disabled
'add': 'SRE',
'in': [
'ops-eqiad',
'ops-codfw',
'ops-esams',
'ops-ulsfo',
# 'hardware-requests', archived project
'SRE-Access-Requests',
'vm-requests',
'ops-eqord',
'ops-eqdfw',
# 'procurement', always in S4
'ops-eqsin',
'DNS',
'LDAP-Access-Requests',
'Wikimedia-Mailing-lists',
],
'once': True
},
{
# H14 - see T85596
'add': 'Social-Tools',
'in': [
'BlogPage',
'Challenge',
'Comments',
'FanBoxes',
'ImageRating',
'LinkFilter',
'MiniInvite',
'NewSignupPage',
# 'NewUsersList', archived project
'PictureGame',
'PollNY',
'QuizGame',
# 'RandomFeaturedUser', archived project
'RandomGameUnit',
# 'RandomUsersWithAvatars', archived project
'SocialProfile',
'SiteMetrics',
'SportsTeams',
# 'TopLists', archived project
'video_non-wmf',
'VoteNY',
'WikiForum',
'WikiTextLoggedInOut',
],
},
{
# H10 - see T76954
'add': 'VisualEditor',
'in': [
'VisualEditor-ContentEditable',
'VisualEditor-ContentLanguage',
'VisualEditor-CopyPaste',
'VisualEditor-DataModel',
'VisualEditor-EditingTools',
'VisualEditor-Initialisation',
'VisualEditor-InterfaceLanguage',
'VisualEditor-MediaWiki',
'VisualEditor-MediaWiki-Links',
'VisualEditor-MediaWiki-Media',
'VisualEditor-MediaWiki-Mobile',
'VisualEditor-MediaWiki-References',
'VisualEditor-MediaWiki-Templates',
'VisualEditor-Performance',
'VisualEditor-Tables',
'TemplateData',
'VisualEditor-MediaWiki-Plugins',
'VisualEditor-LanguageTool',
'VisualEditor-Links',
'VisualEditor-Media',
'VisualEditor-MediaWiki-2017WikitextEditor',
'VisualEditor-VisualDiffs',
],
},
{
# H30
'add': 'wikidata',
'in': [
'Wikibase-Quality-Constraints',
'DataValues',
'DataValues-JavaScript',
'MediaWiki-extensions-WikibaseClient',
'MediaWiki-extensions-WikibaseView',
'Wikibase-DataModel',
'Wikibase-DataModel-JavaScript',
'Wikibase-DataModel-Serialization',
'Wikibase-Internal-Serialization',
'Wikibase-JavaScript-Api',
'Wikibase-Serialization-JavaScript',
'Wikidata-Query-Service',
'Tool-Wikidata-Periodic-Table',
'Wikidata.org',
'DataTypes',
'MediaWiki-extensions-WikibaseRepository',
'SDC General',
'ValueView',
'Wikidata-Gadgets',
'ArticlePlaceholder',
'Wikidata Lexicographical data',
'Automated list generation',
'Wikidata Query UI',
'Wikibase-Containers',
'Soweego',
'Wikidata Mobile',
'Wikidata-Campsite',
'Wikibase-registry',
'wikiba.se website',
'Wikibase-Lua',
'MediaWiki-extensions-PropertySuggester',
'Wikidata-Campsite (Wikidata-Campsite-Iteration-∞)',
'RL Module Terminators Trailblazing',
'Wikidata-Bridge',
'Shape Expressions',
'Wikidata Tainted References',
'Wikidata Design System',
'Wikidata - Reference Treasure Hunt',
'Item Quality Scoring Improvement',
'Wikibase - Automated Configuration Detection (WikibaseManifest)',
'Wikidata Query Builder',
'Wikidata - Visualisation of Reliability Metrics',
'Item Quality Evaluator',
'wdwb-tech',
'Cognate',
'Mismatch Finder',
'Wikidata analytics',
'Wikidata-Termbox',
'Special:NewLexeme revival',
'Wikidata Dev Team',
'Wikidata data quality and trust',
'Wikidata-UX',
'Wikidata Integration in Wikimedia projects',
'Wikidata Sitelinks',
'Wikidata Change Dispatching & Watchlists',
'Wikidata Integration in Wikimedia projects (Sprint Board)',
'wmde-wikidata-tech',
'MediaWiki-extensions-WikimediaBadges',
],
'once': True
},
{
'add': 'Wikidata Lexicographical data',
'in': [
'Special:NewLexeme revival',
],
'once': True
},
{
# H337
'add': 'Research',
'in': [
'address-knowledge-gaps',
'Research-foundational',
'Knowledge-Integrity',
],
'once': True
},
{
# H314
'add': 'Pywikibot',
'in': [
'Pywikibot-archivebot.py',
'Pywikibot-category.py',
'Pywikibot-compat',
'Pywikibot-copyright.py',
'Pywikibot-delinker.py',
'Pywikibot-cosmetic-changes.py',
'Pywikibot-Documentation',
'Pywikibot-General',
'Pywikibot-i18n',
'Pywikibot-interwiki.py',
'Pywikibot-login.py',
'Pywikibot-network',
'Pywikibot-Scripts',
'Pywikibot-pagegenerators.py',
'Pywikibot-redirect.py',
'Pywikibot-replace.py',
'Pywikibot-solve-disambiguation.py',
'Pywikibot-tests',
'Pywikibot-textlib.py',
'Pywikibot-weblinkchecker.py',
'Pywikibot-Wikidata',
'Pywikibot-xmlreader.py',
],
'once': True
},
{
# H285
'add': 'Product-Analytics',
'in': [
'Discovery-Analysis',
],
'once': True
},
{
# H216
'add': 'WMDE-FUN-Team',
'in': [
'WMDE-Fundraising-Tech',
],
'once': True
},
{
# H131
'add': 'Traffic',
'in': [
'HTTPS',
'DNS',
'Domains',
],
'once': True
},
{
# H131
'add': 'Traffic',
'in': [
'HTTPS',
'DNS',
'Domains',
],
'once': True
},
{
# H109
'add': 'Commons',
'in': [
'MediaWiki-File-management',
'MediaWiki-extensions-GWToolset',
],
'once': True
},
{
# Keep all Abstract Wikipedia work on the team board
'add': 'abstract_wikipedia',
'in': [
'abstract_wikipedia_ux',
'wikifunctions',
'wikilambda',
'function-evaluator',
'function-orchestrator',
'function-schemata',
'tool-ducttape',
],
},
{
# https://phabricator.wikimedia.org/T295397
'add': 'Data-Engineering',
'in': [
'Event-Platform',
'Analytics-Wikistats',
],
'once': True
},
{
'add': 'growthexperiments-mentorship',
'in': [
'growthexperiments-personalizedpraise',
],
},
]
client = Client.newFromCreds()
for rule in rules:
handled_tasks = []
wanted_project_phid = client.lookupPhid('#' + rule['add'].replace(' ', '_'))
subprojects = set(client.getSubprojects(wanted_project_phid) + [wanted_project_phid])
for project_name in rule['in']:
project_name = project_name.replace(' ', '_')
try:
project_phid = client.lookupPhid('#' + project_name)
except:
continue
for task_phid in client.getTasksWithProject(project_phid):
# if a task is in multiple 'in' projects, still only process it once
if task_phid in handled_tasks:
continue
task = client.taskDetails(task_phid)
if subprojects.intersection(set(task['projectPHIDs'])):
continue
if rule.get('once') == True:
is_already_added = False
transactions = client.getTransactions(task_phid)
for transaction in transactions:
operations = transaction.get(
'fields', {}).get('operations', [])
for operation in operations:
if operation.get('operation') == 'add' and operation.get('phid') == wanted_project_phid:
is_already_added = True
break
if is_already_added == True:
continue
handled_tasks.append(task_phid)
client.addTaskProject(task_phid, wanted_project_phid)