@twexchangesolutions/hubot-jira-deployment
Advanced tools
Comparing version 0.14.0 to 0.15.0
@@ -94,3 +94,5 @@ 'use strict'; | ||
field: 'Development Team(s)' | ||
}, { | ||
field: 'Issue State' | ||
}]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZXBsb3ltZW50LXRhc2stdHJhbnNpdGlvbi5qcyJdLCJuYW1lcyI6WyJvcHRpb25zIiwicmVxdWlyZWRTdGF0dXNIaXN0b3J5Iiwib3BlcmF0aW9uVHlwZSIsInJlcXVpcmVkU3RhdGVzIiwiYXJlV2VJblRoZVJpZ2h0U3RhdGUiLCJkZXBsb3ltZW50VGFzayIsInN0YXR1cyIsImxhc3QiLCJub1RyYW5zaXRpb25TdGF0ZXMiLCJpbmRleE9mIiwiRXJyb3IiLCJrZXkiLCJoYXNBbnl0aGluZ0hhcHBlbmVkU2luY2VBcHByb3ZhbCIsImhhc0lzc3VlQ2hhbmdlZCIsImhpc3RvcnlJZ25vcmVMaXN0IiwidHJhbnNpdGlvbiIsInJvYm90IiwidHJhbnNpdGlvblRvQXR0ZW1wdCIsInJlZ2V4R3JvdXBzIiwiZGVwbG95bWVudFRhc2tOdW1iZXIiLCJyZXMiLCJzZW5kIiwicGVyZm9ybURlcGxveW1lbnRUYXNrVHJhbnNpdGlvbiIsImZpZWxkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O3dFQVdPLGlCQUErQ0EsT0FBL0M7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0NDLGlDQURELEdBQ3lCLHNDQUFjRCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FEOUQ7QUFFQ0MsZ0NBRkQsR0FFeUJKLFFBQVFLLGNBQVIsQ0FBdUJDLE1BQXZCLEtBQWtDLGlCQUFFQyxJQUFGLENBQU9OLHFCQUFQLENBRjNEOztBQUFBLGtCQUlELHNDQUFjRCxRQUFRRSxhQUF0QixFQUFxQ00sa0JBQXJDLENBQ0NDLE9BREQsQ0FDU1QsUUFBUUssY0FBUixDQUF1QkMsTUFEaEMsSUFDMEMsQ0FBQyxDQUwxQztBQUFBO0FBQUE7QUFBQTs7QUFBQSxrQkFNRyxJQUFJSSxLQUFKLENBQVUsMkJBQXlCVixRQUFRSyxjQUFSLENBQXVCTSxHQUFoRCwyQkFDRyxpQkFBRUosSUFBRixDQUFPLHNDQUFjUCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FBNUMsQ0FESCxPQUFWLENBTkg7O0FBQUE7QUFVQ1MsNENBVkQsR0FVb0NaLFFBQVFLLGNBQVIsQ0FBdUJRLGVBQXZCLENBQ3ZDVCx1QkFBdUIsc0NBQWNKLFFBQVFFLGFBQXRCLEVBQXFDQyxjQUE1RCxHQUNJLENBQUNILFFBQVFLLGNBQVIsQ0FBdUJDLE1BQXhCLENBRm1DLEVBR3ZDUSxpQkFIdUMsQ0FWcEM7O0FBQUEsaUJBZ0JERixnQ0FoQkM7QUFBQTtBQUFBO0FBQUE7O0FBQUE7QUFBQSxtQkFpQkdaLFFBQVFLLGNBQVIsQ0FBdUJVLFVBQXZCLENBQWtDLFFBQWxDLEVBQTRDZixRQUFRZ0IsS0FBcEQsQ0FqQkg7O0FBQUE7QUFBQSxrQkFrQkcsSUFBSU4sS0FBSixDQUFVLDRFQUNkLDRGQURjLEdBRWQsT0FGSSxDQWxCSDs7QUFBQTtBQUFBLGdCQXVCQU4sb0JBdkJBO0FBQUE7QUFBQTtBQUFBOztBQUFBLGtCQXdCRyxJQUFJTSxLQUFKLENBQVUscUNBQW1DVixRQUFRSyxjQUFSLENBQXVCQyxNQUExRCxtQ0FDQSxzQ0FBY04sUUFBUUUsYUFBdEIsRUFBcUNlLG1CQURyQyx3QkFFWGpCLFFBQVFrQixXQUFSLENBQW9CQyxvQkFGVCw4QkFHWCxpQkFBRVosSUFBRixDQUFPLHNDQUFjUCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FBNUMsQ0FIVyxhQUFWLENBeEJIOztBQUFBOztBQStCTEgsb0JBQVFvQixHQUFSLENBQVlDLElBQVosQ0FBaUIsd0dBQ00sc0NBQWNyQixRQUFRRSxhQUF0QixFQUFxQ2UsbUJBRDNDLFdBRVpqQixRQUFRa0IsV0FBUixDQUFvQkMsb0JBRlIsT0FBakI7O0FBL0JLO0FBQUEsbUJBb0NDbkIsUUFBUUssY0FBUixDQUF1QlUsVUFBdkIsQ0FDSixzQ0FBY2YsUUFBUUUsYUFBdEIsRUFBcUNlLG1CQURqQyxFQUVKakIsUUFBUWdCLEtBRkosQ0FwQ0Q7O0FBQUE7QUFBQSw2Q0F3Q0UsRUF4Q0Y7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRzs7a0JBQWVNLCtCOzs7OztBQVh0Qjs7OztBQUNBOzs7Ozs7QUFFTyxJQUFNUixnREFBb0IsQ0FBQztBQUNoQ1MsU0FBTztBQUR5QixDQUFELEVBRTlCO0FBQ0RBLFNBQU87QUFETixDQUY4QixFQUk5QjtBQUNEQSxTQUFPO0FBRE4sQ0FKOEIsQ0FBMUIiLCJmaWxlIjoiZGVwbG95bWVudC10YXNrLXRyYW5zaXRpb24uanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IGNvbW1hbmRDb25maWcgZnJvbSAnLi9kZXBsb3ltZW50LXNjcmlwdC1jb21tYW5kLWluZm8nO1xuXG5leHBvcnQgY29uc3QgaGlzdG9yeUlnbm9yZUxpc3QgPSBbe1xuICBmaWVsZDogJ1NjaGVkdWxlZCBEZXBsb3ltZW50IFRpbWUnXG59LCB7XG4gIGZpZWxkOiAnUmVtb3RlSXNzdWVMaW5rJ1xufSwge1xuICBmaWVsZDogJ0RldmVsb3BtZW50IFRlYW0ocyknXG59XTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBlcmZvcm1EZXBsb3ltZW50VGFza1RyYW5zaXRpb24ob3B0aW9ucykge1xuICBjb25zdCByZXF1aXJlZFN0YXR1c0hpc3RvcnkgPSBjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0ucmVxdWlyZWRTdGF0ZXM7XG4gIGNvbnN0IGFyZVdlSW5UaGVSaWdodFN0YXRlID0gKG9wdGlvbnMuZGVwbG95bWVudFRhc2suc3RhdHVzID09PSBfLmxhc3QocmVxdWlyZWRTdGF0dXNIaXN0b3J5KSk7XG5cbiAgaWYgKGNvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS5ub1RyYW5zaXRpb25TdGF0ZXNcbiAgICAgIC5pbmRleE9mKG9wdGlvbnMuZGVwbG95bWVudFRhc2suc3RhdHVzKSA+IC0xKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBJIHdpbGwgbm90IHRyYW5zaXRpb24gJHtvcHRpb25zLmRlcGxveW1lbnRUYXNrLmtleX0gdW50aWwgaXQgZ2V0cyB0byBgICtcbiAgICAgICAgICAgICAgICAgICAgYCR7Xy5sYXN0KGNvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS5yZXF1aXJlZFN0YXRlcyl9LmApO1xuICB9XG5cbiAgY29uc3QgaGFzQW55dGhpbmdIYXBwZW5lZFNpbmNlQXBwcm92YWwgPSBvcHRpb25zLmRlcGxveW1lbnRUYXNrLmhhc0lzc3VlQ2hhbmdlZChcbiAgICBhcmVXZUluVGhlUmlnaHRTdGF0ZSA/IGNvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS5yZXF1aXJlZFN0YXRlc1xuICAgICAgOiBbb3B0aW9ucy5kZXBsb3ltZW50VGFzay5zdGF0dXNdLFxuICAgIGhpc3RvcnlJZ25vcmVMaXN0XG4gICk7XG5cbiAgaWYgKGhhc0FueXRoaW5nSGFwcGVuZWRTaW5jZUFwcHJvdmFsKSB7XG4gICAgYXdhaXQgb3B0aW9ucy5kZXBsb3ltZW50VGFzay50cmFuc2l0aW9uKCdSZW9wZW4nLCBvcHRpb25zLnJvYm90KTtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1NvbWV0aGluZyByZXF1aXJpbmcgcmUtYXBwcm92YWwgaGFzIGhhcHBlbmVkIHRvIHRoaXMgZGVwbG95bWVudCB0YXNrLiAgJyArXG4gICAgICAnUGxlYXNlIGVuc3VyZSBldmVyeXRoaW5nIGlzIGNvcnJlY3QgYmVmb3JlIGFwcHJvdmluZyBpdCBhZ2Fpbi4gIEkgcmVvcGVuZWQgdGhlIGRlcGxveW1lbnQgJyArXG4gICAgICAndGFzay4nKTtcbiAgfVxuXG4gIGlmICghYXJlV2VJblRoZVJpZ2h0U3RhdGUpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYFRoZSBkZXBsb3ltZW50IHRhc2sgaXMgaW4gdGhlIFxcJyR7b3B0aW9ucy5kZXBsb3ltZW50VGFzay5zdGF0dXN9XFwnIHN0YXRlLiBgICtcbiAgICAgIGAgRm9yIG1lIHRvICR7Y29tbWFuZENvbmZpZ1tvcHRpb25zLm9wZXJhdGlvblR5cGVdLnRyYW5zaXRpb25Ub0F0dGVtcHR9IGl0IHByb3Blcmx5LCBgICtcbiAgICAgIGAke29wdGlvbnMucmVnZXhHcm91cHMuZGVwbG95bWVudFRhc2tOdW1iZXJ9IG5lZWRzIHRvIGJlIGluIHRoZSBgICtcbiAgICAgIGAke18ubGFzdChjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0ucmVxdWlyZWRTdGF0ZXMpfSBzdGF0ZS5gXG4gICAgKTtcbiAgfVxuXG4gIG9wdGlvbnMucmVzLnNlbmQoJ05vdGhpbmcgaGFzIGNoYW5nZWQgc2luY2UgYXBwcm92YWxzLiAgVGhpcyBkZXBsb3ltZW50IHRhc2sgaXMgZ29vZCB0byBnby4gICcgK1xuICAgIGBJIGFtIG5vdyBnb2luZyB0byAke2NvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS50cmFuc2l0aW9uVG9BdHRlbXB0fSBgICtcbiAgICBgJHtvcHRpb25zLnJlZ2V4R3JvdXBzLmRlcGxveW1lbnRUYXNrTnVtYmVyfS5gXG4gICk7XG5cbiAgYXdhaXQgb3B0aW9ucy5kZXBsb3ltZW50VGFzay50cmFuc2l0aW9uKFxuICAgIGNvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS50cmFuc2l0aW9uVG9BdHRlbXB0LFxuICAgIG9wdGlvbnMucm9ib3RcbiAgKTtcbiAgcmV0dXJuIHt9O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZXBsb3ltZW50LXRhc2stdHJhbnNpdGlvbi5qcyJdLCJuYW1lcyI6WyJvcHRpb25zIiwicmVxdWlyZWRTdGF0dXNIaXN0b3J5Iiwib3BlcmF0aW9uVHlwZSIsInJlcXVpcmVkU3RhdGVzIiwiYXJlV2VJblRoZVJpZ2h0U3RhdGUiLCJkZXBsb3ltZW50VGFzayIsInN0YXR1cyIsImxhc3QiLCJub1RyYW5zaXRpb25TdGF0ZXMiLCJpbmRleE9mIiwiRXJyb3IiLCJrZXkiLCJoYXNBbnl0aGluZ0hhcHBlbmVkU2luY2VBcHByb3ZhbCIsImhhc0lzc3VlQ2hhbmdlZCIsImhpc3RvcnlJZ25vcmVMaXN0IiwidHJhbnNpdGlvbiIsInJvYm90IiwidHJhbnNpdGlvblRvQXR0ZW1wdCIsInJlZ2V4R3JvdXBzIiwiZGVwbG95bWVudFRhc2tOdW1iZXIiLCJyZXMiLCJzZW5kIiwicGVyZm9ybURlcGxveW1lbnRUYXNrVHJhbnNpdGlvbiIsImZpZWxkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O3dFQWFPLGlCQUErQ0EsT0FBL0M7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0NDLGlDQURELEdBQ3lCLHNDQUFjRCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FEOUQ7QUFFQ0MsZ0NBRkQsR0FFeUJKLFFBQVFLLGNBQVIsQ0FBdUJDLE1BQXZCLEtBQWtDLGlCQUFFQyxJQUFGLENBQU9OLHFCQUFQLENBRjNEOztBQUFBLGtCQUlELHNDQUFjRCxRQUFRRSxhQUF0QixFQUFxQ00sa0JBQXJDLENBQ0NDLE9BREQsQ0FDU1QsUUFBUUssY0FBUixDQUF1QkMsTUFEaEMsSUFDMEMsQ0FBQyxDQUwxQztBQUFBO0FBQUE7QUFBQTs7QUFBQSxrQkFNRyxJQUFJSSxLQUFKLENBQVUsMkJBQXlCVixRQUFRSyxjQUFSLENBQXVCTSxHQUFoRCwyQkFDRyxpQkFBRUosSUFBRixDQUFPLHNDQUFjUCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FBNUMsQ0FESCxPQUFWLENBTkg7O0FBQUE7QUFVQ1MsNENBVkQsR0FVb0NaLFFBQVFLLGNBQVIsQ0FBdUJRLGVBQXZCLENBQ3ZDVCx1QkFBdUIsc0NBQWNKLFFBQVFFLGFBQXRCLEVBQXFDQyxjQUE1RCxHQUNJLENBQUNILFFBQVFLLGNBQVIsQ0FBdUJDLE1BQXhCLENBRm1DLEVBR3ZDUSxpQkFIdUMsQ0FWcEM7O0FBQUEsaUJBZ0JERixnQ0FoQkM7QUFBQTtBQUFBO0FBQUE7O0FBQUE7QUFBQSxtQkFpQkdaLFFBQVFLLGNBQVIsQ0FBdUJVLFVBQXZCLENBQWtDLFFBQWxDLEVBQTRDZixRQUFRZ0IsS0FBcEQsQ0FqQkg7O0FBQUE7QUFBQSxrQkFrQkcsSUFBSU4sS0FBSixDQUFVLDRFQUNkLDRGQURjLEdBRWQsT0FGSSxDQWxCSDs7QUFBQTtBQUFBLGdCQXVCQU4sb0JBdkJBO0FBQUE7QUFBQTtBQUFBOztBQUFBLGtCQXdCRyxJQUFJTSxLQUFKLENBQVUscUNBQW1DVixRQUFRSyxjQUFSLENBQXVCQyxNQUExRCxtQ0FDQSxzQ0FBY04sUUFBUUUsYUFBdEIsRUFBcUNlLG1CQURyQyx3QkFFWGpCLFFBQVFrQixXQUFSLENBQW9CQyxvQkFGVCw4QkFHWCxpQkFBRVosSUFBRixDQUFPLHNDQUFjUCxRQUFRRSxhQUF0QixFQUFxQ0MsY0FBNUMsQ0FIVyxhQUFWLENBeEJIOztBQUFBOztBQStCTEgsb0JBQVFvQixHQUFSLENBQVlDLElBQVosQ0FBaUIsd0dBQ00sc0NBQWNyQixRQUFRRSxhQUF0QixFQUFxQ2UsbUJBRDNDLFdBRVpqQixRQUFRa0IsV0FBUixDQUFvQkMsb0JBRlIsT0FBakI7O0FBL0JLO0FBQUEsbUJBb0NDbkIsUUFBUUssY0FBUixDQUF1QlUsVUFBdkIsQ0FDSixzQ0FBY2YsUUFBUUUsYUFBdEIsRUFBcUNlLG1CQURqQyxFQUVKakIsUUFBUWdCLEtBRkosQ0FwQ0Q7O0FBQUE7QUFBQSw2Q0F3Q0UsRUF4Q0Y7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRzs7a0JBQWVNLCtCOzs7OztBQWJ0Qjs7OztBQUNBOzs7Ozs7QUFFTyxJQUFNUixnREFBb0IsQ0FBQztBQUNoQ1MsU0FBTztBQUR5QixDQUFELEVBRTlCO0FBQ0RBLFNBQU87QUFETixDQUY4QixFQUk5QjtBQUNEQSxTQUFPO0FBRE4sQ0FKOEIsRUFNOUI7QUFDREEsU0FBTztBQUROLENBTjhCLENBQTFCIiwiZmlsZSI6ImRlcGxveW1lbnQtdGFzay10cmFuc2l0aW9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCBjb21tYW5kQ29uZmlnIGZyb20gJy4vZGVwbG95bWVudC1zY3JpcHQtY29tbWFuZC1pbmZvJztcblxuZXhwb3J0IGNvbnN0IGhpc3RvcnlJZ25vcmVMaXN0ID0gW3tcbiAgZmllbGQ6ICdTY2hlZHVsZWQgRGVwbG95bWVudCBUaW1lJ1xufSwge1xuICBmaWVsZDogJ1JlbW90ZUlzc3VlTGluaydcbn0sIHtcbiAgZmllbGQ6ICdEZXZlbG9wbWVudCBUZWFtKHMpJ1xufSwge1xuICBmaWVsZDogJ0lzc3VlIFN0YXRlJ1xufV07XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwZXJmb3JtRGVwbG95bWVudFRhc2tUcmFuc2l0aW9uKG9wdGlvbnMpIHtcbiAgY29uc3QgcmVxdWlyZWRTdGF0dXNIaXN0b3J5ID0gY29tbWFuZENvbmZpZ1tvcHRpb25zLm9wZXJhdGlvblR5cGVdLnJlcXVpcmVkU3RhdGVzO1xuICBjb25zdCBhcmVXZUluVGhlUmlnaHRTdGF0ZSA9IChvcHRpb25zLmRlcGxveW1lbnRUYXNrLnN0YXR1cyA9PT0gXy5sYXN0KHJlcXVpcmVkU3RhdHVzSGlzdG9yeSkpO1xuXG4gIGlmIChjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0ubm9UcmFuc2l0aW9uU3RhdGVzXG4gICAgICAuaW5kZXhPZihvcHRpb25zLmRlcGxveW1lbnRUYXNrLnN0YXR1cykgPiAtMSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgSSB3aWxsIG5vdCB0cmFuc2l0aW9uICR7b3B0aW9ucy5kZXBsb3ltZW50VGFzay5rZXl9IHVudGlsIGl0IGdldHMgdG8gYCArXG4gICAgICAgICAgICAgICAgICAgIGAke18ubGFzdChjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0ucmVxdWlyZWRTdGF0ZXMpfS5gKTtcbiAgfVxuXG4gIGNvbnN0IGhhc0FueXRoaW5nSGFwcGVuZWRTaW5jZUFwcHJvdmFsID0gb3B0aW9ucy5kZXBsb3ltZW50VGFzay5oYXNJc3N1ZUNoYW5nZWQoXG4gICAgYXJlV2VJblRoZVJpZ2h0U3RhdGUgPyBjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0ucmVxdWlyZWRTdGF0ZXNcbiAgICAgIDogW29wdGlvbnMuZGVwbG95bWVudFRhc2suc3RhdHVzXSxcbiAgICBoaXN0b3J5SWdub3JlTGlzdFxuICApO1xuXG4gIGlmIChoYXNBbnl0aGluZ0hhcHBlbmVkU2luY2VBcHByb3ZhbCkge1xuICAgIGF3YWl0IG9wdGlvbnMuZGVwbG95bWVudFRhc2sudHJhbnNpdGlvbignUmVvcGVuJywgb3B0aW9ucy5yb2JvdCk7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdTb21ldGhpbmcgcmVxdWlyaW5nIHJlLWFwcHJvdmFsIGhhcyBoYXBwZW5lZCB0byB0aGlzIGRlcGxveW1lbnQgdGFzay4gICcgK1xuICAgICAgJ1BsZWFzZSBlbnN1cmUgZXZlcnl0aGluZyBpcyBjb3JyZWN0IGJlZm9yZSBhcHByb3ZpbmcgaXQgYWdhaW4uICBJIHJlb3BlbmVkIHRoZSBkZXBsb3ltZW50ICcgK1xuICAgICAgJ3Rhc2suJyk7XG4gIH1cblxuICBpZiAoIWFyZVdlSW5UaGVSaWdodFN0YXRlKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBUaGUgZGVwbG95bWVudCB0YXNrIGlzIGluIHRoZSBcXCcke29wdGlvbnMuZGVwbG95bWVudFRhc2suc3RhdHVzfVxcJyBzdGF0ZS4gYCArXG4gICAgICBgIEZvciBtZSB0byAke2NvbW1hbmRDb25maWdbb3B0aW9ucy5vcGVyYXRpb25UeXBlXS50cmFuc2l0aW9uVG9BdHRlbXB0fSBpdCBwcm9wZXJseSwgYCArXG4gICAgICBgJHtvcHRpb25zLnJlZ2V4R3JvdXBzLmRlcGxveW1lbnRUYXNrTnVtYmVyfSBuZWVkcyB0byBiZSBpbiB0aGUgYCArXG4gICAgICBgJHtfLmxhc3QoY29tbWFuZENvbmZpZ1tvcHRpb25zLm9wZXJhdGlvblR5cGVdLnJlcXVpcmVkU3RhdGVzKX0gc3RhdGUuYFxuICAgICk7XG4gIH1cblxuICBvcHRpb25zLnJlcy5zZW5kKCdOb3RoaW5nIGhhcyBjaGFuZ2VkIHNpbmNlIGFwcHJvdmFscy4gIFRoaXMgZGVwbG95bWVudCB0YXNrIGlzIGdvb2QgdG8gZ28uICAnICtcbiAgICBgSSBhbSBub3cgZ29pbmcgdG8gJHtjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0udHJhbnNpdGlvblRvQXR0ZW1wdH0gYCArXG4gICAgYCR7b3B0aW9ucy5yZWdleEdyb3Vwcy5kZXBsb3ltZW50VGFza051bWJlcn0uYFxuICApO1xuXG4gIGF3YWl0IG9wdGlvbnMuZGVwbG95bWVudFRhc2sudHJhbnNpdGlvbihcbiAgICBjb21tYW5kQ29uZmlnW29wdGlvbnMub3BlcmF0aW9uVHlwZV0udHJhbnNpdGlvblRvQXR0ZW1wdCxcbiAgICBvcHRpb25zLnJvYm90XG4gICk7XG4gIHJldHVybiB7fTtcbn1cbiJdfQ== |
@@ -169,2 +169,69 @@ 'use strict'; | ||
}() | ||
}, { | ||
key: 'getFirstCommitInRepoSha', | ||
value: function () { | ||
var _ref4 = (0, _asyncToGenerator3.default)(_regenerator2.default.mark(function _callee4(options) { | ||
var repoPath, repoInfo, firstDayCommits; | ||
return _regenerator2.default.wrap(function _callee4$(_context4) { | ||
while (1) { | ||
switch (_context4.prev = _context4.next) { | ||
case 0: | ||
repoPath = this.restApiPath + '/repos/' + options.user + '/' + options.repo; | ||
_context4.next = 3; | ||
return this.makeRequest(repoPath); | ||
case 3: | ||
repoInfo = _context4.sent; | ||
_context4.next = 6; | ||
return this.makeRequest(repoPath + '/commits?until=' + repoInfo.created_at); | ||
case 6: | ||
firstDayCommits = _context4.sent; | ||
return _context4.abrupt('return', firstDayCommits[0].sha); | ||
case 8: | ||
case 'end': | ||
return _context4.stop(); | ||
} | ||
} | ||
}, _callee4, this); | ||
})); | ||
function getFirstCommitInRepoSha(_x5) { | ||
return _ref4.apply(this, arguments); | ||
} | ||
return getFirstCommitInRepoSha; | ||
}() | ||
}, { | ||
key: 'getLastCommitInRepoSha', | ||
value: function () { | ||
var _ref5 = (0, _asyncToGenerator3.default)(_regenerator2.default.mark(function _callee5(options) { | ||
var repoPath, repoInfo; | ||
return _regenerator2.default.wrap(function _callee5$(_context5) { | ||
while (1) { | ||
switch (_context5.prev = _context5.next) { | ||
case 0: | ||
repoPath = this.restApiPath + '/repos/' + options.user + '/' + options.repo + '/master'; | ||
_context5.next = 3; | ||
return this.makeRequest(repoPath); | ||
case 3: | ||
repoInfo = _context5.sent; | ||
return _context5.abrupt('return', repoInfo.sha); | ||
case 5: | ||
case 'end': | ||
return _context5.stop(); | ||
} | ||
} | ||
}, _callee5, this); | ||
})); | ||
function getLastCommitInRepoSha(_x6) { | ||
return _ref5.apply(this, arguments); | ||
} | ||
return getLastCommitInRepoSha; | ||
}() | ||
}]); | ||
@@ -184,2 +251,2 @@ return GithubAPI; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9naXRodWItQVBJLmpzIl0sIm5hbWVzIjpbImlzVmFsaWRDb21taXRSYW5nZSIsInBhcnNlR2l0VVJMRm9yVXNlckFuZFJlcG8iLCJzdGF0dXMiLCJHaXRodWJBUEkiLCJvcHRpb25zIiwidmVyc2lvbiIsIkhVQk9UX0dJVEhVQl9WRVJTSU9OIiwicHJvdG9jb2wiLCJIVUJPVF9HSVRIVUJfUFJPVE9DT0wiLCJob3N0IiwiSFVCT1RfR0lUSFVCX0hPU1QiLCJwb3J0IiwiSFVCT1RfR0lUSFVCX1BPUlQiLCJwYXRoUHJlZml4IiwiSFVCT1RfR0lUSFVCX0VOVEVSUFJJU0UiLCJsb2dnZXIiLCJyZXF1ZXN0T3B0aW9ucyIsIm1ldGhvZCIsImluZGV4T2YiLCJoZWFkZXJzIiwiQWNjZXB0IiwicmVzdEFwaVBhdGgiLCJ1cmkiLCJkZWJ1ZyIsInJlc3VsdCIsIkpTT04iLCJwYXJzZSIsInVybCIsInVzZXIiLCJyZXBvIiwiYmFzZSIsImhlYWQiLCJtYWtlUmVxdWVzdCIsInJlcyIsIk51bWJlciIsImFoZWFkX2J5IiwiY29tbWl0cyIsImxlbmd0aCIsIkVycm9yIiwic2hhIiwiZmlsZVBhdGgiLCJnaXRVUkwiLCJtYXRjaCIsInVudXNlZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1FBRWdCQSxrQixHQUFBQSxrQjtRQXFEQUMseUIsR0FBQUEseUI7O0FBdkRoQjs7Ozs7O0FBRU8sU0FBU0Qsa0JBQVQsQ0FBNEJFLE1BQTVCLEVBQW9DO0FBQ3pDLFNBQVFBLFdBQVcsT0FBbkI7QUFDRDs7SUFFb0JDLFM7QUFDbkIsdUJBQTBCO0FBQUEsUUFBZEMsT0FBYyx1RUFBSixFQUFJO0FBQUE7O0FBQ3hCLFNBQUtDLE9BQUwsR0FBZUQsUUFBUUUsb0JBQVIsSUFBZ0MsT0FBL0M7QUFDQSxTQUFLQyxRQUFMLEdBQWdCSCxRQUFRSSxxQkFBUixJQUFpQyxNQUFqRDtBQUNBLFNBQUtDLElBQUwsR0FBWUwsUUFBUU0saUJBQVIsSUFBNkIsZ0JBQXpDO0FBQ0EsU0FBS0MsSUFBTCxHQUFZUCxRQUFRUSxpQkFBUixJQUE2QixFQUF6QztBQUNBLFNBQUtDLFVBQUwsR0FBbUJULFFBQVFVLHVCQUFULEdBQW9DLFNBQXBDLEdBQWdELEVBQWxFO0FBQ0EsU0FBS0MsTUFBTCxHQUFjWCxRQUFRVyxNQUF0QjtBQUNBLFNBQUtDLGNBQUwsR0FBc0I7QUFDcEJDLGNBQVEsS0FEWTtBQUVwQlYsZ0JBQVcsS0FBS0EsUUFBTCxDQUFjVyxPQUFkLENBQXNCLEdBQXRCLElBQTZCLENBQUMsQ0FBL0IsR0FBb0MsS0FBS1gsUUFBekMsR0FBdUQsS0FBS0EsUUFBNUQsTUFGVTtBQUdwQlksZUFBUztBQUNQQyxnQkFBUTtBQUREO0FBSFcsS0FBdEI7QUFPQSxTQUFLQyxXQUFMLEdBQXNCLEtBQUtkLFFBQTNCLFdBQXlDLEtBQUtFLElBQTlDLFNBQXNELEtBQUtFLElBQTNELEdBQWtFLEtBQUtFLFVBQXZFO0FBQ0Q7Ozs7OzZGQUVpQlMsRzs7Ozs7O0FBQ2hCLHFCQUFLUCxNQUFMLENBQVlRLEtBQVoscUJBQW9DRCxHQUFwQzs7dUJBQ3FCLHlEQUFhLEtBQUtOLGNBQWxCLElBQWtDTSxRQUFsQyxJOzs7QUFBZkUsc0I7O3NCQUVGQSxXQUFXLFc7Ozs7O2lEQUNOQSxNOzs7aURBR0ZDLEtBQUtDLEtBQUwsQ0FBV0YsTUFBWCxDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OytGQUdZcEIsTzs7Ozs7O0FBQ2J1QixtQixHQUFTLEtBQUtOLFdBQVIsZUFBNkJqQixRQUFRd0IsSUFBckMsU0FBNkN4QixRQUFReUIsSUFBckQsa0JBQ1l6QixRQUFRMEIsSUFEcEIsV0FDOEIxQixRQUFRMkIsSUFEdEMsQzs7dUJBRU0sS0FBS0MsV0FBTCxDQUFpQkwsR0FBakIsQzs7O0FBQVpNLG1COztzQkFFRmpDLG1CQUFtQmlDLElBQUkvQixNQUF2QixLQUFrQ2dDLE9BQU9ELElBQUlFLFFBQVgsSUFBdUJELE9BQU9ELElBQUlHLE9BQUosQ0FBWUMsTUFBbkIsQzs7Ozs7c0JBQ3JELElBQUlDLEtBQUosQ0FBVSw2RUFDQSxxQkFEVixDOzs7a0RBR0RMLEc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7K0ZBR2U3QixPOzs7OztrREFDZixLQUFLNEIsV0FBTCxDQUNGLEtBQUt6QixRQUFSLFdBQXNCLEtBQUtFLElBQTNCLFNBQW1DLEtBQUtFLElBQXhDLGFBQW9EUCxRQUFRd0IsSUFBNUQsU0FBb0V4QixRQUFReUIsSUFBNUUsZUFDR3pCLFFBQVFtQyxHQURYLEdBQ2lCbkMsUUFBUW9DLFFBRHpCLENBREssQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7a0JBMUNVckMsUztBQWlEZCxTQUFTRix5QkFBVCxDQUFtQ3dDLE1BQW5DLEVBQTJDO0FBQUEsc0JBRTlDQSxPQUFPQyxLQUFQLENBQWEsK0RBQWIsQ0FGOEM7QUFBQTtBQUFBLE1BQ3pDQyxNQUR5QztBQUFBLE1BQ2pDZixJQURpQztBQUFBLE1BQzNCQyxJQUQyQjs7QUFHaEQsU0FBTyxFQUFFYyxjQUFGLEVBQVVkLFVBQVYsRUFBZ0JELFVBQWhCLEVBQVA7QUFDRCIsImZpbGUiOiJnaXRodWItQVBJLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHJlcXVlc3QgZnJvbSAncmVxdWVzdC1wcm9taXNlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGlzVmFsaWRDb21taXRSYW5nZShzdGF0dXMpIHtcbiAgcmV0dXJuIChzdGF0dXMgPT09ICdhaGVhZCcpO1xufVxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBHaXRodWJBUEkge1xuICBjb25zdHJ1Y3RvcihvcHRpb25zID0ge30pIHtcbiAgICB0aGlzLnZlcnNpb24gPSBvcHRpb25zLkhVQk9UX0dJVEhVQl9WRVJTSU9OIHx8ICczLjAuMCc7XG4gICAgdGhpcy5wcm90b2NvbCA9IG9wdGlvbnMuSFVCT1RfR0lUSFVCX1BST1RPQ09MIHx8ICdodHRwJztcbiAgICB0aGlzLmhvc3QgPSBvcHRpb25zLkhVQk9UX0dJVEhVQl9IT1NUIHx8ICdhcGkuZ2l0aHViLmNvbSc7XG4gICAgdGhpcy5wb3J0ID0gb3B0aW9ucy5IVUJPVF9HSVRIVUJfUE9SVCB8fCA4MDtcbiAgICB0aGlzLnBhdGhQcmVmaXggPSAob3B0aW9ucy5IVUJPVF9HSVRIVUJfRU5URVJQUklTRSkgPyAnL2FwaS92MycgOiAnJztcbiAgICB0aGlzLmxvZ2dlciA9IG9wdGlvbnMubG9nZ2VyO1xuICAgIHRoaXMucmVxdWVzdE9wdGlvbnMgPSB7XG4gICAgICBtZXRob2Q6ICdHRVQnLFxuICAgICAgcHJvdG9jb2w6ICh0aGlzLnByb3RvY29sLmluZGV4T2YoJzonKSA+IC0xKSA/IHRoaXMucHJvdG9jb2wgOiBgJHt0aGlzLnByb3RvY29sfTpgLFxuICAgICAgaGVhZGVyczoge1xuICAgICAgICBBY2NlcHQ6ICdhcHBsaWNhdGlvbi9qc29uJ1xuICAgICAgfVxuICAgIH07XG4gICAgdGhpcy5yZXN0QXBpUGF0aCA9IGAke3RoaXMucHJvdG9jb2x9Oi8vJHt0aGlzLmhvc3R9OiR7dGhpcy5wb3J0fSR7dGhpcy5wYXRoUHJlZml4fWA7XG4gIH1cblxuICBhc3luYyBtYWtlUmVxdWVzdCh1cmkpIHtcbiAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhgR2l0aHViIFJlcXVlc3QgJHt1cml9YCk7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcmVxdWVzdCh7IC4uLnRoaXMucmVxdWVzdE9wdGlvbnMsIHVyaSB9KTtcblxuICAgIGlmIChyZXN1bHQgPT09ICdOb3QgRm91bmQnKSB7XG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cblxuICAgIHJldHVybiBKU09OLnBhcnNlKHJlc3VsdCk7XG4gIH1cblxuICBhc3luYyBjb21wYXJlQ29tbWl0cyhvcHRpb25zKSB7XG4gICAgY29uc3QgdXJsID0gYCR7dGhpcy5yZXN0QXBpUGF0aH0vcmVwb3MvJHtvcHRpb25zLnVzZXJ9LyR7b3B0aW9ucy5yZXBvfWAgK1xuICAgICAgICAgICAgICAgIGAvY29tcGFyZS8ke29wdGlvbnMuYmFzZX0uLi4ke29wdGlvbnMuaGVhZH1gO1xuICAgIGNvbnN0IHJlcyA9IGF3YWl0IHRoaXMubWFrZVJlcXVlc3QodXJsKTtcblxuICAgIGlmIChpc1ZhbGlkQ29tbWl0UmFuZ2UocmVzLnN0YXR1cykgJiYgTnVtYmVyKHJlcy5haGVhZF9ieSkgPiBOdW1iZXIocmVzLmNvbW1pdHMubGVuZ3RoKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdUaGVyZSBhcmUgdG9vIG1hbnkgY29tbWl0cyBpbiB0aGlzIGRlcGxveW1lbnQsIHRoaXMgZGVwbG95bWVudCB0YXNrIG11c3QnICtcbiAgICAgICAgICAgICAgICAgICAgICAnIGJlIGh1Ym90IGJ5cGFzc2VkLicpO1xuICAgIH1cbiAgICByZXR1cm4gcmVzO1xuICB9XG5cbiAgYXN5bmMgZ2V0RmlsZUZyb21Db21taXQob3B0aW9ucykge1xuICAgIHJldHVybiB0aGlzLm1ha2VSZXF1ZXN0KFxuICAgICAgYCR7dGhpcy5wcm90b2NvbH06Ly8ke3RoaXMuaG9zdH06JHt0aGlzLnBvcnR9L3Jhdy8ke29wdGlvbnMudXNlcn0vJHtvcHRpb25zLnJlcG99L2AgK1xuICAgICAgYCR7b3B0aW9ucy5zaGF9JHtvcHRpb25zLmZpbGVQYXRofWBcbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZUdpdFVSTEZvclVzZXJBbmRSZXBvKGdpdFVSTCkge1xuICBjb25zdCBbdW51c2VkLCB1c2VyLCByZXBvXSA9XG4gICAgZ2l0VVJMLm1hdGNoKC8oPzpodHRwKD86cyk/fGdpdCk6XFwvXFwvLipcXC8oLiopXFwvKFthLXpBLVpcXC1fMC05XSopKD86XFwuZ2l0KT8vaSk7XG4gIHJldHVybiB7IHVudXNlZCwgcmVwbywgdXNlciB9O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9naXRodWItQVBJLmpzIl0sIm5hbWVzIjpbImlzVmFsaWRDb21taXRSYW5nZSIsInBhcnNlR2l0VVJMRm9yVXNlckFuZFJlcG8iLCJzdGF0dXMiLCJHaXRodWJBUEkiLCJvcHRpb25zIiwidmVyc2lvbiIsIkhVQk9UX0dJVEhVQl9WRVJTSU9OIiwicHJvdG9jb2wiLCJIVUJPVF9HSVRIVUJfUFJPVE9DT0wiLCJob3N0IiwiSFVCT1RfR0lUSFVCX0hPU1QiLCJwb3J0IiwiSFVCT1RfR0lUSFVCX1BPUlQiLCJwYXRoUHJlZml4IiwiSFVCT1RfR0lUSFVCX0VOVEVSUFJJU0UiLCJsb2dnZXIiLCJyZXF1ZXN0T3B0aW9ucyIsIm1ldGhvZCIsImluZGV4T2YiLCJoZWFkZXJzIiwiQWNjZXB0IiwicmVzdEFwaVBhdGgiLCJ1cmkiLCJkZWJ1ZyIsInJlc3VsdCIsIkpTT04iLCJwYXJzZSIsInVybCIsInVzZXIiLCJyZXBvIiwiYmFzZSIsImhlYWQiLCJtYWtlUmVxdWVzdCIsInJlcyIsIk51bWJlciIsImFoZWFkX2J5IiwiY29tbWl0cyIsImxlbmd0aCIsIkVycm9yIiwic2hhIiwiZmlsZVBhdGgiLCJyZXBvUGF0aCIsInJlcG9JbmZvIiwiY3JlYXRlZF9hdCIsImZpcnN0RGF5Q29tbWl0cyIsImdpdFVSTCIsIm1hdGNoIiwidW51c2VkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7UUFFZ0JBLGtCLEdBQUFBLGtCO1FBb0VBQyx5QixHQUFBQSx5Qjs7QUF0RWhCOzs7Ozs7QUFFTyxTQUFTRCxrQkFBVCxDQUE0QkUsTUFBNUIsRUFBb0M7QUFDekMsU0FBUUEsV0FBVyxPQUFuQjtBQUNEOztJQUVvQkMsUztBQUNuQix1QkFBMEI7QUFBQSxRQUFkQyxPQUFjLHVFQUFKLEVBQUk7QUFBQTs7QUFDeEIsU0FBS0MsT0FBTCxHQUFlRCxRQUFRRSxvQkFBUixJQUFnQyxPQUEvQztBQUNBLFNBQUtDLFFBQUwsR0FBZ0JILFFBQVFJ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IjoiZ2l0aHViLUFQSS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCByZXF1ZXN0IGZyb20gJ3JlcXVlc3QtcHJvbWlzZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1ZhbGlkQ29tbWl0UmFuZ2Uoc3RhdHVzKSB7XG4gIHJldHVybiAoc3RhdHVzID09PSAnYWhlYWQnKTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgR2l0aHViQVBJIHtcbiAgY29uc3RydWN0b3Iob3B0aW9ucyA9IHt9KSB7XG4gICAgdGhpcy52ZXJzaW9uID0gb3B0aW9ucy5IVUJPVF9HSVRIVUJfVkVSU0lPTiB8fCAnMy4wLjAnO1xuICAgIHRoaXMucHJvdG9jb2wgPSBvcHRpb25zLkhVQk9UX0dJVEhVQl9QUk9UT0NPTCB8fCAnaHR0cCc7XG4gICAgdGhpcy5ob3N0ID0gb3B0aW9ucy5IVUJPVF9HSVRIVUJfSE9TVCB8fCAnYXBpLmdpdGh1Yi5jb20nO1xuICAgIHRoaXMucG9ydCA9IG9wdGlvbnMuSFVCT1RfR0lUSFVCX1BPUlQgfHwgODA7XG4gICAgdGhpcy5wYXRoUHJlZml4ID0gKG9wdGlvbnMuSFVCT1RfR0lUSFVCX0VOVEVSUFJJU0UpID8gJy9hcGkvdjMnIDogJyc7XG4gICAgdGhpcy5sb2dnZXIgPSBvcHRpb25zLmxvZ2dlcjtcbiAgICB0aGlzLnJlcXVlc3RPcHRpb25zID0ge1xuICAgICAgbWV0aG9kOiAnR0VUJyxcbiAgICAgIHByb3RvY29sOiAodGhpcy5wcm90b2NvbC5pbmRleE9mKCc6JykgPiAtMSkgPyB0aGlzLnByb3RvY29sIDogYCR7dGhpcy5wcm90b2NvbH06YCxcbiAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgQWNjZXB0OiAnYXBwbGljYXRpb24vanNvbidcbiAgICAgIH1cbiAgICB9O1xuICAgIHRoaXMucmVzdEFwaVBhdGggPSBgJHt0aGlzLnByb3RvY29sfTovLyR7dGhpcy5ob3N0fToke3RoaXMucG9ydH0ke3RoaXMucGF0aFByZWZpeH1gO1xuICB9XG5cbiAgYXN5bmMgbWFrZVJlcXVlc3QodXJpKSB7XG4gICAgdGhpcy5sb2dnZXIuZGVidWcoYEdpdGh1YiBSZXF1ZXN0ICR7dXJpfWApO1xuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHJlcXVlc3QoeyAuLi50aGlzLnJlcXVlc3RPcHRpb25zLCB1cmkgfSk7XG5cbiAgICBpZiAocmVzdWx0ID09PSAnTm90IEZvdW5kJykge1xuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9XG5cbiAgICByZXR1cm4gSlNPTi5wYXJzZShyZXN1bHQpO1xuICB9XG5cbiAgYXN5bmMgY29tcGFyZUNvbW1pdHMob3B0aW9ucykge1xuICAgIGNvbnN0IHVybCA9IGAke3RoaXMucmVzdEFwaVBhdGh9L3JlcG9zLyR7b3B0aW9ucy51c2VyfS8ke29wdGlvbnMucmVwb31gICtcbiAgICAgICAgICAgICAgICBgL2NvbXBhcmUvJHtvcHRpb25zLmJhc2V9Li4uJHtvcHRpb25zLmhlYWR9YDtcbiAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLm1ha2VSZXF1ZXN0KHVybCk7XG5cbiAgICBpZiAoaXNWYWxpZENvbW1pdFJhbmdlKHJlcy5zdGF0dXMpICYmIE51bWJlcihyZXMuYWhlYWRfYnkpID4gTnVtYmVyKHJlcy5jb21taXRzLmxlbmd0aCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignVGhlcmUgYXJlIHRvbyBtYW55IGNvbW1pdHMgaW4gdGhpcyBkZXBsb3ltZW50LCB0aGlzIGRlcGxveW1lbnQgdGFzayBtdXN0JyArXG4gICAgICAgICAgICAgICAgICAgICAgJyBiZSBodWJvdCBieXBhc3NlZC4nKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlcztcbiAgfVxuXG4gIGFzeW5jIGdldEZpbGVGcm9tQ29tbWl0KG9wdGlvbnMpIHtcbiAgICByZXR1cm4gdGhpcy5tYWtlUmVxdWVzdChcbiAgICAgIGAke3RoaXMucHJvdG9jb2x9Oi8vJHt0aGlzLmhvc3R9OiR7dGhpcy5wb3J0fS9yYXcvJHtvcHRpb25zLnVzZXJ9LyR7b3B0aW9ucy5yZXBvfS9gICtcbiAgICAgIGAke29wdGlvbnMuc2hhfSR7b3B0aW9ucy5maWxlUGF0aH1gXG4gICAgKTtcbiAgfVxuXG4gIGFzeW5jIGdldEZpcnN0Q29tbWl0SW5SZXBvU2hhKG9wdGlvbnMpIHtcbiAgICBjb25zdCByZXBvUGF0aCA9IGAke3RoaXMucmVzdEFwaVBhdGh9L3JlcG9zLyR7b3B0aW9ucy51c2VyfS8ke29wdGlvbnMucmVwb31gO1xuICAgIGNvbnN0IHJlcG9JbmZvID0gYXdhaXQgdGhpcy5tYWtlUmVxdWVzdChyZXBvUGF0aCk7XG4gICAgY29uc3QgZmlyc3REYXlDb21taXRzID0gYXdhaXQgdGhpcy5tYWtlUmVxdWVzdChcbiAgICAgIGAke3JlcG9QYXRofS9jb21taXRzP3VudGlsPSR7cmVwb0luZm8uY3JlYXRlZF9hdH1gXG4gICAgKTtcbiAgICByZXR1cm4gZmlyc3REYXlDb21taXRzWzBdLnNoYTtcbiAgfVxuXG4gIGFzeW5jIGdldExhc3RDb21taXRJblJlcG9TaGEob3B0aW9ucykge1xuICAgIGNvbnN0IHJlcG9QYXRoID0gYCR7dGhpcy5yZXN0QXBpUGF0aH0vcmVwb3MvJHtvcHRpb25zLnVzZXJ9LyR7b3B0aW9ucy5yZXBvfS9tYXN0ZXJgO1xuICAgIGNvbnN0IHJlcG9JbmZvID0gYXdhaXQgdGhpcy5tYWtlUmVxdWVzdChyZXBvUGF0aCk7XG4gICAgcmV0dXJuIHJlcG9JbmZvLnNoYTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VHaXRVUkxGb3JVc2VyQW5kUmVwbyhnaXRVUkwpIHtcbiAgY29uc3QgW3VudXNlZCwgdXNlciwgcmVwb10gPVxuICAgIGdpdFVSTC5tYXRjaCgvKD86aHR0cCg/OnMpP3xnaXQpOlxcL1xcLy4qXFwvKC4qKVxcLyhbYS16QS1aXFwtXzAtOV0qKSg/OlxcLmdpdCk/L2kpO1xuICByZXR1cm4geyB1bnVzZWQsIHJlcG8sIHVzZXIgfTtcbn1cbiJdfQ== |
@@ -8,6 +8,2 @@ 'use strict'; | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _promise = require('babel-runtime/core-js/promise'); | ||
@@ -29,2 +25,6 @@ | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _asyncToGenerator2 = require('babel-runtime/helpers/asyncToGenerator'); | ||
@@ -51,3 +51,3 @@ | ||
deploymentBuildTypeId = _ref2.deploymentBuildTypeId; | ||
var dependencyIgnoreList, response, successfulBuilds, deploymentBuildId, deploymentBuildInfo, artifactDependencies, dependencies; | ||
var dependencyIgnoreList, response, successfulBuilds, otherResponse, otherBuilds, info, deploymentBuildId, deploymentBuildInfo, artifactDependencies, dependencies; | ||
return _regenerator2.default.wrap(function _callee$(_context) { | ||
@@ -66,14 +66,33 @@ while (1) { | ||
if (!(successfulBuilds.length < 1)) { | ||
_context.next = 7; | ||
_context.next = 16; | ||
break; | ||
} | ||
throw new Error('There has never been a deployment from ' + name + ' Project before. ' + 'The first deployment should be a manual process for now.'); | ||
_context.next = 8; | ||
return teamcity.fetchBuildTypeInfo(deploymentBuildTypeId); | ||
case 7: | ||
case 8: | ||
otherResponse = _context.sent; | ||
_context.next = 11; | ||
return teamcity.fetchSuccessfulBuilds(otherResponse['artifact-dependencies']['artifact-dependency'].filter(function (x) { | ||
return dependencyIgnoreList.indexOf(x['source-buildType'].id) === -1; | ||
})[0]['source-buildType'].id); | ||
case 11: | ||
otherBuilds = _context.sent; | ||
_context.next = 14; | ||
return teamcity.getGitInfo(otherBuilds.build[0].id); | ||
case 14: | ||
info = _context.sent; | ||
return _context.abrupt('return', (0, _extends3.default)({}, info, { | ||
firstTimeDeployment: true | ||
})); | ||
case 16: | ||
deploymentBuildId = successfulBuilds[0].id; | ||
_context.next = 10; | ||
_context.next = 19; | ||
return teamcity.fetchBuildInfo(deploymentBuildId); | ||
case 10: | ||
case 19: | ||
deploymentBuildInfo = _context.sent; | ||
@@ -83,3 +102,3 @@ artifactDependencies = deploymentBuildInfo['artifact-dependencies']; | ||
if (!(!artifactDependencies || artifactDependencies.build.length === 0)) { | ||
_context.next = 14; | ||
_context.next = 23; | ||
break; | ||
@@ -90,3 +109,3 @@ } | ||
case 14: | ||
case 23: | ||
dependencies = artifactDependencies.build.filter(function (x) { | ||
@@ -97,3 +116,3 @@ return dependencyIgnoreList.indexOf(x.buildTypeId) === -1; | ||
if (!(dependencies.length > 1)) { | ||
_context.next = 17; | ||
_context.next = 26; | ||
break; | ||
@@ -104,6 +123,6 @@ } | ||
case 17: | ||
case 26: | ||
return _context.abrupt('return', teamcity.getGitInfo(dependencies[0].id)); | ||
case 18: | ||
case 27: | ||
case 'end': | ||
@@ -534,9 +553,25 @@ return _context.stop(); | ||
_context7.next = 15; | ||
if (!base.firstTimeDeployment) { | ||
_context7.next = 18; | ||
break; | ||
} | ||
this.res.send('Scanning for first time deployment from ' + query.repo + '.'); | ||
_context7.next = 17; | ||
return this.github.getFirstCommitInRepoSha({ | ||
repo: base.repo, | ||
user: base.user | ||
}); | ||
case 17: | ||
base.sha = _context7.sent; | ||
case 18: | ||
_context7.next = 20; | ||
return this.compareBuilds(query.sha, base.sha, base.user, base.repo); | ||
case 15: | ||
case 20: | ||
result = _context7.sent; | ||
relevantCommits = []; | ||
_context7.next = 19; | ||
_context7.next = 24; | ||
return (0, _fileFiltering.getRegexWhitelist)({ | ||
@@ -550,7 +585,7 @@ githubAPI: this.github, | ||
case 19: | ||
case 24: | ||
_context7.t1 = _context7.sent; | ||
if (_context7.t1) { | ||
_context7.next = 22; | ||
_context7.next = 27; | ||
break; | ||
@@ -561,7 +596,7 @@ } | ||
case 22: | ||
case 27: | ||
relevantFilesToDeployment = _context7.t1; | ||
if (!(relevantFilesToDeployment.length > 0)) { | ||
_context7.next = 25; | ||
_context7.next = 30; | ||
break; | ||
@@ -596,5 +631,5 @@ } | ||
}, _callee6, _this3); | ||
})(), 't2', 25); | ||
})(), 't2', 30); | ||
case 25: | ||
case 30: | ||
@@ -604,3 +639,3 @@ this.robot.logger.debug('Commits were in a ' + result.status + ' status'); | ||
if (!(0, _githubAPI.isValidCommitRange)(result.status)) { | ||
_context7.next = 30; | ||
_context7.next = 35; | ||
break; | ||
@@ -610,3 +645,3 @@ } | ||
if (!(relevantCommits.length <= 0)) { | ||
_context7.next = 29; | ||
_context7.next = 34; | ||
break; | ||
@@ -617,3 +652,3 @@ } | ||
case 29: | ||
case 34: | ||
return _context7.abrupt('return', (0, _extends3.default)({}, result, { | ||
@@ -626,5 +661,5 @@ commits: result.commits.filter(function (_ref10) { | ||
case 30: | ||
case 35: | ||
if (!this.commitResultStatusStrategies.hasOwnProperty(result.status)) { | ||
_context7.next = 32; | ||
_context7.next = 37; | ||
break; | ||
@@ -635,6 +670,6 @@ } | ||
case 32: | ||
case 37: | ||
throw new Error('The commits were in some status we have not accounted for ' + ('(' + result.status + '), please notify the maintainers of this deployment script.')); | ||
case 33: | ||
case 38: | ||
case 'end': | ||
@@ -713,2 +748,2 @@ return _context7.stop(); | ||
}(); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/tool-teamcity-requests.js"],"names":["teamcity","env","robot","name","deploymentBuildTypeId","dependencyIgnoreList","HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST","split","fetchSuccessfulBuilds","response","successfulBuilds","build","length","Error","deploymentBuildId","id","fetchBuildInfo","deploymentBuildInfo","artifactDependencies","buildType","dependencies","filter","indexOf","x","buildTypeId","getGitInfo","getMostRecentSuccessfulBuild","options","poller","CommitListPoller","teamcityAPI","githubAPI","res","process","getCommitLists","parsedDeployments","newBases","commitListsResult","getDeploymentCommitLists","deployment","buildId","headBuildId","memoizedArguments","result","githubInfoMemoizeGate","listOfDeployments","consolidatedDeploymentList","flatMap","prodBuildField","deployments","map","y","key","githubInfo","all","headSha","sha","repo","user","getGithubInfoFromDeployment","github","commitResultStatusStrategies","diverged","behind","identical","productionBuildList","scanDeployment","resultList","errorList","error","commits","deploymentTarget","send","getGitCommits","commitsResult","deploymentName","logger","stack","message","compareBuildsResult","fileFilteringFunction","makeRequest","url","treeResult","truncated","files","commitToReturn","filename","filesChanged","query","baseInNewBases","hash","base","compareBuilds","relevantCommits","relevantFilesToDeployment","fileFilterer","regexWhiteList","createCommitFileMap","memoizedFileFilter","debug","status","hasOwnProperty","head","compareCommits","compareResult","__gitRepo"],"mappings":"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","file":"tool-teamcity-requests.js","sourcesContent":["import { isValidCommitRange } from './github-API';\nimport { accumulateAndThrow } from './error-accumulator';\nimport transformThrownToString from './error-conversion';\nimport {\n  FileFilterer,\n  getRegexWhitelist\n} from './file-filtering';\nimport _ from 'lodash';\n\n/*\n * Important variable names:\n *\n * Prefixes:\n * - head: The sha/build we wish to deploy (sha if no suffix)\n * - base: The sha/build we previously deployed (sha if no suffix)\n * - deployment: The build configuration we use to deploy\n *\n * Suffixes:\n * - BuildId: A TeamCity Build Id\n * - BuildTypeId: A TeamCity Build Configuration Id\n */\n\nasync function getMostRecentSuccessfulBuild({ name, deploymentBuildTypeId }, teamcity, env, robot) {\n  const dependencyIgnoreList = env.HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST\n    ? env.HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST.split(',')\n    : [];\n\n  const response = await teamcity.fetchSuccessfulBuilds(deploymentBuildTypeId);\n  const successfulBuilds = response.build || [];\n\n  if (successfulBuilds.length < 1) {\n    throw new Error(`There has never been a deployment from ${name} Project before. ` +\n                    'The first deployment should be a manual process for now.');\n  }\n\n  const deploymentBuildId = successfulBuilds[0].id;\n\n  const deploymentBuildInfo = await teamcity.fetchBuildInfo(deploymentBuildId);\n\n  const artifactDependencies = deploymentBuildInfo['artifact-dependencies'];\n\n  if (!artifactDependencies || artifactDependencies.build.length === 0) {\n    throw new Error('The Production Deploy does not have any artifact dependencies.  Please ' +\n                    'ensure the Production Deploy buildType ' +\n                    `'${deploymentBuildInfo.buildType.name}' is actually ` +\n                    'a Deploy BuildType in teamcity.');\n  }\n\n  const dependencies = artifactDependencies.build\n    .filter(x => dependencyIgnoreList.indexOf(x.buildTypeId) === -1);\n\n  if (dependencies.length > 1) {\n    throw new Error(`Unable to find the CI build from '${deploymentBuildInfo.name}', ` +\n                    'ensure the deployment has the CI listed as an artifact dependency ' +\n                    'in TeamCity.');\n  }\n\n  return teamcity.getGitInfo(dependencies[0].id);\n}\n\nexport class CommitListPoller {\n  constructor(teamcity, github, robot, res, env = {}) {\n    this.teamcity = teamcity;\n    this.github = github;\n    this.robot = robot;\n    this.res = res;\n    this.env = env;\n    this.commitResultStatusStrategies = {\n      diverged: 'No range of commits exist, the production CI builds are diverged.',\n      behind: 'The commits for the build you are attempting to deploy are behind the ' +\n              'head of master. Are you trying to deploy an old build? Double check the CI ' +\n              'build # is correct in the Proposed Build(s) field on the deployment task.  ' +\n              '(The ability to roll-back a deployment has not been created yet.)',\n      identical: 'There is no discernable difference between the build you are deploying ' +\n                 'and the previous production build\\'s commits.  Were project dependencies ' +\n                 'the only thing updated in this deploy? Follow along at TW-7901'\n    };\n  }\n\n  async getCommitLists(productionBuildList, newBases = []) {\n    const resultList = await Promise.all(\n      productionBuildList.deployments.map(x => this.scanDeployment(x, newBases))\n    );\n\n    const errorList = resultList.filter(x => !x.result).map(x => x.error);\n    if (errorList.length > 0) {\n      accumulateAndThrow(errorList);\n    }\n\n    return resultList.map(x => x.commits);\n  }\n\n  async scanDeployment(deploymentTarget, newBases = []) {\n    try {\n      this.res.send(`Scanning changes for '${deploymentTarget.name}'`);\n\n      const commitsResult = await this.getGitCommits(deploymentTarget, newBases);\n\n      const result = {\n        deploymentName: deploymentTarget.name,\n        result: true,\n        commits: commitsResult.commits\n      };\n\n      this.res.send(`Successfully scanned '${deploymentTarget.name}'`);\n\n      return result;\n    } catch (err) {\n      this.robot.logger.error(err.stack);\n      return {\n        result: false,\n        error: `Error in Deployment: '${deploymentTarget.name}', ${err.message}`\n      };\n    }\n  }\n\n  async createCommitFileMap({\n    compareBuildsResult,\n    fileFilteringFunction\n  }) {\n    const commits = compareBuildsResult.commits;\n\n    const filesChanged = await Promise.all(commits.map(async x => {\n      const treeResult = await this.github.makeRequest(x.url);\n\n      if (treeResult.truncated) {\n        this.res.send(\n          `WARNING: Commit with sha: ${x.sha} is huge and cannot be adequately checked if it is ` +\n          'relevant or not.  Too many files were changed and github has truncated the results.  ' +\n          'Please check this commit\\'s files manually.'\n        );\n\n        return {\n          sha: x.sha,\n          files: []\n        };\n      }\n\n      const commitToReturn = {\n        sha: x.sha,\n        files: treeResult.files.map(y => y.filename).filter(y => fileFilteringFunction(y))\n      };\n      return commitToReturn;\n    }));\n\n    return filesChanged.filter(({ files = [] }) => files.length > 0).map(x => x.sha);\n  }\n\n  async getGitCommits(deploymentTarget, newBases = []) {\n    const query = await this.teamcity.getGitInfo(deploymentTarget.headBuildId);\n\n    const baseInNewBases = newBases.filter(x => x.hash === `${query.repo}|${query.user}`);\n    const base = (baseInNewBases.length === 1) ? baseInNewBases[0].base :\n      (await getMostRecentSuccessfulBuild(deploymentTarget, this.teamcity, this.env, this.robot));\n\n    if (base.headSha) {\n      base.sha = base.headSha;\n    }\n\n    const result = await this.compareBuilds(query.sha, base.sha, base.user, base.repo);\n\n    let relevantCommits = [];\n\n    const relevantFilesToDeployment = await getRegexWhitelist({\n      githubAPI: this.github,\n      repo: base.repo,\n      user: base.user,\n      sha: query.sha,\n      buildType: deploymentTarget.deploymentBuildTypeId\n    }) || [];\n\n    if (relevantFilesToDeployment.length > 0) {\n      const fileFilterer = new FileFilterer({\n        regexWhiteList: relevantFilesToDeployment\n      });\n\n      relevantCommits = await this.createCommitFileMap({\n        compareBuildsResult: result,\n        fileFilteringFunction: (filename) => fileFilterer.memoizedFileFilter(filename)\n      });\n    }\n\n    this.robot.logger.debug(`Commits were in a ${result.status} status`);\n\n    if (isValidCommitRange(result.status)) {\n      if (relevantCommits.length <= 0) {\n        return result;\n      }\n\n      return {\n        ...result,\n        commits: result.commits.filter(({ sha }) => relevantCommits.indexOf(sha) > -1)\n      };\n    }\n\n    if (this.commitResultStatusStrategies.hasOwnProperty(result.status)) {\n      throw new Error(this.commitResultStatusStrategies[result.status]);\n    }\n\n    throw new Error('The commits were in some status we have not accounted for ' +\n                    `(${result.status}), please notify the maintainers of this deployment script.`);\n  }\n\n  async compareBuilds(head, base, user, repo) {\n    try {\n      this.robot.logger.debug(`Comparing commits ${base}...${head} in ${user}/${repo}`);\n      const compareResult = await this.github.compareCommits({ base, head, user, repo });\n\n      return {\n        status: compareResult.status,\n        commits: compareResult.commits.map(x => ({\n          ...x,\n          __gitRepo: repo\n        }))\n      };\n    } catch (err) {\n      if (err.message.indexOf('Not Found') > -1) {\n        if (this.robot) {\n          this.robot.logger.error(transformThrownToString(err, false));\n        }\n        throw new Error(`The Git Repository ${repo} is not linked properly in Teamcity.  ` +\n                        'Check to make sure the repository exists, and that the URL ' +\n                        'specified in the Teamcity CI Build is not a redirected URL.');\n      } else {\n        throw err;\n      }\n    }\n  }\n}\n\nexport async function getDeploymentCommitLists(options) {\n/*  productionBuildList,\n  teamCityAPI,\n  githubAPI,\n  hubotResponse,\n  hubotRobot,\n  newBases = []\n) { */\n  const poller = new CommitListPoller(\n    options.teamcityAPI,\n    options.githubAPI,\n    options.robot,\n    options.res,\n    process.env\n  );\n\n  return {\n    commitListsResult:\n      await poller.getCommitLists(options.parsedDeployments, options.newBases || [])\n  };\n}\n\nexport async function getGithubInfoFromDeployment(teamcityAPI, listOfDeployments = []) {\n  const memoizedArguments = {};\n\n  const consolidatedDeploymentList = _.flatMap(listOfDeployments, x =>\n    x.prodBuildField.deployments.map(y => ({ ...y, key: x.key })),\n  );\n\n  async function githubInfoMemoizeGate(deployment) {\n    const buildId = deployment.headBuildId;\n    if (memoizedArguments[buildId]) {\n      return memoizedArguments[buildId];\n    }\n\n    const result = await teamcityAPI.getGitInfo(buildId);\n    memoizedArguments[buildId] = result;\n    return result;\n  }\n\n  const githubInfo = consolidatedDeploymentList.map(async x => {\n    const result = await githubInfoMemoizeGate(x);\n    memoizedArguments[x.headBuildId] = result;\n    return result;\n  });\n\n  await Promise.all(githubInfo);\n\n  return consolidatedDeploymentList.map(x => ({\n    deployment: x,\n    headSha: memoizedArguments[x.headBuildId].sha,\n    repo: memoizedArguments[x.headBuildId].repo,\n    user: memoizedArguments[x.headBuildId].user\n  }));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/tool-teamcity-requests.js"],"names":["teamcity","env","robot","name","deploymentBuildTypeId","dependencyIgnoreList","HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST","split","fetchSuccessfulBuilds","response","successfulBuilds","build","length","fetchBuildTypeInfo","otherResponse","filter","indexOf","x","id","otherBuilds","getGitInfo","info","firstTimeDeployment","deploymentBuildId","fetchBuildInfo","deploymentBuildInfo","artifactDependencies","Error","buildType","dependencies","buildTypeId","getMostRecentSuccessfulBuild","options","poller","CommitListPoller","teamcityAPI","githubAPI","res","process","getCommitLists","parsedDeployments","newBases","commitListsResult","getDeploymentCommitLists","deployment","buildId","headBuildId","memoizedArguments","result","githubInfoMemoizeGate","listOfDeployments","consolidatedDeploymentList","flatMap","prodBuildField","deployments","map","y","key","githubInfo","all","headSha","sha","repo","user","getGithubInfoFromDeployment","github","commitResultStatusStrategies","diverged","behind","identical","productionBuildList","scanDeployment","resultList","errorList","error","commits","deploymentTarget","send","getGitCommits","commitsResult","deploymentName","logger","stack","message","compareBuildsResult","fileFilteringFunction","makeRequest","url","treeResult","truncated","files","commitToReturn","filename","filesChanged","query","baseInNewBases","hash","base","getFirstCommitInRepoSha","compareBuilds","relevantCommits","relevantFilesToDeployment","fileFilterer","regexWhiteList","createCommitFileMap","memoizedFileFilter","debug","status","hasOwnProperty","head","compareCommits","compareResult","__gitRepo"],"mappings":"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","file":"tool-teamcity-requests.js","sourcesContent":["import { isValidCommitRange } from './github-API';\nimport { accumulateAndThrow } from './error-accumulator';\nimport transformThrownToString from './error-conversion';\nimport {\n  FileFilterer,\n  getRegexWhitelist\n} from './file-filtering';\nimport _ from 'lodash';\n\n/*\n * Important variable names:\n *\n * Prefixes:\n * - head: The sha/build we wish to deploy (sha if no suffix)\n * - base: The sha/build we previously deployed (sha if no suffix)\n * - deployment: The build configuration we use to deploy\n *\n * Suffixes:\n * - BuildId: A TeamCity Build Id\n * - BuildTypeId: A TeamCity Build Configuration Id\n */\n\nasync function getMostRecentSuccessfulBuild({ name, deploymentBuildTypeId }, teamcity, env, robot) {\n  const dependencyIgnoreList = env.HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST\n    ? env.HUBOT_TEAMCITY_DEPENDENCY_BLACKLIST.split(',')\n    : [];\n\n  const response = await teamcity.fetchSuccessfulBuilds(deploymentBuildTypeId);\n  const successfulBuilds = response.build || [];\n\n  if (successfulBuilds.length < 1) {\n    const otherResponse = await teamcity.fetchBuildTypeInfo(deploymentBuildTypeId);\n    const otherBuilds = await teamcity.fetchSuccessfulBuilds(\n      otherResponse['artifact-dependencies']['artifact-dependency']\n      .filter(x => dependencyIgnoreList.indexOf(x['source-buildType'].id) === -1)\n      [0]['source-buildType'].id\n    );\n    const info = await teamcity.getGitInfo(\n      otherBuilds.build[0].id\n    );\n    return {\n      ...info,\n      firstTimeDeployment: true\n    };\n  }\n\n  const deploymentBuildId = successfulBuilds[0].id;\n\n  const deploymentBuildInfo = await teamcity.fetchBuildInfo(deploymentBuildId);\n\n  const artifactDependencies = deploymentBuildInfo['artifact-dependencies'];\n\n  if (!artifactDependencies || artifactDependencies.build.length === 0) {\n    throw new Error('The Production Deploy does not have any artifact dependencies.  Please ' +\n                    'ensure the Production Deploy buildType ' +\n                    `'${deploymentBuildInfo.buildType.name}' is actually ` +\n                    'a Deploy BuildType in teamcity.');\n  }\n\n  const dependencies = artifactDependencies.build\n    .filter(x => dependencyIgnoreList.indexOf(x.buildTypeId) === -1);\n\n  if (dependencies.length > 1) {\n    throw new Error(`Unable to find the CI build from '${deploymentBuildInfo.name}', ` +\n                    'ensure the deployment has the CI listed as an artifact dependency ' +\n                    'in TeamCity.');\n  }\n\n  return teamcity.getGitInfo(dependencies[0].id);\n}\n\nexport class CommitListPoller {\n  constructor(teamcity, github, robot, res, env = {}) {\n    this.teamcity = teamcity;\n    this.github = github;\n    this.robot = robot;\n    this.res = res;\n    this.env = env;\n    this.commitResultStatusStrategies = {\n      diverged: 'No range of commits exist, the production CI builds are diverged.',\n      behind: 'The commits for the build you are attempting to deploy are behind the ' +\n              'head of master. Are you trying to deploy an old build? Double check the CI ' +\n              'build # is correct in the Proposed Build(s) field on the deployment task.  ' +\n              '(The ability to roll-back a deployment has not been created yet.)',\n      identical: 'There is no discernable difference between the build you are deploying ' +\n                 'and the previous production build\\'s commits.  Were project dependencies ' +\n                 'the only thing updated in this deploy? Follow along at TW-7901'\n    };\n  }\n\n  async getCommitLists(productionBuildList, newBases = []) {\n    const resultList = await Promise.all(\n      productionBuildList.deployments.map(x => this.scanDeployment(x, newBases))\n    );\n\n    const errorList = resultList.filter(x => !x.result).map(x => x.error);\n    if (errorList.length > 0) {\n      accumulateAndThrow(errorList);\n    }\n\n    return resultList.map(x => x.commits);\n  }\n\n  async scanDeployment(deploymentTarget, newBases = []) {\n    try {\n      this.res.send(`Scanning changes for '${deploymentTarget.name}'`);\n\n      const commitsResult = await this.getGitCommits(deploymentTarget, newBases);\n\n      const result = {\n        deploymentName: deploymentTarget.name,\n        result: true,\n        commits: commitsResult.commits\n      };\n\n      this.res.send(`Successfully scanned '${deploymentTarget.name}'`);\n\n      return result;\n    } catch (err) {\n      this.robot.logger.error(err.stack);\n      return {\n        result: false,\n        error: `Error in Deployment: '${deploymentTarget.name}', ${err.message}`\n      };\n    }\n  }\n\n  async createCommitFileMap({\n    compareBuildsResult,\n    fileFilteringFunction\n  }) {\n    const commits = compareBuildsResult.commits;\n\n    const filesChanged = await Promise.all(commits.map(async x => {\n      const treeResult = await this.github.makeRequest(x.url);\n\n      if (treeResult.truncated) {\n        this.res.send(\n          `WARNING: Commit with sha: ${x.sha} is huge and cannot be adequately checked if it is ` +\n          'relevant or not.  Too many files were changed and github has truncated the results.  ' +\n          'Please check this commit\\'s files manually.'\n        );\n\n        return {\n          sha: x.sha,\n          files: []\n        };\n      }\n\n      const commitToReturn = {\n        sha: x.sha,\n        files: treeResult.files.map(y => y.filename).filter(y => fileFilteringFunction(y))\n      };\n      return commitToReturn;\n    }));\n\n    return filesChanged.filter(({ files = [] }) => files.length > 0).map(x => x.sha);\n  }\n\n  async getGitCommits(deploymentTarget, newBases = []) {\n    const query = await this.teamcity.getGitInfo(deploymentTarget.headBuildId);\n\n    const baseInNewBases = newBases.filter(x => x.hash === `${query.repo}|${query.user}`);\n    const base = (baseInNewBases.length === 1) ? baseInNewBases[0].base :\n      (await getMostRecentSuccessfulBuild(deploymentTarget, this.teamcity, this.env, this.robot));\n\n    if (base.headSha) {\n      base.sha = base.headSha;\n    }\n\n    if (base.firstTimeDeployment) {\n      this.res.send(`Scanning for first time deployment from ${query.repo}.`);\n      base.sha = await this.github.getFirstCommitInRepoSha({\n        repo: base.repo,\n        user: base.user\n      });\n    }\n\n    const result = await this.compareBuilds(query.sha, base.sha, base.user, base.repo);\n\n    let relevantCommits = [];\n\n    const relevantFilesToDeployment = await getRegexWhitelist({\n      githubAPI: this.github,\n      repo: base.repo,\n      user: base.user,\n      sha: query.sha,\n      buildType: deploymentTarget.deploymentBuildTypeId\n    }) || [];\n\n    if (relevantFilesToDeployment.length > 0) {\n      const fileFilterer = new FileFilterer({\n        regexWhiteList: relevantFilesToDeployment\n      });\n\n      relevantCommits = await this.createCommitFileMap({\n        compareBuildsResult: result,\n        fileFilteringFunction: (filename) => fileFilterer.memoizedFileFilter(filename)\n      });\n    }\n\n    this.robot.logger.debug(`Commits were in a ${result.status} status`);\n\n    if (isValidCommitRange(result.status)) {\n      if (relevantCommits.length <= 0) {\n        return result;\n      }\n\n      return {\n        ...result,\n        commits: result.commits.filter(({ sha }) => relevantCommits.indexOf(sha) > -1)\n      };\n    }\n\n    if (this.commitResultStatusStrategies.hasOwnProperty(result.status)) {\n      throw new Error(this.commitResultStatusStrategies[result.status]);\n    }\n\n    throw new Error('The commits were in some status we have not accounted for ' +\n                    `(${result.status}), please notify the maintainers of this deployment script.`);\n  }\n\n  async compareBuilds(head, base, user, repo) {\n    try {\n      this.robot.logger.debug(`Comparing commits ${base}...${head} in ${user}/${repo}`);\n      const compareResult = await this.github.compareCommits({ base, head, user, repo });\n\n      return {\n        status: compareResult.status,\n        commits: compareResult.commits.map(x => ({\n          ...x,\n          __gitRepo: repo\n        }))\n      };\n    } catch (err) {\n      if (err.message.indexOf('Not Found') > -1) {\n        if (this.robot) {\n          this.robot.logger.error(transformThrownToString(err, false));\n        }\n        throw new Error(`The Git Repository ${repo} is not linked properly in Teamcity.  ` +\n                        'Check to make sure the repository exists, and that the URL ' +\n                        'specified in the Teamcity CI Build is not a redirected URL.');\n      } else {\n        throw err;\n      }\n    }\n  }\n}\n\nexport async function getDeploymentCommitLists(options) {\n/*  productionBuildList,\n  teamCityAPI,\n  githubAPI,\n  hubotResponse,\n  hubotRobot,\n  newBases = []\n) { */\n  const poller = new CommitListPoller(\n    options.teamcityAPI,\n    options.githubAPI,\n    options.robot,\n    options.res,\n    process.env\n  );\n\n  return {\n    commitListsResult:\n      await poller.getCommitLists(options.parsedDeployments, options.newBases || [])\n  };\n}\n\nexport async function getGithubInfoFromDeployment(teamcityAPI, listOfDeployments = []) {\n  const memoizedArguments = {};\n\n  const consolidatedDeploymentList = _.flatMap(listOfDeployments, x =>\n    x.prodBuildField.deployments.map(y => ({ ...y, key: x.key })),\n  );\n\n  async function githubInfoMemoizeGate(deployment) {\n    const buildId = deployment.headBuildId;\n    if (memoizedArguments[buildId]) {\n      return memoizedArguments[buildId];\n    }\n\n    const result = await teamcityAPI.getGitInfo(buildId);\n    memoizedArguments[buildId] = result;\n    return result;\n  }\n\n  const githubInfo = consolidatedDeploymentList.map(async x => {\n    const result = await githubInfoMemoizeGate(x);\n    memoizedArguments[x.headBuildId] = result;\n    return result;\n  });\n\n  await Promise.all(githubInfo);\n\n  return consolidatedDeploymentList.map(x => ({\n    deployment: x,\n    headSha: memoizedArguments[x.headBuildId].sha,\n    repo: memoizedArguments[x.headBuildId].repo,\n    user: memoizedArguments[x.headBuildId].user\n  }));\n}\n"]} |
{ | ||
"name": "@twexchangesolutions/hubot-jira-deployment", | ||
"version": "0.14.0", | ||
"version": "0.15.0", | ||
"description": "Hook used to ensure that all issues being deployed to production meet audit requirements", | ||
@@ -5,0 +5,0 @@ "main": "lib/index.js", |
301345
3204