SM2Gen/Targets/DiskUsage/DiskUsage.pm

246 lines
6.9 KiB
Perl
Raw Normal View History

package SrvMngr::Controller::DiskUsage;
2024-04-28 13:03:06 +02:00
#
# Generated by version:SM2Gen version:0.8 Chameleon version:4.5.4 On Python:3.12.3 at 2024-09-15 11:51
2024-04-28 13:03:06 +02:00
#
2024-04-09 11:36:36 +02:00
#----------------------------------------------------------------------
# heading : Miscellaneous
# description : Disk Usage
2024-04-09 11:36:36 +02:00
# navigation : 2000 400
#
# name : diskusage, method : get, url : /diskusage, ctlact : DiskUsage#main
# name : diskusageu, method : post, url : /diskusageu, ctlact : DiskUsage#do_update
# name : diskusaged, method : get, url : /diskusaged, ctlact : DiskUsage#do_display
2024-04-09 11:36:36 +02:00
#
# routes : end
#
# Documentation: https://wiki.contribs.org/DiskUsage
2024-04-09 11:36:36 +02:00
#----------------------------------------------------------------------
#
# Scheme of things:
#
2024-04-28 13:03:06 +02:00
# TBA!!
2024-04-09 11:36:36 +02:00
use strict;
use warnings;
use Mojo::Base 'Mojolicious::Controller';
use constant FALSE => 0;
use constant TRUE => 1;
use Locale::gettext;
use SrvMngr::I18N;
use SrvMngr qw(theme_list init_session);
use Data::Dumper;
use esmith::util;
use esmith::HostsDB;
use esmith::AccountsDB;
use esmith::NetworksDB;
use esmith::HostsDB;
use esmith::DomainsDB;
#The most common ones
2024-04-24 17:09:23 +02:00
our $cdb = esmith::ConfigDB->open() || die("Couldn't open config db");
2024-04-09 11:36:36 +02:00
our $adb = esmith::AccountsDB->open() || die("Couldn't open Accounts db");
our $ndb = esmith::NetworksDB->open() || die("Couldn't open Network db");
2024-04-24 17:09:23 +02:00
our $hdb = esmith::HostsDB->open() || die("Couldn't open Hosts db");
our $ddb = esmith::DomainsDB->open() || die("Couldn't open Domains db");
2024-04-09 11:36:36 +02:00
require '/usr/share/smanager/lib/SrvMngr/Controller/DiskUsage-Custom.pm'; #The code that is to be added by the developer
2024-04-09 11:36:36 +02:00
sub main {
2024-04-28 13:03:06 +02:00
#
# Initial entry - route is "/<whatever>"
#
#set initial panel
#for initial panel:
#Specifiy panel to enter
#load up _data hash with DB fields
#load up stash with pointer(s) to control fields hash(= get-))
#and a pointer to the prefix_data hash
#render initial panel
2024-04-09 11:36:36 +02:00
my $c = shift;
$c->app->log->info( $c->log_req );
my %du_data = ();
my $title = $c->l('du_Disk_Usage');
2024-04-09 11:36:36 +02:00
my $modul = '';
$du_data{'trt'} = 'PARAMS';
2024-04-24 17:09:23 +02:00
#Load any DB entries into the <prefix>_data area so as they are preset in the form
2024-04-28 13:03:06 +02:00
# which DB - this only really works if the initial panel is a PARAMS type panel and not a TABLE
my $db = $cdb; #pickup local or global db or Default to config
2024-04-24 17:09:23 +02:00
2024-04-09 11:36:36 +02:00
# and table control fields
$c->stash(Table1=>$c->get_Table1());
$c->stash(Table2=>$c->get_Table2());
2024-04-09 11:36:36 +02:00
$c->stash(
title => $title,
modul => $modul,
du_data => \%du_data
2024-04-09 11:36:36 +02:00
);
$c->render( template => "diskusage" );
2024-04-09 11:36:36 +02:00
}
2024-05-06 11:05:43 +02:00
# Post request with params - submit from the form
2024-04-09 11:36:36 +02:00
sub do_update {
2024-04-28 13:03:06 +02:00
#
# Return after submit pushed on panel (this is a post) - route is "/<whatever>u"
# parameters in the params hash.
#
#load up all params into prefix_data hash:
#By panel (series of if statements - only one executed):
#call validate-PANEL() - return ret = ok or error message
#if validation not ok:
#render back to current panel with error message in stash
#otherwise:
#By panel (series of if statements - only one executed):
#do whatever is required: call perform-PANEL() - return "ok" or Error Message
#call signal-event for any global actions specified (check it exists - error and continue?)
#if action smeserver-<whatever>-update exists
#signal_event smeserver-<whatever>-update
#call signal-event for any specific actions for thids panel (check it exists first - error and continue)
#set success in stash
#if no "nextpanel" entry:
#set firstpanel
#else
#set nextpanel
#call render
2024-04-09 11:36:36 +02:00
my $c = shift;
$c->app->log->info($c->log_req);
my %du_data = ();
my $title = $c->l('du_Disk_Usage');
2024-04-09 11:36:36 +02:00
# Accessing all POST parameters
my %params = $c->req->params->to_hash;
# Get number of POST parameters
my $num_params = keys %params;
2024-04-28 13:03:06 +02:00
#Params are available in the hash "params" - copy to the prefix_data hash
while (my ($key, $value) = each %{$c->req->params->to_hash}) {
$du_data{$key} = $value;
2024-04-09 11:36:36 +02:00
}
# the value of trt will tell you which panel has returned
my $trt = $c->param('trt') || 'PARAMS'; #hidden control on every form.
2024-04-09 11:36:36 +02:00
my $ret = 'ok';
2024-04-28 13:03:06 +02:00
#Validate the parameters in a custom sub one for each panel (although only one of these will be executed)
my $thispanel;
2024-04-09 11:36:36 +02:00
if ($trt eq 'PARAMS'){
#Validate form parameters for panel PARAMS
$ret = $c->validate_PARAMS(\%du_data);
$thispanel = 'PARAMS';
}
2024-04-09 11:36:36 +02:00
2024-04-28 13:03:06 +02:00
if ($ret ne "ok") {
# return to the panel with error message
$c->stash(error => $c->l($ret));
$c->render("diskusage");
2024-04-28 13:03:06 +02:00
} else {
#Do whatever is needed, including writing values to the DB
2024-04-28 13:03:06 +02:00
if ($trt eq 'PARAMS'){
#do whatever is required ...
$ret = $c->perform_PARAMS(\%du_data);
2024-04-28 13:03:06 +02:00
if ($ret ne "ok") {
# return to the panel with error message
$c->stash(error => $c->l($ret));
$c->render("diskusage");
2024-04-28 13:03:06 +02:00
} else {
$c->stash( success => $c->l('du_PARAMS_panel_action_was_successful')); #A bit bland - edit it in the lex file
2024-04-28 13:03:06 +02:00
}
}
# and call any signal-events needed
# Setup shared data and call panel
$c->stash(
title => $title,
du_data => \%du_data
);
2024-04-28 13:03:06 +02:00
if ('none' eq 'none') {
$du_data{'trt'} = 'PARAMS';
2024-04-28 13:03:06 +02:00
} else {
$du_data{'trt'} = 'none';
2024-04-28 13:03:06 +02:00
}
$c->render("diskusage");
2024-04-28 13:03:06 +02:00
}
2024-04-09 11:36:36 +02:00
}
2024-04-28 13:03:06 +02:00
sub do_display {
#
# Return after link clicked in table (this is a get) - route is "/<whatever>d"
2024-05-06 11:05:43 +02:00
# Expects ?trt=PANEL&selected="TableRowName" plus any other required
#
# OR it maybe a post from the main panel to add a new record
2024-04-28 13:03:06 +02:00
#
#load up all supplied params into prefix_data hash
#call get-selected-PANEL() - returns hash of all relevent parameters
#load up returned hash into prefix_data
#render - to called panel
my $c = shift;
$c->app->log->info($c->log_req);
my %du_data = ();
my $title = $c->l('du_Disk_Usage');
2024-04-28 13:03:06 +02:00
2024-05-06 11:05:43 +02:00
# Accessing all parameters
2024-04-28 13:03:06 +02:00
my %params = $c->req->params->to_hash;
2024-05-06 11:05:43 +02:00
# Get number of parameters
2024-04-28 13:03:06 +02:00
my $num_params = keys %params;
2024-05-06 11:05:43 +02:00
#Tag as Post or Get (ie. create new entry or edit existing one
my $is_new_record = ($c->req->method() eq 'POST');
2024-04-28 13:03:06 +02:00
#Params are available in the hash "params" - copy to the prefix_data hash
while (my ($key, $value) = each %{$c->req->params->to_hash}) {
$du_data{$key} = $value;
2024-04-28 13:03:06 +02:00
}
# the value of trt will tell you which panel has returned
my $trt = $c->param('trt') || 'PARAMS'; #Indicates where to go now
2024-04-28 13:03:06 +02:00
# Now add in the params from the selected row from the table
2024-05-06 11:05:43 +02:00
2024-04-28 13:03:06 +02:00
my %selectedrow;
if ($trt eq 'PARAMS'){
#Validate form parameters for panel PARAMS
%selectedrow = $c->get_selected_PARAMS($du_data{'Selected'},$is_new_record);
2024-04-28 13:03:06 +02:00
}
#Copy in the selected row params to the prefix_data hash to pass to the panel
while (my ($key, $value) = each %selectedrow){
$du_data{$key} = $value;
2024-04-28 13:03:06 +02:00
}
# Where to go now
$du_data{'trt'} = $trt;
2024-04-28 13:03:06 +02:00
# Data for panel
$c->stash(
title => $title,
du_data => \%du_data
2024-04-28 13:03:06 +02:00
);
$c->render("diskusage");
2024-04-28 13:03:06 +02:00
}
2024-04-09 11:36:36 +02:00
1;