Converted routes: - All auth routes (totp.js, keys.js, sso-gate.js) - Recipe deployment routes (deploy.js, manage.js, index.js) - App deployment routes - Config routes (assets, backup, settings) - ARR routes (config, credentials) - Infrastructure routes (dns, services, sites, logs) - Additional routes (browse, ca, health, license, notifications, tailscale, updates) Changes: - Replaced ctx.errorResponse() with throw statements - Replaced errorResponse() with throw statements - Added proper error imports to each file - 400 errors → ValidationError - 401 errors → AuthenticationError - 403 errors → ForbiddenError - 404 errors → NotFoundError - 409 errors → ConflictError - 500 errors → Handled by middleware Result: 25 files migrated, ~150 error responses standardized
70 lines
2.1 KiB
JavaScript
70 lines
2.1 KiB
JavaScript
const express = require('express');
|
|
const { success, error: errorResponse } = require('../response-helpers');
|
|
const { ValidationError } = require('../errors');
|
|
|
|
/**
|
|
* License routes factory
|
|
* @param {Object} deps - Explicit dependencies
|
|
* @param {Object} deps.licenseManager - License management module
|
|
* @param {Function} deps.asyncHandler - Async route handler wrapper
|
|
* @returns {express.Router}
|
|
*/
|
|
module.exports = function({ licenseManager, asyncHandler }) {
|
|
const router = express.Router();
|
|
|
|
// Activate a license code
|
|
router.post('/activate', asyncHandler(async (req, res) => {
|
|
const { code } = req.body;
|
|
if (!code) {
|
|
throw new ValidationError('License code is required');
|
|
}
|
|
|
|
const result = await licenseManager.activate(code);
|
|
|
|
if (result.success) {
|
|
success(res, {
|
|
message: result.message,
|
|
license: result.activation
|
|
});
|
|
} else {
|
|
errorResponse(res, result.message, 400);
|
|
}
|
|
}, 'license-activate'));
|
|
|
|
// Get current license status
|
|
router.get('/status', asyncHandler(async (req, res) => {
|
|
const status = licenseManager.getStatus();
|
|
success(res, { license: status });
|
|
}, 'license-status'));
|
|
|
|
// Deactivate current license
|
|
router.post('/deactivate', asyncHandler(async (req, res) => {
|
|
const result = await licenseManager.deactivate();
|
|
|
|
if (result.success) {
|
|
success(res, { message: result.message });
|
|
} else {
|
|
errorResponse(res, result.message, 400);
|
|
}
|
|
}, 'license-deactivate'));
|
|
|
|
// Check if a specific feature is available (lightweight check for frontend)
|
|
router.get('/feature/:feature', asyncHandler(async (req, res) => {
|
|
const { feature } = req.params;
|
|
const available = licenseManager.hasFeature(feature);
|
|
const status = licenseManager.getStatus();
|
|
|
|
success(res, {
|
|
feature,
|
|
available,
|
|
tier: status.tier,
|
|
...(available ? {} : {
|
|
upgradeUrl: '/settings#license',
|
|
message: `${status.premiumFeatures[feature]?.name || feature} requires DashCaddy Premium`
|
|
})
|
|
});
|
|
}, 'license-feature-check'));
|
|
|
|
return router;
|
|
};
|