2018-01-22 13:48:57 +00:00
// Description:
// Script that listens to new labels on GitHub issues
// and assigns the issues to the bounty-awaiting-approval column on the "Status SOB Swarm" project
//
// Dependencies:
// github: "^13.1.0"
// probot-config "^0.1.0"
// probot-slack-status: "^0.2.2"
//
// Author:
// PombeirP
2018-01-23 14:27:25 +00:00
const getConfig = require ( 'probot-config' )
const defaultConfig = require ( '../lib/config' )
const Slack = require ( 'probot-slack-status' )
2018-01-22 13:48:57 +00:00
2018-01-23 14:27:25 +00:00
let slackClient = null
2018-01-22 13:48:57 +00:00
module . exports = function ( robot ) {
// robot.on('slack.connected', ({ slack }) => {
Slack ( robot , ( slack ) => {
2018-01-23 14:27:25 +00:00
robot . log . trace ( "Connected, assigned slackClient" )
slackClient = slack
} )
2018-01-22 13:48:57 +00:00
robot . on ( 'issues.labeled' , async context => {
// Make sure we don't listen to our own messages
2018-01-23 14:27:25 +00:00
if ( context . isBot ) { return }
2018-01-22 13:48:57 +00:00
// A new issue was labeled
2018-01-23 14:27:25 +00:00
await assignIssueToBountyAwaitingForApproval ( context , robot )
} )
}
2018-01-22 13:48:57 +00:00
async function assignIssueToBountyAwaitingForApproval ( context , robot ) {
2018-01-23 14:27:25 +00:00
const github = context . github
const payload = context . payload
//const config = await getConfig(context, 'github-bot.yml', defaultConfig(robot, '.github/github-bot.yml'))
const config = defaultConfig ( robot , '.github/github-bot.yml' )
const ownerName = payload . repository . owner . login
const repoName = payload . repository . name
const issueNumber = payload . issue . number
2018-01-22 13:48:57 +00:00
2018-01-23 14:30:24 +00:00
if ( ! config [ 'bounty-project-board' ] ) {
return ;
}
2018-01-23 14:27:25 +00:00
robot . log ( ` assignIssueToBountyAwaitingForApproval - Handling Issue # ${ issueNumber } on repo ${ ownerName } / ${ repoName } ` )
2018-01-22 13:48:57 +00:00
// Fetch org projects
// TODO: The org project and project column info should be cached
// in order to improve performance and reduce roundtrips
try {
2018-01-23 14:27:25 +00:00
const orgName = 'status-im'
2018-01-22 13:48:57 +00:00
ghprojects = await github . projects . getOrgProjects ( {
org : orgName ,
state : "open"
2018-01-23 14:27:25 +00:00
} )
2018-01-22 13:48:57 +00:00
// Find "Status SOB Swarm" project
2018-01-23 14:27:25 +00:00
const projectBoardName = config [ 'bounty-project-board' ] . name
const project = ghprojects . data . find ( function ( p ) { return p . name === projectBoardName } )
2018-01-22 13:48:57 +00:00
if ( ! project ) {
2018-01-23 14:27:25 +00:00
robot . log . error ( ` Couldn't find project ${ projectBoardName } in ${ orgName } org ` )
return
2018-01-22 13:48:57 +00:00
}
2018-01-23 14:27:25 +00:00
robot . log . debug ( ` Fetched ${ project . name } project ( ${ project . id } ) ` )
2018-01-22 13:48:57 +00:00
// Fetch bounty-awaiting-approval column ID
try {
2018-01-23 14:27:25 +00:00
ghcolumns = await github . projects . getProjectColumns ( { project _id : project . id } )
2018-01-22 13:48:57 +00:00
2018-01-23 14:27:25 +00:00
const approvalColumnName = config [ 'bounty-project-board' ] [ 'awaiting-approval-column-name' ]
const column = ghcolumns . data . find ( c => c . name === approvalColumnName )
2018-01-22 13:48:57 +00:00
if ( ! column ) {
2018-01-23 14:27:25 +00:00
robot . log . error ( ` Couldn't find ${ approvalColumnName } column in project ${ project . name } ` )
return
2018-01-22 13:48:57 +00:00
}
2018-01-23 14:27:25 +00:00
robot . log . debug ( ` Fetched ${ column . name } column ( ${ column . id } ) ` )
2018-01-22 13:48:57 +00:00
// Create project card for the issue in the bounty-awaiting-approval column
try {
ghcard = await github . projects . createProjectCard ( {
column _id : column . id ,
content _type : 'Issue' ,
content _id : payload . issue . id
2018-01-23 14:27:25 +00:00
} )
2018-01-22 13:48:57 +00:00
2018-01-23 14:27:25 +00:00
robot . log . debug ( ` Created card: ${ ghcard . data . url } ` , ghcard . data . id )
2018-01-22 13:48:57 +00:00
// Send message to Slack
2018-01-23 14:27:25 +00:00
const slackHelper = require ( '../lib/slack' )
slackHelper . sendMessage ( robot , slackClient , config . slack . notification . room , ` Assigned issue to ${ approvalColumnName } in ${ projectBoardName } project \n ${ payload . issue . html _url } ` )
2018-01-22 13:48:57 +00:00
} catch ( err ) {
2018-01-23 14:27:25 +00:00
robot . log . error ( ` Couldn't create project card for the issue: ${ err } ` , column . id , payload . issue . id )
2018-01-22 13:48:57 +00:00
}
} catch ( err ) {
2018-01-23 14:27:25 +00:00
robot . log . error ( ` Couldn't fetch the github columns for project: ${ err } ` , ownerName , repoName , project . id )
2018-01-22 13:48:57 +00:00
}
} catch ( err ) {
2018-01-23 14:27:25 +00:00
robot . log . error ( ` Couldn't fetch the github projects for repo: ${ err } ` , ownerName , repoName )
2018-01-22 13:48:57 +00:00
}
2018-01-23 14:27:25 +00:00
}