feat(metadata): implement MetadataRequest and supporting classes for file metadata extraction and response formatting

This commit is contained in:
buzz-lightsnack-2007 2025-04-21 21:34:08 +08:00
parent 72769a3ef4
commit 74fb118aa4
4 changed files with 126 additions and 0 deletions

View file

@ -0,0 +1,49 @@
/*
Modify data returned by "middle-man" scripts.
*/
const Parser = class {
constructor(DATA = {}, MAPPINGS = {}) {
this.data = DATA;
this.mappings = MAPPINGS;
}
/*
Modify the data for output.
@return {Object} cleaned data
*/
format () {
let ENTRIES;
/*
Map certain new keys to their original counterparts.
*/
function mapKeys (ORIGINAL = {}, MAPPINGS) {
let RESULT = {};
Object.entries(MAPPINGS).forEach(([NEW, OLD]) => {
RESULT[NEW] = (ORIGINAL[OLD] != null ? (typeof ORIGINAL[OLD]).includes(`str`) : false) ? ORIGINAL[OLD].trim() : ORIGINAL[OLD];
});
return RESULT;
}
if (this.data instanceof Array) {
ENTRIES = [];
(this.data.length) ? this.data.forEach((SELECTED) => {
if (SELECTED) {
let CLEANED = mapKeys(SELECTED, this.mappings);
(Object.keys(CLEANED).length) ? ENTRIES.push(CLEANED) : false;
};
}) : false;
} else if (this.data && this.data instanceof Object) {
ENTRIES = mapKeys(this.data, this.mappings);
};
this.cleaned = ENTRIES;
return (this.cleaned);
}
}
module.exports = Parser;

View file

@ -0,0 +1,18 @@
const Parser = require(`./parser`);
class SimpleMetadata extends Parser {
/*
Clean the log information.
@param {Object} ENTRY the selected entry, or the entries
*/
constructor(ENTRY) {
super(ENTRY, {
"name": "originalname",
"type": "mimetype",
"size": "size"
});
};
}
module.exports = SimpleMetadata;