Files
dashcaddy/dashcaddy-api/routes/license.js
Krystie b172a21b63 Migrate 25 route files to throw-based error handling
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
2026-03-29 18:53:03 -07:00

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;
};