git-stats/lib/index.js

79 lines
2 KiB
JavaScript
Raw Normal View History

2015-01-25 20:49:49 +01:00
// Dependencies
var FsExtra = require("fs-extra")
, Ul = require("ul")
2015-01-26 08:56:49 +01:00
, Moment = require("moment")
2015-01-25 20:49:49 +01:00
;
2015-01-25 20:54:02 +01:00
const STORE_PATH = Ul.USER_DIR + "/.git-stats";
2015-01-25 20:49:49 +01:00
// Constructor
var GitStats = module.exports = {};
2015-01-26 08:56:49 +01:00
/**
* record
* Records a new commit.
*
* @name record
* @function
* @param {Object} data The commit data containing:
*
* - `date` (String|Date): The date object or a string in this format: `DDD MMM dd HH:mm:ss YYYY`
* - `url` (String): The repository remote url.
* - `hash` (String): The commit hash.
*
* @param {Function} callback The callback function.
* @return {undefined}
*/
2015-01-25 20:54:02 +01:00
GitStats.record = function (data, callback) {
2015-01-26 08:58:03 +01:00
// Validate data
2015-01-26 08:56:49 +01:00
callback = callback || function (err) { if (err) throw err; };
data = Object(data);
if (typeof data.date === "string") {
2015-01-26 09:21:40 +01:00
data.date = Moment(data.date, "DDD MMM dd HH:mm:ss yyyy");
2015-01-26 08:56:49 +01:00
}
2015-01-26 09:21:40 +01:00
if (!data.date || !/^Moment|Date$/.test(data.date.constructor.name)) {
2015-01-26 08:56:49 +01:00
return callback(new Error("The date field should be a string or a date object."));
}
if (typeof data.hash !== "string" || !data.hash) {
return callback(new Error("Invalid hash."));
}
if (typeof data.url !== "string" || !data.url) {
return callback(new Error("Invalid url field."));
}
2015-01-26 08:58:03 +01:00
// Get stats
GitStats.get(function (err, stats) {
2015-01-25 20:54:02 +01:00
stats = stats || {};
2015-01-26 09:21:40 +01:00
var day = data.date.format("MMM DDD, YYYY")
2015-01-26 08:56:49 +01:00
, today = stats[day] = Object(stats[day])
, repo = today[data.url] = Object(today[data.url])
;
repo[data.hash] = { date: data.date };
2015-01-25 20:54:02 +01:00
FsExtra.writeJSON(STORE_PATH, stats, callback);
});
};
2015-01-26 09:05:46 +01:00
/**
* get
* Gets the git stats.
*
* @name get
* @function
* @param {Object} data The stats filter. **Not yet implemented**.
* @param {Function} callback The callback function.
* @return {undefined}
*/
2015-01-25 20:54:02 +01:00
GitStats.get = function (data, callback) {
if (typeof data === "function") {
callback = data;
data = {};
}
FsExtra.readJSON(STORE_PATH, callback);
2015-01-25 20:49:49 +01:00
};