chore: remove dotenv
convert to module, just pass in the auth and repo info to module
This commit is contained in:
2
index.js
2
index.js
@@ -2,4 +2,4 @@
|
||||
require = require('esm')(module);
|
||||
const mod = require('./src/index.mjs').default;
|
||||
|
||||
mod();
|
||||
module.exports = mod;
|
||||
|
||||
@@ -50,7 +50,6 @@
|
||||
"cjs": true
|
||||
},
|
||||
"dependencies": {
|
||||
"dotenv": "^6.2.0",
|
||||
"esm": "^3.0.17",
|
||||
"node-fetch": "^2.3.0"
|
||||
},
|
||||
|
||||
@@ -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 {
|
||||
|
||||
@@ -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"
|
||||
|
||||
Reference in New Issue
Block a user