Major structural reorganization and feature additions: ## Folder Reorganization - Move 17 luci-app-* packages to package/secubox/ (except luci-app-secubox core hub) - Update all tooling to support new structure: - secubox-tools/quick-deploy.sh: search both locations - secubox-tools/validate-modules.sh: validate both directories - secubox-tools/fix-permissions.sh: fix permissions in both locations - .github/workflows/test-validate.yml: build from both paths - Update README.md links to new package/secubox/ paths ## AppStore Migration (Complete) - Add catalog entries for all remaining luci-app packages: - network-tweaks.json: Network optimization tools - secubox-bonus.json: Documentation & demos hub - Total: 24 apps in AppStore catalog (22 existing + 2 new) - New category: 'documentation' for docs/demos/tutorials ## VHost Manager v2.0 Enhancements - Add profile activation system for Internal Services and Redirects - Implement createVHost() API wrapper for template-based deployment - Fix Virtual Hosts view rendering with proper LuCI patterns - Fix RPCD backend shell script errors (remove invalid local declarations) - Extend backend validation for nginx return directives (redirect support) - Add section_id parameter for named VHost profiles - Add Remove button to Redirects page for feature parity - Update README to v2.0 with comprehensive feature documentation ## Network Tweaks Dashboard - Close button added to component details modal Files changed: 340+ (336 renames with preserved git history) Packages affected: 19 luci-app, 2 secubox-app, 1 theme, 4 tools 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
104 lines
2.1 KiB
JavaScript
104 lines
2.1 KiB
JavaScript
'use strict';
|
|
'require baseclass';
|
|
'require rpc';
|
|
|
|
/**
|
|
* Netifyd Dashboard API
|
|
* Package: luci-app-netifyd-dashboard
|
|
* RPCD object: luci.netifyd-dashboard
|
|
*/
|
|
|
|
// Version: 0.4.0
|
|
|
|
var callStatus = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'status',
|
|
expect: { }
|
|
});
|
|
|
|
var callFlows = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'flows',
|
|
expect: { flows: [] }
|
|
});
|
|
|
|
var callApplications = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'applications',
|
|
expect: { applications: [] }
|
|
});
|
|
|
|
var callHosts = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'hosts',
|
|
expect: { hosts: [] }
|
|
});
|
|
|
|
var callProtocols = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'protocols',
|
|
expect: { protocols: [] }
|
|
});
|
|
|
|
var callDevices = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'devices',
|
|
expect: { devices: [] }
|
|
});
|
|
|
|
var callStats = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'stats',
|
|
expect: { }
|
|
});
|
|
|
|
var callSecuboxLogs = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'seccubox_logs',
|
|
expect: { }
|
|
});
|
|
|
|
var callCollectDebug = rpc.declare({
|
|
object: 'luci.netifyd-dashboard',
|
|
method: 'collect_debug',
|
|
expect: { success: false }
|
|
});
|
|
|
|
function formatBytes(bytes) {
|
|
if (bytes === 0) return '0 B';
|
|
var k = 1024;
|
|
var sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
|
|
var i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
return parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i];
|
|
}
|
|
|
|
return baseclass.extend({
|
|
getStatus: callStatus,
|
|
getFlows: callFlows,
|
|
getApplications: callApplications,
|
|
getHosts: callHosts,
|
|
getProtocols: callProtocols,
|
|
getDevices: callDevices,
|
|
getStats: callStats,
|
|
getSecuboxLogs: callSecuboxLogs,
|
|
collectDebugSnapshot: callCollectDebug,
|
|
formatBytes: formatBytes,
|
|
|
|
// Aggregate function for overview page
|
|
getAllData: function() {
|
|
return Promise.all([
|
|
callStatus(),
|
|
callStats(),
|
|
callFlows(),
|
|
callApplications()
|
|
]).then(function(results) {
|
|
return {
|
|
status: results[0] || {},
|
|
stats: results[1] || {},
|
|
flows: results[2] || { flows: [] },
|
|
applications: results[3] || { applications: [] }
|
|
};
|
|
});
|
|
}
|
|
});
|