2018-01-18 14:34:32 +00:00
|
|
|
// Description:
|
|
|
|
// Script that keeps GitHub-related context to be shared among scripts
|
|
|
|
//
|
|
|
|
// Dependencies:
|
|
|
|
// github: "^13.1.0"
|
|
|
|
//
|
|
|
|
// Author:
|
|
|
|
// PombeirP
|
|
|
|
|
|
|
|
const GitHubApi = require('github');
|
|
|
|
|
|
|
|
let cachedRobotNameRegex;
|
|
|
|
let initialized = false;
|
|
|
|
const githubAPI = new GitHubApi({
|
|
|
|
timeout: 15000,
|
|
|
|
requestMedia: 'application/vnd.github.v3+json'
|
|
|
|
});
|
2018-01-18 17:54:10 +00:00
|
|
|
let githubConfig = null;
|
2018-01-18 14:34:32 +00:00
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
|
2018-01-18 17:54:54 +00:00
|
|
|
api() { return githubAPI; },
|
2018-01-18 14:34:32 +00:00
|
|
|
|
2018-01-18 17:54:10 +00:00
|
|
|
config() { return githubConfig; },
|
|
|
|
|
2018-01-18 14:34:32 +00:00
|
|
|
initialize(robot, integrationID) {
|
|
|
|
if (initialized) { return; }
|
|
|
|
|
2018-01-18 17:54:10 +00:00
|
|
|
githubConfig = loadConfig(robot, './github.yaml')
|
|
|
|
|
2018-01-18 14:34:32 +00:00
|
|
|
const token = robot.brain.get('github-token');
|
|
|
|
if (token) {
|
|
|
|
initialized = true;
|
|
|
|
process.env.HUBOT_GITHUB_TOKEN = token;
|
|
|
|
robot.logger.debug("Reused cached GitHub token");
|
|
|
|
githubAPI.authenticate({ type: 'token', token });
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const jwtLib = require('jwt-simple');
|
|
|
|
|
|
|
|
// Private key contents
|
2018-01-19 16:33:12 +00:00
|
|
|
let privateKey = process.env.GITHUB_PEM;
|
2018-01-18 14:34:32 +00:00
|
|
|
|
|
|
|
const now = Math.round(Date.now() / 1000);
|
|
|
|
// Generate the JWT
|
|
|
|
const payload = {
|
|
|
|
// issued at time
|
|
|
|
iat: now,
|
|
|
|
// JWT expiration time (10 minute maximum)
|
|
|
|
exp: now + (1 * 60),
|
|
|
|
// GitHub App's identifier
|
|
|
|
iss: integrationID
|
|
|
|
};
|
|
|
|
|
|
|
|
jwt = jwtLib.encode(payload, privateKey, 'RS256');
|
|
|
|
githubAPI.authenticate({
|
|
|
|
type: 'integration',
|
|
|
|
token: jwt
|
|
|
|
});
|
|
|
|
robot.logger.debug("Configured integration authentication with JWT", jwt);
|
|
|
|
|
|
|
|
initialized = true;
|
|
|
|
},
|
|
|
|
|
|
|
|
equalsRobotName(robot, str) {
|
|
|
|
return getRegexForRobotName(robot).test(str);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
function getRegexForRobotName(robot) {
|
|
|
|
// This comes straight out of Hubot's Robot.coffee
|
|
|
|
// - they didn't get a nice way of extracting that method though
|
|
|
|
if (!cachedRobotNameRegex) {
|
|
|
|
let namePattern;
|
|
|
|
const name = robot.name.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
|
|
|
|
|
|
|
|
if (robot.alias) {
|
|
|
|
const alias = robot.alias.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
|
|
|
|
namePattern = `^\\s*[@]?(?:${alias}|${name})`;
|
|
|
|
} else {
|
|
|
|
namePattern = `^\\s*[@]?${name}`;
|
|
|
|
}
|
|
|
|
cachedRobotNameRegex = new RegExp(namePattern, 'i');
|
|
|
|
}
|
|
|
|
return cachedRobotNameRegex;
|
|
|
|
};
|
2018-01-18 17:54:10 +00:00
|
|
|
|
|
|
|
function loadConfig(robot, fileName) {
|
|
|
|
// Get document, or throw exception on error
|
|
|
|
try {
|
|
|
|
const yaml = require('js-yaml');
|
|
|
|
const fs = require('fs');
|
|
|
|
|
|
|
|
return yaml.safeLoad(fs.readFileSync(fileName, 'utf8'));
|
|
|
|
} catch (e) {
|
|
|
|
robot.logger.error(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|