Sync DNS2 production changes - removed obsolete test suite and refactored structure

This commit is contained in:
Krystie
2026-03-23 10:47:15 +01:00
parent 1ac50918ab
commit d76644d948
288 changed files with 8965 additions and 15731 deletions

View File

@@ -1,44 +1,50 @@
const express = require('express');
const asyncHandler = require('../src/utils/async-handler');
const { errorResponse } = require('../src/utils/responses');
module.exports = function({ licenseManager }) {
module.exports = function(ctx) {
const router = express.Router();
router.post('/activate', asyncHandler(async (req, res) => {
// Activate a license code
router.post('/activate', ctx.asyncHandler(async (req, res) => {
const { code } = req.body;
if (!code) {
return errorResponse(res, 400, 'License code is required');
return ctx.errorResponse(res, 400, 'License code is required');
}
const result = await licenseManager.activate(code);
const result = await ctx.licenseManager.activate(code);
if (result.success) {
res.json({ success: true, message: result.message, license: result.activation });
res.json({
success: true,
message: result.message,
license: result.activation
});
} else {
errorResponse(res, 400, result.message);
ctx.errorResponse(res, 400, result.message);
}
}, 'license-activate'));
router.get('/status', asyncHandler(async (req, res) => {
const status = licenseManager.getStatus();
// Get current license status
router.get('/status', ctx.asyncHandler(async (req, res) => {
const status = ctx.licenseManager.getStatus();
res.json({ success: true, license: status });
}, 'license-status'));
router.post('/deactivate', asyncHandler(async (req, res) => {
const result = await licenseManager.deactivate();
// Deactivate current license
router.post('/deactivate', ctx.asyncHandler(async (req, res) => {
const result = await ctx.licenseManager.deactivate();
if (result.success) {
res.json({ success: true, message: result.message });
} else {
errorResponse(res, 400, result.message);
ctx.errorResponse(res, 400, result.message);
}
}, 'license-deactivate'));
router.get('/feature/:feature', asyncHandler(async (req, res) => {
// Check if a specific feature is available (lightweight check for frontend)
router.get('/feature/:feature', ctx.asyncHandler(async (req, res) => {
const { feature } = req.params;
const available = licenseManager.hasFeature(feature);
const status = licenseManager.getStatus();
const available = ctx.licenseManager.hasFeature(feature);
const status = ctx.licenseManager.getStatus();
res.json({
success: true,
@@ -47,8 +53,8 @@ module.exports = function({ licenseManager }) {
tier: status.tier,
...(available ? {} : {
upgradeUrl: '/settings#license',
message: `${status.premiumFeatures[feature]?.name || feature} requires DashCaddy Premium`,
}),
message: `${status.premiumFeatures[feature]?.name || feature} requires DashCaddy Premium`
})
});
}, 'license-feature-check'));