- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
47 lines
1.3 KiB
JavaScript
47 lines
1.3 KiB
JavaScript
/**
|
|
* @fileoverview Module for loading rules from files and directories.
|
|
* @author Michael Ficarra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Requirements
|
|
//------------------------------------------------------------------------------
|
|
|
|
const fs = require("node:fs"),
|
|
path = require("node:path");
|
|
|
|
const rulesDirCache = {};
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Public Interface
|
|
//------------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Load all rule modules from specified directory.
|
|
* @param {string} relativeRulesDir Path to rules directory, may be relative.
|
|
* @param {string} cwd Current working directory
|
|
* @returns {Object} Loaded rule modules.
|
|
*/
|
|
module.exports = function (relativeRulesDir, cwd) {
|
|
const rulesDir = path.resolve(cwd, relativeRulesDir);
|
|
|
|
// cache will help performance as IO operation are expensive
|
|
if (rulesDirCache[rulesDir]) {
|
|
return rulesDirCache[rulesDir];
|
|
}
|
|
|
|
const rules = Object.create(null);
|
|
|
|
fs.readdirSync(rulesDir).forEach(file => {
|
|
if (path.extname(file) !== ".js") {
|
|
return;
|
|
}
|
|
rules[file.slice(0, -3)] = require(path.join(rulesDir, file));
|
|
});
|
|
rulesDirCache[rulesDir] = rules;
|
|
|
|
return rules;
|
|
};
|