Compare commits

...

7 Commits

Author SHA1 Message Date
Luke Tomlinson
489c8a69b9 More debugging 2021-06-29 11:50:32 -04:00
Luke Tomlinson
31eafc7219 Debug events 2021-06-29 11:44:24 -04:00
Luke Tomlinson
75a803e008 Filter comments based on content, not author 2021-06-24 16:50:23 -04:00
Luke Tomlinson
cce770077c Print comments 2021-06-24 15:28:15 -04:00
Luke Tomlinson
b95063d0a1 Print more user info 2021-06-24 15:23:23 -04:00
Luke Tomlinson
7370047184 Print actor 2021-06-24 14:09:38 -04:00
Luke Tomlinson
a7d1a14092 Testing 2021-06-24 14:00:41 -04:00
3 changed files with 101 additions and 23 deletions

116
dist/index.js vendored
View File

@@ -267,7 +267,7 @@ class IssuesProcessor {
} }
} }
static _updatedSince(timestamp, num_days) { static _updatedSince(timestamp, num_days) {
const daysInMillis = 1000 * 60 * 60 * 24 * num_days; const daysInMillis = 1000 * 60 * num_days; //temporarily number of minutes
const millisSinceLastUpdated = new Date().getTime() - new Date(timestamp).getTime(); const millisSinceLastUpdated = new Date().getTime() - new Date(timestamp).getTime();
return millisSinceLastUpdated <= daysInMillis; return millisSinceLastUpdated <= daysInMillis;
} }
@@ -555,6 +555,7 @@ class IssuesProcessor {
}); });
const events = yield this.client.paginate(options); const events = yield this.client.paginate(options);
const reversedEvents = events.reverse(); const reversedEvents = events.reverse();
issueLogger.info(`Reversed Events: ${JSON.stringify(reversedEvents)}`);
const staleLabeledEvent = reversedEvents.find(event => event.event === 'labeled' && event.label.name === label); const staleLabeledEvent = reversedEvents.find(event => event.event === 'labeled' && event.label.name === label);
if (!staleLabeledEvent) { if (!staleLabeledEvent) {
// Must be old rather than labeled // Must be old rather than labeled
@@ -623,7 +624,9 @@ class IssuesProcessor {
} }
// find any comments since the date // find any comments since the date
const comments = yield this.listIssueComments(issue.number, sinceDate); const comments = yield this.listIssueComments(issue.number, sinceDate);
const filteredComments = comments.filter(comment => comment.user.type === 'User' && comment.user.login !== actor); core.debug(`The actor is: ${actor}`);
core.debug(`The comments are ${JSON.stringify(comments)}`);
const filteredComments = comments.filter(comment => comment.user.type === 'User' && comment.body !== IssuesProcessor._getStaleMessageUsedOptionName(issue));
issueLogger.info(`Comments not made by actor or another bot: ${logger_service_1.LoggerService.cyan(filteredComments.length)}`); issueLogger.info(`Comments not made by actor or another bot: ${logger_service_1.LoggerService.cyan(filteredComments.length)}`);
// if there are any user comments returned // if there are any user comments returned
return filteredComments.length > 0; return filteredComments.length > 0;
@@ -5792,14 +5795,17 @@ ansiEscapes.iTerm = {
/***/ }), /***/ }),
/***/ 2068: /***/ 2068:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __nccwpck_require__) => {
"use strict"; "use strict";
/* module decorator */ module = __nccwpck_require__.nmd(module); __nccwpck_require__.r(__webpack_exports__);
/* harmony export */ __nccwpck_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => __WEBPACK_DEFAULT_EXPORT__
/* harmony export */ });
const ANSI_BACKGROUND_OFFSET = 10; const ANSI_BACKGROUND_OFFSET = 10;
const wrapAnsi16 = (offset = 0) => code => `\u001B[${code + offset}m`;
const wrapAnsi256 = (offset = 0) => code => `\u001B[${38 + offset};5;${code}m`; const wrapAnsi256 = (offset = 0) => code => `\u001B[${38 + offset};5;${code}m`;
const wrapAnsi16m = (offset = 0) => (red, green, blue) => `\u001B[${38 + offset};2;${red};${green};${blue}m`; const wrapAnsi16m = (offset = 0) => (red, green, blue) => `\u001B[${38 + offset};2;${red};${green};${blue}m`;
@@ -5893,8 +5899,10 @@ function assembleStyles() {
styles.color.close = '\u001B[39m'; styles.color.close = '\u001B[39m';
styles.bgColor.close = '\u001B[49m'; styles.bgColor.close = '\u001B[49m';
styles.color.ansi = wrapAnsi16();
styles.color.ansi256 = wrapAnsi256(); styles.color.ansi256 = wrapAnsi256();
styles.color.ansi16m = wrapAnsi16m(); styles.color.ansi16m = wrapAnsi16m();
styles.bgColor.ansi = wrapAnsi16(ANSI_BACKGROUND_OFFSET);
styles.bgColor.ansi256 = wrapAnsi256(ANSI_BACKGROUND_OFFSET); styles.bgColor.ansi256 = wrapAnsi256(ANSI_BACKGROUND_OFFSET);
styles.bgColor.ansi16m = wrapAnsi16m(ANSI_BACKGROUND_OFFSET); styles.bgColor.ansi16m = wrapAnsi16m(ANSI_BACKGROUND_OFFSET);
@@ -5949,17 +5957,67 @@ function assembleStyles() {
hexToAnsi256: { hexToAnsi256: {
value: hex => styles.rgbToAnsi256(...styles.hexToRgb(hex)), value: hex => styles.rgbToAnsi256(...styles.hexToRgb(hex)),
enumerable: false enumerable: false
},
ansi256ToAnsi: {
value: code => {
if (code < 8) {
return 30 + code;
}
if (code < 16) {
return 90 + (code - 8);
}
let red;
let green;
let blue;
if (code >= 232) {
red = (((code - 232) * 10) + 8) / 255;
green = red;
blue = red;
} else {
code -= 16;
const remainder = code % 36;
red = Math.floor(code / 36) / 5;
green = Math.floor(remainder / 6) / 5;
blue = (remainder % 6) / 5;
}
const value = Math.max(red, green, blue) * 2;
if (value === 0) {
return 30;
}
let result = 30 + ((Math.round(blue) << 2) | (Math.round(green) << 1) | Math.round(red));
if (value === 2) {
result += 60;
}
return result;
},
enumerable: false
},
rgbToAnsi: {
value: (red, green, blue) => styles.ansi256ToAnsi(styles.rgbToAnsi256(red, green, blue)),
enumerable: false
},
hexToAnsi: {
value: hex => styles.ansi256ToAnsi(styles.hexToAnsi256(hex)),
enumerable: false
} }
}); });
return styles; return styles;
} }
// Make the export immutable const ansiStyles = assembleStyles();
Object.defineProperty(module, 'exports', {
enumerable: true, /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ansiStyles);
get: assembleStyles
});
/***/ }), /***/ }),
@@ -8950,8 +9008,8 @@ module.exports = require("zlib");;
/******/ } /******/ }
/******/ // Create a new module (and put it into the cache) /******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = { /******/ var module = __webpack_module_cache__[moduleId] = {
/******/ id: moduleId, /******/ // no module.id needed
/******/ loaded: false, /******/ // no module.loaded needed
/******/ exports: {} /******/ exports: {}
/******/ }; /******/ };
/******/ /******/
@@ -8964,20 +9022,36 @@ module.exports = require("zlib");;
/******/ if(threw) delete __webpack_module_cache__[moduleId]; /******/ if(threw) delete __webpack_module_cache__[moduleId];
/******/ } /******/ }
/******/ /******/
/******/ // Flag the module as loaded
/******/ module.loaded = true;
/******/
/******/ // Return the exports of the module /******/ // Return the exports of the module
/******/ return module.exports; /******/ return module.exports;
/******/ } /******/ }
/******/ /******/
/************************************************************************/ /************************************************************************/
/******/ /* webpack/runtime/node module decorator */ /******/ /* webpack/runtime/define property getters */
/******/ (() => { /******/ (() => {
/******/ __nccwpck_require__.nmd = (module) => { /******/ // define getter functions for harmony exports
/******/ module.paths = []; /******/ __nccwpck_require__.d = (exports, definition) => {
/******/ if (!module.children) module.children = []; /******/ for(var key in definition) {
/******/ return module; /******/ if(__nccwpck_require__.o(definition, key) && !__nccwpck_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __nccwpck_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __nccwpck_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ }; /******/ };
/******/ })(); /******/ })();
/******/ /******/

View File

@@ -29,7 +29,7 @@ import {LoggerService} from '../services/logger.service';
*/ */
export class IssuesProcessor { export class IssuesProcessor {
private static _updatedSince(timestamp: string, num_days: number): boolean { private static _updatedSince(timestamp: string, num_days: number): boolean {
const daysInMillis = 1000 * 60 * 60 * 24 * num_days; const daysInMillis = 1000 * 60 * num_days; //temporarily number of minutes
const millisSinceLastUpdated = const millisSinceLastUpdated =
new Date().getTime() - new Date(timestamp).getTime(); new Date().getTime() - new Date(timestamp).getTime();
@@ -551,6 +551,7 @@ export class IssuesProcessor {
const events: IIssueEvent[] = await this.client.paginate(options); const events: IIssueEvent[] = await this.client.paginate(options);
const reversedEvents = events.reverse(); const reversedEvents = events.reverse();
issueLogger.info(`Reversed Events: ${JSON.stringify(reversedEvents)}`)
const staleLabeledEvent = reversedEvents.find( const staleLabeledEvent = reversedEvents.find(
event => event.event === 'labeled' && event.label.name === label event => event.event === 'labeled' && event.label.name === label
@@ -687,8 +688,10 @@ export class IssuesProcessor {
// find any comments since the date // find any comments since the date
const comments = await this.listIssueComments(issue.number, sinceDate); const comments = await this.listIssueComments(issue.number, sinceDate);
core.debug(`The actor is: ${actor}`)
core.debug(`The comments are ${JSON.stringify(comments)}`)
const filteredComments = comments.filter( const filteredComments = comments.filter(
comment => comment.user.type === 'User' && comment.user.login !== actor comment => comment.user.type === 'User' && comment.body !== IssuesProcessor._getStaleMessageUsedOptionName(issue)
); );
issueLogger.info( issueLogger.info(

View File

@@ -2,4 +2,5 @@ import {IUser} from './user';
export interface IComment { export interface IComment {
user: IUser; user: IUser;
body: string;
} }