chore: remove dotenv

convert to module, just pass in the auth and repo info to module
This commit is contained in:
2018-12-06 14:27:38 -07:00
parent e041412051
commit da786a6e02
5 changed files with 34 additions and 41 deletions

View File

@@ -2,4 +2,4 @@
require = require('esm')(module);
const mod = require('./src/index.mjs').default;
mod();
module.exports = mod;

View File

@@ -1,3 +1,3 @@
import mod from './src/index.mjs';
mod();
export default mod;

View File

@@ -50,7 +50,6 @@
"cjs": true
},
"dependencies": {
"dotenv": "^6.2.0",
"esm": "^3.0.17",
"node-fetch": "^2.3.0"
},

View File

@@ -5,15 +5,8 @@
// <bitbar.desc>Get list of pull requests from Github for multiple repositories</bitbar.desc>
// <bitbar.dependencies>node.js request co bluebird</bitbar.dependencies>
import dotenv from 'dotenv';
import nodeFetch, { FetchError } from 'node-fetch';
dotenv.config();
const username = process.env.GITHUB_USER;
const token = process.env.GITHUB_TOKEN;
const repos = process.env.GITHUB_REPOS.split(',');
const GITHUB_API = 'https://api.github.com';
// make fetch sane
@@ -23,7 +16,8 @@ const fetch = async (...args) => {
throw new FetchError(`Unsuccessful Request (${args[0]}) [${res.status}]`);
};
const getPull = async (repo, id) =>
const api = ({ username, token }) => {
const getPull = async (repo, id) =>
fetch(`${GITHUB_API}/repos/${repo}/pulls/${id}`, {
method: 'GET',
headers: {
@@ -31,7 +25,8 @@ const getPull = async (repo, id) =>
},
}).then(res => res.json());
const getPulls = async repo => {
return {
getPulls: async repo => {
const issues = await fetch(
`${GITHUB_API}/repos/${repo}/issues?state=open&sort=updated&creator=w33ble`,
{
@@ -47,15 +42,17 @@ const getPulls = async repo => {
// return actual pull info
return Promise.all(pulls.map(pull => getPull(repo, pull.number)));
};
},
const getStatus = async (repo, sha) =>
getStatus: async (repo, sha) =>
fetch(`${GITHUB_API}/repos/${repo}/commits/${sha}/status`, {
method: 'GET',
headers: {
Authorization: `Basic ${Buffer.from(`${username}:${token}`).toString('base64')}`,
},
}).then(res => res.json());
}).then(res => res.json()),
};
};
const getStatusColor = status => {
if (status === 'failure') return ' color=#aa0000';
@@ -64,7 +61,9 @@ const getStatusColor = status => {
return '';
};
export default async () => {
export default async ({ username, token, repos = [] }) => {
const { getPulls, getStatus } = api({ username, token });
let failed = false;
const tasks = await (() => {
try {

View File

@@ -551,11 +551,6 @@ doctrine@^2.1.0:
dependencies:
esutils "^2.0.2"
dotenv@^6.2.0:
version "6.2.0"
resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-6.2.0.tgz#941c0410535d942c8becf28d3f357dbd9d476064"
integrity sha512-HygQCKUBSFl8wKQZBSemMywRWcEDNidvNbjGVyZu3nbZ8qq9ubiPoGLMdRDpfSrpkkm9BXYFkpKxxFX38o/76w==
elegant-spinner@^1.0.1:
version "1.0.1"
resolved "https://registry.yarnpkg.com/elegant-spinner/-/elegant-spinner-1.0.1.tgz#db043521c95d7e303fd8f345bedc3349cfb0729e"