Compare commits

...

12 Commits

Author SHA1 Message Date
John Crisp
305e7b75d2 Update email templates, mai_data, button sizes, numerous tweaks 2025-07-06 13:37:49 +02:00
John Crisp
b5b7645ebc add email setting partials 2025-07-06 13:35:27 +02:00
John Crisp
cd31fcfc5b 11.0.0-42 Finish Software updater 2025-06-26 16:08:15 +02:00
John Crisp
4204273b79 11.0.0-42.sme Update Nut Letsenc Datetime 2025-06-19 17:58:31 +02:00
John Crisp
4d47e099a6 11.0.0-40.sme 2025-06-18 15:44:15 +02:00
John Crisp
9e05c8df28 Update Letsencrypt templates 2025-06-18 15:42:51 +02:00
John Crisp
625855f87e Fix typo in css file 2025-06-18 15:42:19 +02:00
John Crisp
37361c8c3f Fix typo in _usr files 2025-06-18 15:40:41 +02:00
John Crisp
322d3b7038 Start Letsencrypt panels 2025-06-17 15:33:22 +02:00
John Crisp
1baec827d3 11.0.0-38.sme More formatting 2025-06-13 19:55:48 +02:00
John Crisp
2d6deb9b37 More formatting with PortForwards 2025-06-13 19:54:20 +02:00
John Crisp
f547a5300d More formatting with LocalNetworks 2025-06-13 19:49:28 +02:00
101 changed files with 1992 additions and 2032 deletions

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,12 @@
function spinner() {
const spinnerDisplayer = document.querySelector('.spinner-displayer');
const btn = document.getElementById('btn');
btn.addEventListener('click', () => {
spinnerDisplayer.classList.add('loading');
})
}
spinner();
// <div class='spinner-displayer'></div>

View File

@@ -1,302 +0,0 @@
document.addEventListener('DOMContentLoaded', () => {
const flagContainer = document.getElementById('flag-container');
// Mapping of language codes to country codes and their names
const languageToCountryMap = {
"af": { code: "NA", name: "Namibia" },
"agq": { code: "CM", name: "Cameroon" },
"ak": { code: "GH", name: "Ghana" },
"am": { code: "ET", name: "Ethiopia" },
"ar": { code: "SA", name: "Saudi Arabia" },
"as": { code: "IN", name: "India" },
"asa": { code: "TZ", name: "Tanzania" },
"ast": { code: "ES", name: "Spain" },
"az": { code: "AZ", name: "Azerbaijan" },
"bas": { code: "CM", name: "Cameroon" },
"be": { code: "BY", name: "Belarus" },
"bem": { code: "ZM", name: "Zambia" },
"bez": { code: "TZ", name: "Tanzania" },
"bg": { code: "BG", name: "Bulgaria" },
"bm": { code: "ML", name: "Mali" },
"bn": { code: "BD", name: "Bangladesh" },
"bo": { code: "CN", name: "China" },
"br": { code: "FR", name: "France" },
"brx": { code: "IN", name: "India" },
"bs": { code: "BA", name: "Bosnia and Herzegovina" },
"ca": { code: "AD", name: "Andorra" },
"ccp": { code: "BD", name: "Bangladesh" },
"ce": { code: "RU", name: "Russia" },
"cgg": { code: "UG", name: "Uganda" },
"chr": { code: "US", name: "United States" },
"ckb": { code: "IQ", name: "Iraq" },
"cs": { code: "CZ", name: "Czech Republic" },
"cy": { code: "GB", name: "United Kingdom" },
"da": { code: "DK", name: "Denmark" },
"dav": { code: "KE", name: "Kenya" },
"de": { code: "DE", name: "Germany" },
"dje": { code: "NE", name: "Niger" },
"dsb": { code: "DE", name: "Germany" },
"dua": { code: "CM", name: "Cameroon" },
"dyo": { code: "SN", name: "Senegal" },
"dz": { code: "BT", name: "Bhutan" },
"ebu": { code: "KE", name: "Kenya" },
"ee": { code: "GH", name: "Ghana" },
"el": { code: "CY", name: "Cyprus" },
"en": { code: "US", name: "United States" }, // Assume US for English if unspecified
"es": { code: "ES", name: "Spain" },
"et": { code: "EE", name: "Estonia" },
"eu": { code: "ES", name: "Spain" },
"ewo": { code: "CM", name: "Cameroon" },
"fa": { code: "AF", name: "Afghanistan" },
"ff": { code: "CM", name: "Cameroon" },
"fi": { code: "FI", name: "Finland" },
"fil": { code: "PH", name: "Philippines" },
"fo": { code: "FO", name: "Faroe Islands" },
"fr": { code: "FR", name: "France" },
"fur": { code: "IT", name: "Italy" },
"fy": { code: "NL", name: "Netherlands" },
"ga": { code: "IE", name: "Ireland" },
"gd": { code: "GB", name: "United Kingdom" },
"gl": { code: "ES", name: "Spain" },
"gsw": { code: "CH", name: "Switzerland" },
"gu": { code: "IN", name: "India" },
"guz": { code: "KE", name: "Kenya" },
"gv": { code: "IM", name: "Isle of Man" },
"ha": { code: "GH", name: "Ghana" },
"haw": { code: "US", name: "United States" },
"he": { code: "IL", name: "Israel" },
"hi": { code: "IN", name: "India" },
"hr": { code: "HR", name: "Croatia" },
"hsb": { code: "DE", name: "Germany" },
"hu": { code: "HU", name: "Hungary" },
"hy": { code: "AM", name: "Armenia" },
"id": { code: "ID", name: "Indonesia" },
"ig": { code: "NG", name: "Nigeria" },
"ii": { code: "CN", name: "China" },
"is": { code: "IS", name: "Iceland" },
"it": { code: "IT", name: "Italy" },
"ja": { code: "JP", name: "Japan" },
"jgo": { code: "CM", name: "Cameroon" },
"jmc": { code: "TZ", name: "Tanzania" },
"ka": { code: "GE", name: "Georgia" },
"kab": { code: "DZ", name: "Algeria" },
"kam": { code: "KE", name: "Kenya" },
"kde": { code: "TZ", name: "Tanzania" },
"kea": { code: "CV", name: "Cabo Verde" },
"khq": { code: "ML", name: "Mali" },
"ki": { code: "KE", name: "Kenya" },
"kk": { code: "KZ", name: "Kazakhstan" },
"kkj": { code: "CM", name: "Cameroon" },
"kl": { code: "GL", name: "Greenland" },
"kln": { code: "KE", name: "Kenya" },
"km": { code: "KH", name: "Cambodia" },
"kn": { code: "IN", name: "India" },
"ko": { code: "KP", name: "North Korea" },
"kok": { code: "IN", name: "India" },
"ks": { code: "IN", name: "India" },
"ksb": { code: "TZ", name: "Tanzania" },
"ksf": { code: "CM", name: "Cameroon" },
"ksh": { code: "DE", name: "Germany" },
"kw": { code: "GB", name: "United Kingdom" },
"ky": { code: "KG", name: "Kyrgyzstan" },
"lag": { code: "TZ", name: "Tanzania" },
"lb": { code: "LU", name: "Luxembourg" },
"lg": { code: "UG", name: "Uganda" },
"lkt": { code: "US", name: "United States" },
"ln": { code: "AO", name: "Angola" },
"lo": { code: "LA", name: "Laos" },
"lrc": { code: "IQ", name: "Iraq" },
"lt": { code: "LT", name: "Lithuania" },
"lu": { code: "CD", name: "Democratic Republic of the Congo" },
"luo": { code: "KE", name: "Kenya" },
"Luo": { code: "KE", name: "Kenya" },
"luy": { code: "KE", name: "Kenya" },
"lv": { code: "LV", name: "Latvia" },
"mas": { code: "KE", name: "Kenya" },
"mer": { code: "KE", name: "Kenya" },
"mfe": { code: "MU", name: "Mauritius" },
"mg": { code: "MG", name: "Madagascar" },
"mgh": { code: "MZ", name: "Mozambique" },
"mgo": { code: "CM", name: "Cameroon" },
"mk": { code: "MK", name: "North Macedonia" },
"ml": { code: "IN", name: "India" },
"mn": { code: "MN", name: "Mongolia" },
"mr": { code: "IN", name: "India" },
"ms": { code: "BN", name: "Brunei" },
"mt": { code: "MT", name: "Malta" },
"mua": { code: "CM", name: "Cameroon" },
"my": { code: "MM", name: "Myanmar" },
"mzn": { code: "IR", name: "Iran" },
"naq": { code: "NA", name: "Namibia" },
"nb": { code: "NO", name: "Norway" },
"nd": { code: "ZW", name: "Zimbabwe" },
"nds": { code: "DE", name: "Germany" },
"ne": { code: "IN", name: "India" },
"nl": { code: "NL", name: "Netherlands" },
"nmg": { code: "CM", name: "Cameroon" },
"nn": { code: "NO", name: "Norway" },
"nnh": { code: "CM", name: "Cameroon" },
"nus": { code: "SS", name: "South Sudan" },
"nyn": { code: "UG", name: "Uganda" },
"om": { code: "ET", name: "Ethiopia" },
"or": { code: "IN", name: "India" },
"os": { code: "GE", name: "Georgia" },
"pa": { code: "PK", name: "Pakistan" },
"pl": { code: "PL", name: "Poland" },
"ps": { code: "AF", name: "Afghanistan" },
"pt": { code: "PT", name: "Portugal" },
"qu": { code: "BO", name: "Bolivia" },
"rm": { code: "CH", name: "Switzerland" },
"rn": { code: "BI", name: "Burundi" },
"ro": { code: "RO", name: "Romania" },
"rof": { code: "TZ", name: "Tanzania" },
"ru": { code: "RU", name: "Russia" },
"rw": { code: "RW", name: "Rwanda" },
"rwk": { code: "TZ", name: "Tanzania" },
"sah": { code: "RU", name: "Russia" },
"saq": { code: "KE", name: "Kenya" },
"sbp": { code: "TZ", name: "Tanzania" },
"se": { code: "SE", name: "Sweden" },
"seh": { code: "MZ", name: "Mozambique" },
"ses": { code: "ML", name: "Mali" },
"sg": { code: "CF", name: "Central African Republic" },
"shi": { code: "TN", name: "Tunisia" },
"si": { code: "LK", name: "Sri Lanka" },
"sk": { code: "SK", name: "Slovakia" },
"sl": { code: "SI", name: "Slovenia" },
"smn": { code: "FI", name: "Finland" },
"sn": { code: "ZW", name: "Zimbabwe" },
"so": { code: "SO", name: "Somalia" },
"sq": { code: "AL", name: "Albania" },
"sr": { code: "RS", name: "Serbia" },
"sv": { code: "SE", name: "Sweden" },
"sw": { code: "CD", name: "Democratic Republic of the Congo" },
"ta": { code: "IN", name: "India" },
"te": { code: "IN", name: "India" },
"teo": { code: "KE", name: "Kenya" },
"tg": { code: "TJ", name: "Tajikistan" },
"th": { code: "TH", name: "Thailand" },
"ti": { code: "ER", name: "Eritrea" },
"to": { code: "TO", name: "Tonga" },
"tr": { code: "TR", name: "Turkey" },
"tt": { code: "RU", name: "Russia" },
"twq": { code: "NE", name: "Niger" },
"tzm": { code: "MA", name: "Morocco" },
"ug": { code: "CN", name: "China" },
"uk": { code: "UA", name: "Ukraine" },
"ur": { code: "IN", name: "India" },
"uz": { code: "UZ", name: "Uzbekistan" },
"vai": { code: "TN", name: "Tunisia" },
"Vai": { code: "TN", name: "Tunisia" },
"vi": { code: "VN", name: "Vietnam" },
"vun": { code: "TZ", name: "Tanzania" },
"wae": { code: "CH", name: "Switzerland" },
"wo": { code: "SN", name: "Senegal" },
"xog": { code: "UG", name: "Uganda" },
"yav": { code: "CM", name: "Cameroon" },
"yi": { code: "01", name: "Unknown" }, // Placeholder for unspecified region
"yo": { code: "BJ", name: "Benin" },
"yue": { code: "CN", name: "China" },
"zgh": { code: "MA", name: "Morocco" },
"zh": { code: "CN", name: "China" },
"zu": { code: "ZA", name: "South Africa" },
};
//async function getCountryName(countryCode) {
//try {
//const response = await fetch(`https://restcountries.com/v3.1/alpha/${countryCode}`);
//if (!response.ok) throw new Error('Country not found');
//const data = await response.json();
//// Return the name in the native language
//return data[0].name.common;
//} catch (error) {
//console.error(error);
//return 'Unknown Country';
//}
//}
function getCountryNameFromLanguage(language) {
return languageToCountryMap[language] ? languageToCountryMap[language].name : null;
}
function getCountryCodeFromLanguage(language) {
return languageToCountryMap[language] ? languageToCountryMap[language].code : null;
}
function getCountryNameFromCountryCode(countryCode) {
//alert(`Country code: ${countryCode}`);
for (const language in languageToCountryMap) {
if (languageToCountryMap.hasOwnProperty(language)) {
if (languageToCountryMap[language].code === countryCode) {
return languageToCountryMap[language].name;
}
}
}
return null; // Return null if country code not found
}
function getFlagEmoji(locale) {
// Split the locale to get the language and country code
const parts = locale.split('-');
let countryCode;
// Handle single subtag (language only) or double subtag (language-country)
if (parts.length === 1) {
countryCode = getCountryCodeFromLanguage(parts[0]);
} else if (parts.length === 2) {
countryCode = parts[1].toLowerCase(); // Use the country code
}
// If country code is not found, set a fallback output
if (!countryCode) {
const fallback = `? ${locale.toUpperCase()}`; // Just a question mark and the full locale
return { flag: fallback, isUnknown: true, countryName: 'Unknown Country' };
}
// Convert the country code to a flag emoji
return {
flag: String.fromCodePoint(...[...countryCode.toUpperCase()].map(char => 0x1F1E6 + char.charCodeAt(0) - 'A'.charCodeAt(0))),
isUnknown: false,
countryCode: countryCode
};
}
function displayLocaleAndFlag() {
// Get the browser locale
const userLocale = navigator.languages && navigator.languages.length
? navigator.languages[0]
: navigator.language;
//alert(`User Locale: ${userLocale}`); // Alert the detected locale
//console.log(navigator.languages); // Log language to console
const { flag, isUnknown, countryCode } = getFlagEmoji(userLocale);
//alert(`Country Code: ${countryCode}, Is Unknown: ${isUnknown}`); // Debug country code and unknown flag status
// Display the locale and the corresponding flag (or fallback)
//document.getElementById('locale').textContent = `Your Locale: ${userLocale}`;
if (isUnknown) {
const fallbackDiv = document.createElement('div');
fallbackDiv.className = 'fallback-box';
fallbackDiv.textContent = `? ${userLocale.toUpperCase()}`; // Show ? and locale code inside the box
document.getElementById('flag-container').appendChild(fallbackDiv);
// Tooltip for fallback
fallbackDiv.title = "Unknown Country"; // Tooltip for fallback
//alert('Fallback triggered: Unknown Country'); // Debug fallback
} else {
const countryName = getCountryNameFromCountryCode(countryCode.toUpperCase());
//alert(`Country Name from Country Code: ${countryName}`); // Alert the country name
const flagSpan = document.createElement('span');
flagSpan.textContent = flag; // Use flag emoji
flagSpan.title = countryName; // Tooltip for the flag in country language
document.getElementById('flag-container').appendChild(flagSpan);
//alert(`Flag Emoji: ${flag}`); // Debug flag emoji display
}
}
displayLocaleAndFlag();
});

View File

@@ -1,28 +0,0 @@
$(document).ready(function() {
function toggleUPSClasses() {
var selectedOption = $('#Nutmode_select').val();
$('.masterups').toggle(selectedOption === 'netserver' || selectedOption === 'standalone'); // Show/Hide masterups based on Net Server or Standalone
$('.slaveups').toggle(selectedOption === 'netclient'); // Show/Hide slaveups based on Net Client
// Enable/Disable inputs based on the selected option
$('.masterups input').prop('disabled', !(selectedOption === 'netserver' || selectedOption === 'standalone'));
$('.slaveups input').prop('disabled', selectedOption !== 'netclient');
}
function toggleGenerics() {
var upsModelValue = $('#UPS_Model_select').val().toLowerCase(); // Get the current value from UPS_Model
var isGenericUps = upsModelValue === 'genericups'; // Check if it's 'genericups'
// Show/Hide generics section and enable/disable inputs
$('.generics').toggle(isGenericUps);
$('.generics input').prop('disabled', !isGenericUps); // Enable/Disable inputs based on the value
}
// Event listener for the selections
$('#Nutmode_select').change(toggleUPSClasses);
$('#UPS_Model_select').change(toggleGenerics); // Listen for changes in the UPS_Model dropdown
// Set the initial state based on current selections
toggleGenerics();
toggleUPSClasses();
});

View File

@@ -1,25 +0,0 @@
document.addEventListener('DOMContentLoaded', function() {
const analysisType = document.getElementById('analysis_type');
const messageIdGroup = document.getElementById('message_id_group');
const emailAddressGroup = document.getElementById('email_address_group');
// Initially hide both controls
messageIdGroup.style.display = 'none';
emailAddressGroup.style.display = 'none';
analysisType.addEventListener('change', function() {
// Hide both controls first
messageIdGroup.style.display = 'none';
emailAddressGroup.style.display = 'none';
// Show the relevant control based on the selected option
switch(this.value) {
case 'trace_message':
messageIdGroup.style.display = 'block';
break;
case 'user_activity':
emailAddressGroup.style.display = 'block';
break;
}
});
});

View File

@@ -96,7 +96,7 @@
% my $btn = l('bac_UPDATE_CONF');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary" value="<%=$c->l('bac_UPDATE_CONF')%>"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm" value="<%=$c->l('bac_UPDATE_CONF')%>"><%= $btn %></button>
</div>
</div>

View File

@@ -40,7 +40,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary" value="<%=$c->l('bac_RESTORE_FROM_TAPE')%>"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm" value="<%=$c->l('bac_RESTORE_FROM_TAPE')%>"><%= $btn %></button>
</div>
</div>

View File

@@ -65,7 +65,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary" value="<%=$c->l('NEXT')%>"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm" value="<%=$c->l('NEXT')%>"><%= $btn %></button>
</div>
</div>

View File

@@ -259,7 +259,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary" value="<%=$c->l('NEXT')%>"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm" value="<%=$c->l('NEXT')%>"><%= $btn %></button>
</div>
</div>

View File

@@ -58,7 +58,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -44,7 +44,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -67,7 +67,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -65,7 +65,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary" value="<%=$c->l('bac_RESTORE_FROM_TAPE')%>"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm" value="<%=$c->l('bac_RESTORE_FROM_TAPE')%>"><%= $btn %></button>
</div>
</div>

View File

@@ -38,7 +38,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -70,7 +70,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -40,7 +40,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -93,7 +93,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -81,7 +81,7 @@
<form action="/smanager/bugreport" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => $bugr_datas->{trt} %>

View File

@@ -20,7 +20,7 @@
<form action="/smanager/bugreportD" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => $bugr_datas->{trt} %>

View File

@@ -59,7 +59,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -1,9 +1,16 @@
<!-- common_css.html.ep -->
%= stylesheet 'koozali/css/adminlte.koozali.css'
%= stylesheet 'koozali/css/flag-icon.min.css'
%#= stylesheet 'css/sme-jquery-overrides.css'
<!-- Generic to AdminLTE -->
%= stylesheet 'dist/css/adminlte.min.css'
%= stylesheet 'dist/font/bootstrap-icons.min.css'
<!-- Specific to Koozali from smanager/default -->
%= stylesheet 'css/flag-icon.min.css'
<!-- Specific Koozali AdminLTE overrides -->
%= stylesheet 'koozali/css/adminlte.koozali.css'
%#= stylesheet 'dist/css/overlayscrollbars.min.css'
%#= stylesheet 'css/sme-jquery-overrides.css'

View File

@@ -1,9 +1,16 @@
<!-- common_js.html.ep -->
%= javascript 'dist/js/jquery.min.js'
%= javascript 'dist/js/bootstrap.min.js'
%= javascript 'dist/js/popper.min.js'
%= javascript 'dist/js/adminlte.min.js'
%= javascript 'koozali/js/flag-by-locale.js'
<!-- Specific to AdminLTE -->
%= javascript 'dist/js/adminlte.min.js'
%= javascript 'dist/js/bootstrap.min.js'
<!-- Generic JS -->
%= javascript 'dist/js/jquery.min.js'
%= javascript 'dist/js/popper.min.js'
<!-- Specific to Koozali from smanager/default -->
%= javascript 'js/flag-by-locale.js'
<!-- Specific to Koozali AdminLTE -->
%= javascript 'koozali/js/sme-password.js'

View File

@@ -4,205 +4,229 @@
<div class="card-body">
% if (config->{debug} == 0) {
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
<%= dumper $dat_datas %>
<%= dumper $dat_data %>
</pre>
% }
% if ( stash 'error' ) {
<br>
<div class="text-danger">
%= $c->render_to_string(inline => stash 'error')
% if ($c->stash('first')) {
<div>
<%= $c->render_to_string(inline =>$c->l($c->stash('first'))) %>
</div>
%}
% } elsif ($c->stash('success')) {
<div class='text-success'>
<%= $c->l($c->stash('success')); %>
</div>
% } elsif ($c->stash('error')) {
<div class='text-danger'>
<%= $c->l($c->stash('error')); %>
</div>
% }
<h1><%= $title %></h1>
<br>
%= $modul
<% my $btn = l('SAVE'); %>
<%= $modul %>
<form action="/smanager/datetime" method="POST">
<br><br>
<br>
% param 'Ntpstatus' => $dat_datas->{ntpstatus} unless param 'Ntpstatus';
% param 'Ntpserver' => 'smeserver.pool.ntp.org' unless param 'Ntpserver';
<br>
% if ($dat_datas->{ntpstatus} eq 'disabled') {
<div>
You can manually set your server time here (static string for testing)<br><br>
</div>
<br>
<div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_CURRENT_SETTING' %>
</div>
<div class="col-auto">
<b><%= $dat_datas->{now_string} %></b>
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_NEW_M/D/Y' %>
</div>
<div class="col-auto">
% param 'Month' => $dat_datas->{month} unless param 'Month';
%= select_field 'Month' => $c->getMonth_list(), class => "form-select"
</div>
<div class="col-auto">
% param 'Day' => $dat_datas->{day} unless param 'Day';
%= text_field 'Day', size => '2', class => ""
</div>
<div class="col-auto">
% param 'Year' => $dat_datas->{year} unless param 'Year';
%= text_field 'Year', size => '4', class => ""
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_NEW_H/M/S' %>
</div>
<div class="col-auto">
% param 'Hour' => $dat_datas->{hour} unless param 'Hour';
%= text_field 'Hour', size => '2', class => ""
</div>
<div class="col-auto">
% param 'Minute' => $dat_datas->{minute} unless param 'Minute';
%= text_field 'Minute', size => '2', class => ""
</div>
<div class="col-auto">
% param 'Second' => $dat_datas->{second} unless param 'Second';
%= text_field 'Second', size => '2', class => ""
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_AM/PM_AND_TZ' %>
</div>
<div class="col-auto">
% param 'Ampm' => $dat_datas->{ampm} unless param 'Ampm';
%= select_field 'Ampm' => ['AM', 'PM'], class => "form-select"
</div>
<div class="col-auto">
% param 'Timezone' => $c->getTimezone() unless param 'Timezone';
%= select_field 'Timezone' => $c->getZone_list(), class => "form-select"
</div>
</div>
<br>
<div class="form-check">
<label class="form-check-label" for="radioDefault1">
<%=l 'dat_NTP_CONFIGURE_TITLE' %>
</label>
<input class="form-check-input" type="radio" name="Ntpstatus" id="radioDefault1" value="enabled">
</div>
</div>
<%#= hidden_field 'Old_ntpstatus' => $dat_datas->{ntpstatus}; %>
<%= hidden_field 'Old_ntpstatus' => 'disabled' %>
% } else {
<!-- # % if ($dat_datas->{ntpstatus} eq 'enabled') { -->
<div>
<%= l 'dat_NTP_ENABLE_DESC' %>
</div>
<div>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_CURRENT_SETTING' %>
</div>
<div class="col-auto">
<b><%= $dat_datas->{now_string} %></b>
</div>
</div>
<br>
<div class="form-check">
<label class="form-check-label" for="radioDefault1">
<%=l 'dat_NTP_CONFIGURE_TITLE' %>
</label>
<input class="form-check-input" type="radio" name="Ntpstatus" id="radioDefault1" value="enabled">
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputNTPServer" class="col-form-label"><%= l 'dat_NTP_SERVER' %></label>
</div>
<div class="col-auto">
<input type="text" name="Ntpserver" id="inputNTPServer" class="form-control" aria-describedby="NTP Server" value="<%= $dat_datas->{ntpserver} %>">
</div>
</div>
</div>
<br>
<div>
<%= l 'dat_NTP_DISABLE_DESC' %>
</div>
<br>
<div class="form-check">
<label class="form-check-label" for="radioDefault2">
<%= l 'dat_NTP_DISABLE_TITLE' %>
</label>
<input class="form-check-input" type="radio" name="Ntpstatus" id="radioDefault2" value="disabled">
</div>
<%= hidden_field 'Old_ntpstatus' => $dat_datas->{ntpstatus}; %>
<%#= hidden_field 'Old_ntpstatus' => 'disabled' %>
% }
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
<div div class="row g-3 align-items-center">
<div class="col-md-2">
<%= $c->l('dat_The_time_is_currently') %>
</div>
<br>
<div>
<%= text_field 'clock', id => 'real-time-clock', readonly => 'readonly', class => 'col-md-2' , value => $dat_data->{currentdatetime} %>
</div>
</div>
<br>
% if ($dat_data->{ntpstatus} eq 'disabled') {
<div class='datetime-set-ntp'>
<%= l 'dat_NTP_ENABLE_DESC' %>
</div>
% } else {
% my $current_year = $dat_data->{year};
% my $year_options = [ map { [ $_, $_ ] } ($current_year..($current_year+30)) ];
% my $month_options = [ map { [ sprintf('%02d', $_), sprintf('%02d', $_) ] } (1..12) ];
% my $hour_options = [ map { [ sprintf('%02d', $_), sprintf('%02d', $_) ] } (0..23) ];
% my $minute_options = [ map { [ sprintf('%02d', $_), sprintf('%02d', $_) ] } (0..60) ];
% my $second_options = [ map { [ sprintf('%02d', $_), sprintf('%02d', $_) ] } (0..60) ];
% my $mode_options = [
% [ $c->l('dat_ntp_server'), 'dat_ntp_server' ],
% [ $c->l('dat_manually_set'), 'dat_manually_set' ]
% ];
<br>
<h2><%= $c->l('Time Configuration') %></h2>
</form>
<form action="/smanager/datetimeu" method="POST">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= label_for time_mode => $c->l('Time Setting Mode:') %>
</div>
<div class="col-auto">
% param 'time_mode' => $dat_data->{time_mode} unless param 'time_mode';
<%= select_field time_mode => ($mode_options, id => 'time_mode_select'), class => "form-select" %>
</div>
</div>
<br><br>
<div id='ntp_section'>
<div>
<%= $c->l('dat_NTP_CONFIGURE_DESC') %>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputNTPServerURL" class="col-form-label"><%=$c->l('dat_NTP_Server_URL') %></label>
</div>
<div class="col-auto">
% my $server_check = '^([a-zA-Z0-9][a-zA-Z0-9\.\-]{0,253}[a-zA-Z0-9]|(\d{1,3}\.){3}\d{1,3})$';
% param 'ntpserver' => $dat_data->{ntpserver} unless param 'ntpserver';
<input type="text" name="ntpserver" id="inputNTPServerURL" class="form-control" aria-describedby="NTP Server URL" pattern="<%= $server_check %>" value="<%= $dat_data->{ntpserver} %>">
</div>
<div class="col-auto">
<button type="button" id="test-ntp-btn" class="btn btn-primary btn-sm ml-2">Test Server</button>
<span id="ntp-test-result" class="ntp-test-result ml-2"></span>
</div>
</div>
</div>
<br>
<div id='manual_section'>
<div>
<%= $c->l('dat_NTP_DISABLE_DESC') %>
</div>
<br>
<div>
<h3><%= $c->l('dat_set_manually') %></h3>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<legend><%= $c->l('Date') %><legend>
</div>
<div class="col-auto">
<%= $c->l('Year:') %>
</div>
<div class="col-auto">
% param 'year' => ($dat_data->{year}) unless param 'year';
<%= select_field year => ($year_options, id => 'year'), required => 'required', class=> "form-select" %>
</div>
<div class="col-auto">
<%= $c->l('Month:') %>
</div>
<div class="col-auto">
% param 'month' => ($dat_data->{month}) unless param 'month';
<%= select_field month => ($month_options, id => 'month'), required => 'required', class=> "form-select" %>
</div>
<div class="col-auto">
<label for="inputDay" class="col-form-label"><%= $c->l('Day:') %></label>
</div>
<div class="col-auto">
% param 'day' => ($dat_data->{day}) unless param 'day';
<input type="text" name="day" id="inputDay" class="form-control" aria-describedby="Day" placeholder="<%= $dat_data->{day} %>" pattern="^(0[1-9]|[12][0-9]|3[01])$" size="2" maxlength="2" required="required" inputmode = "numeric" autcomplete="off">
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<legend><%= $c->l('Time') %></legend>
</div>
<div class="col-auto">
<%= $c->l('Hour:') %>
</div>
<div class="col-auto">
% param 'hour' => ($dat_data->{hour}) unless param 'hour';
<%= select_field hour => ($hour_options, id => 'hour'), required => 'required', class=> "form-select" %>
</div>
<div class="col-auto">
%= label_for minute => $c->l('Minute:')
</div>
<div class="col-auto">
% param 'minute' => ($dat_data->{minute}) unless param 'minute';
<%= select_field minute => ($minute_options, id => 'minute'), required => 'required', class=> "form-select", inputmode => 'numeric' %>
%#= text_field minute => id => 'minute', size => 2, maxlength => 2, placeholder => 'MM', pattern => '^[0-5][0-9]$', title => 'Minute (00-59)', required => 'required', inputmode => 'numeric', autocomplete => 'off'
</div>
<div class="col-auto">
%= label_for second => $c->l('Second:')
</div>
<div class="col-auto">
% param 'second' => ($dat_data->{second}) unless param 'second';
<%= select_field minute => ($second_options, id => 'minute'), required => 'required', class=> "form-select" , inputmode => 'numeric' %>
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_TZ' %>
</div>
<div class="col-auto">
% param 'Timezone' => $c->getTimezone() unless param 'Timezone';
<%= select_field 'Timezone' => $c->getZone_list(), class => "form-select" %>
</div>
</div>
</div>
<br>
<%= hidden_field 'Old_ntpstatus' => $dat_data->{ntpstatus}; %>
<%= hidden_field 'trt' => $dat_data->{trt}; %>
<% my $btn = l('SAVE'); %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
% }
</div>
%end
% end
1;

View File

@@ -1,172 +0,0 @@
% layout 'AdminLTE', title => "Sme server 2 - datetime";
% content_for 'module' => begin
<div class="card-body">
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
<%= dumper $dat_datas %>
</pre>
% }
% if ( stash 'error' ) {
<br>
<div class="text-danger">
%= $c->render_to_string(inline => stash 'error')
</div>
%}
<h1><%= $title %></h1>
<br>
%= $modul
<% my $btn = l('SAVE'); %>
<form action="/smanager/datetime" method="POST">
<br>
% param 'Ntpstatus' => $dat_datas->{ntpstatus} unless param 'Ntpstatus';
<div class="form-check">
<label class="form-check-label" for="radioDefault1">
<%=l 'dat_NTP_CONFIGURE_TITLE' %>
</label>
<input class="form-check-input" type="radio" name="Ntpstatus" id="radioDefault1">
</div>
<br>
<%= radio_button Ntpstatus => 'enabled' %>
<%=l 'dat_NTP_CONFIGURE_TITLE' %>
<br>
% if ($dat_datas->{ntpstatus} eq 'disabled') {
<div>
Status disabled
<%= l 'dat_NTP_ENABLE_DESC' %>
<br>
</div>
% } else {
<div>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'dat_CURRENT_SETTING' %>
</div>
<div class="col-auto">
<b><%= $dat_datas->{now_string} %></b>
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputNTPServer" class="col-form-label"><%= l 'dat_NTP_SERVER' %></label>
</div>
<div class="col-auto">
<input type="text" name="Ntpserver" id="inputNTPServer" class="form-control" aria-describedby="NTP Server" value="<%= $dat_datas->{ntpserver} %>">
</div>
</div>
</div>
% }
<%= radio_button Ntpstatus => 'disabled' %>
<%= l 'dat_NTP_DISABLE_TITLE' %>
<div class="form-check">
<label class="form-check-label" for="radioDefault2">
<%= l 'dat_NTP_DISABLE_TITLE' %>
</label>
<input class="form-check-input" type="radio" name="Ntpstatus" id="radioDefault2" value="disabled">
</div>
% if ($dat_datas->{ntpstatus} eq 'enabled') {
<br><br>
<div>
<%= l 'dat_NTP_DISABLE_DESC' %>
</div>
% } else {
<div>
<br>
<%= l 'dat_CURRENT_SETTING' %>
<b><%= $dat_datas->{now_string} %></b>
<br>
<span class="">
<%= l 'dat_NEW_M/D/Y' %>
</span>
<span class="">
% param 'Month' => $dat_datas->{month} unless param 'Month';
%= select_field 'Month' => $c->getMonth_list(), class => ""
</span>
<span class="">
% param 'Day' => $dat_datas->{day} unless param 'Day';
%= text_field 'Day', size => '2', class => ""
</span>
<span class="">
% param 'Year' => $dat_datas->{year} unless param 'Year';
%= text_field 'Year', size => '4', class => ""
</span>
<br>
<span class="">
<%= l 'dat_NEW_H/M/S' %>
</span>
<span class="">
% param 'Hour' => $dat_datas->{hour} unless param 'Hour';
%= text_field 'Hour', size => '2', class => ""
</span>
<span class="">
% param 'Minute' => $dat_datas->{minute} unless param 'Minute';
%= text_field 'Minute', size => '2', class => ""
</span>
<span class="">
% param 'Second' => $dat_datas->{second} unless param 'Second';
%= text_field 'Second', size => '2', class => ""
</span>
<br>
<span class="">
<%= l 'dat_AM/PM_AND_TZ' %>
</span>
<span class="">
% param 'Ampm' => $dat_datas->{ampm} unless param 'Ampm';
%= select_field 'Ampm' => ['AM', 'PM'], class => ""
</span>
<span class="">
% param 'Timezone' => $c->getTimezone() unless param 'Timezone';
%= select_field 'Timezone' => $c->getZone_list(), class => ""
</span>
</p>
</div>
% }
<br>
<%= hidden_field 'Old_ntpstatus' => $dat_datas->{ntpstatus}; %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
</div>
</form>
</div>
%end

View File

@@ -123,7 +123,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -1,4 +1,4 @@
% layout 'AdminLTE', title => "Sme server 2 - emailsettings";
% layout 'AdminLTE', title => "Sme server 2 - E-Mail";
% content_for 'module' => begin
@@ -12,7 +12,7 @@
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
<= dumper $mai_datas %>
<%= dumper $mai_data->{trt} %>
</pre>
% }
@@ -27,202 +27,31 @@
<br>
<form action="/smanager/emailsettings" method="POST">
%#Routing to partials according to trt parameter.
%#This ought to be cascading if/then/elsif, but is easier to just stack the if/then's rather like a case statement'
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_POP_ACCESS_CONTROL' %>
</div>
<div class="col-auto">
<%= $c->get_current_pop3_access( TRUE ) %>
</div>
</div>
% if ($mai_data->{trt} eq "FRONT") {
<%= include 'partials/_mai_FRONT' %>
% }
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_IMAP_ACCESS_CONTROL' %>
</div>
<div class="col-auto">
<%= $c->get_current_imap_access( TRUE ) %>
</div>
</div>
% if ($mai_data->{trt} eq "ACC") {
<%= include 'partials/_mai_ACC' %>
% }
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_WEBMAIL' %>
</div>
<div class="col-auto">
<%= $c->get_current_webmail_status( TRUE ) %>
</div>
</div>
% if ($mai_data->{trt} eq "FIL") {
<%= include 'partials/_mai_FIL' %>
% }
<br>
% if ($mai_data->{trt} eq "REC") {
<%= include 'partials/_mai_REC' %>
% }
% my $btn = l('mai_DESC_STATE_ACCESS_BUTTON');
<%= hidden_field 'trt' => 'ACC' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_VIRUS_SCAN' %>
</div>
<div class="col-auto">
<%= $c->get_virus_status(TRUE) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_SPAM_SCAN' %>
</div>
<div class="col-auto">
<%= $c->get_spam_status(TRUE) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_BLOCK_EXECUTABLE_CONTENT' %>
</div>
<div class="col-auto">
<%= $c->get_patterns_status(TRUE) %>
</div>
</div>
<br>
% my $btn = l('mai_DESC_STATE_FILTERING_BUTTON');
<%= hidden_field 'trt' => 'FIL' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_MODE' %>
</div>
<div class="col-auto">
<%= $mai_datas->{fetchmailmethod} %>
</div>
</div>
% my $smtp_mesg;
% $smtp_mesg=l('SMTP port %u allow client to authenticate:');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('qpsmtpd','TCPPort',25)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_auth( TRUE ) %>
</div>
</div>
% $smtp_mesg=l('SMTPS SSL/TLS auth: port %u status:');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('sqpsmtpd','TCPPort',465)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_ssl_auth( TRUE, 's', FALSE ) %>
</div>
</div>
% $smtp_mesg=l 'Submission port %u status:';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('uqpsmtpd','TCPPort',587)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_ssl_auth( TRUE,'u', FALSE ) %>
</div>
</div>
<br>
% my $btn = l('mai_DESC_STATE_RECEPTION_BUTTON');
<%= hidden_field 'trt' => 'REC' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_UNKNOWN' %>
</div>
<div class="col-auto">
<%= $c->get_emailunknownuser_status( TRUE ) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_DELEGATE' %>
</div>
<div class="col-auto">
<%= $c->get_value('DelegateMailServer') %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_SMARTHOST' %>
</div>
<div class="col-auto">
<%= $c->get_value('SMTPSmartHost') %>
</div>
</div>
<br>
% if ($mai_data->{trt} eq "DEL") {
<%= include 'partials/_mai_DEL' %>
% }
% my $btn = l('mai_DESC_STATE_DELIVERY_BUTTON');
<%= hidden_field 'trt' => 'DEL' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
</div>
</div>
<br>
</form>
</div>
%end

View File

@@ -19,21 +19,36 @@
%= content_for 'head_contrib'
%= content_for 'refresh'
<!-- Specific for AdminLTE -->
%= include 'common_js'
%= include 'common_css'
<!-- should move the JS in here to a proper file if required -->
%# if (config 'hasJquery') {
%#= include 'partials/_js_imports'
%# }
<!-- Custom overrides js/css? -->
<!-- This needs refining - do contribs add in their own stuff?? -->
<!-- This needs refining -->
% if (config 'hasJquery') {
%= include 'partials/_js_imports'
<!-- the sections below should add the correct JS/CSS per panel -->
%# if ($c->current_route eq 'nutups') {
%#= include 'partials/_nutups_overrides'
%# }
%# panel specific css file
% my $controller = stash('controller');
% if ($controller) {
% my $css_path = "css/$controller.css";
%# Use the url_for helper to generate the correct static file URL
% if (app->static->file($css_path)) {
<link rel="stylesheet" href="<%= url_for("/$css_path") %>">
% }
% }
% if ($c->current_route eq 'nutups') {
%= include 'partials/_nutups_overrides'
% }
</head>
@@ -208,6 +223,16 @@
<div id="adminlte-version"></div>
%# Specific panel js code
% $controller = stash('controller');
% if ($controller) {
% my $js_path = "js/$controller.js";
%# Use the url_for helper to generate the correct static file URL
% if (app->static->file($js_path)) {
<script src="<%= url_for("/$js_path") %>"></script>
% }
% }
</body>
</html>

View File

@@ -6,69 +6,73 @@
% content_for 'module' => begin
<!-- needs moving -->
<!-- reetp needs moving - probabyl not required -->
%= stylesheet '/css/letsencrypt.css'
<!-- stylesheet '/css/letsencrypt.css' -->
<div class="card-body">
% if (config->{debug} == 1) {
<pre>
%= dumper $c->current_route
%= dumper $lets_data->{trt}
<%= dumper $c->current_route %>
<%= dumper $lets_data->{trt} %>
</pre>
% }
<h1><%=$title%></h1>
% if ( stash('modul')) {
%= $c->render_to_string(inline => stash('modul') );
<br>
<div>
<%= $c->render_to_string(inline => stash('modul') ); %>
</div>
% }
%if ($c->stash('first')) {
<br><p>
%=$c->render_to_string(inline =>$c->l($c->stash('first')))
</p>
%} elsif ($c->stash('success')) {
<div class="">
<h2><%=$c->l('lets_Status_Report') %></h2><p>
%= $c->l($c->stash('success'));
</p>
% if ($c->stash('first')) {
<br>
<div>
<%=$c->render_to_string(inline =>$c->l($c->stash('first'))) %>
</div>
%} elsif ($c->stash('error')) {
<div class="">
<h2><%=$c->l('lets_Error_Status_Report') %></h2><p>
%= $c->l($c->stash('error'));
</p>
% } elsif ($c->stash('success')) {
<div class="text-success">
<h2><%=$c->l('lets_Status_Report') %></h2>
<div>
<%= $c->l($c->stash('success')); %>
</div>
</div>
%}
% } elsif ($c->stash('error')) {
<div class="text-danger">
<h2><%=$c->l('lets_Error_Status_Report') %></h2>
<div>
<%= $c->l($c->stash('error')); %>
</div>
</div>
% }
%#Routing to partials according to trt parameter.
%#This ought to be cascading if/then/elsif, but is easier to just stack the if/then's rather like a case statement'
% if ($lets_data->{trt} eq "LIST") {
%= include 'partials/_lets_LIST'
%}
<%= include 'partials/_lets_LIST' %>
% }
% if ($lets_data->{trt} eq "PARAMS") {
%= include 'partials/_lets_PARAMS'
%}
<%= include 'partials/_lets_PARAMS' %>
% }
% if ($lets_data->{trt} eq "CHECKALLDOMAINS") {
%= include 'partials/_lets_CHECKALLDOMAINS'
%}
<%= include 'partials/_lets_CHECKALLDOMAINS' %>
% }
% if ($lets_data->{trt} eq "CHECKALLENABLEDDOMAINS") {
%= include 'partials/_lets_CHECKALLENABLEDDOMAINS'
%}
<%= include 'partials/_lets_CHECKALLENABLEDDOMAINS' %>
% }
% if ($lets_data->{trt} eq "CHECKONEDOMAIN") {
%= include 'partials/_lets_CHECKONEDOMAIN'
%}
<%= include 'partials/_lets_CHECKONEDOMAIN' %>
% }
</div>
%end

View File

@@ -89,7 +89,7 @@
<!-- /.col -->
<div class="col-4">
<div class="d-grid gap-2">
<button type="submit" class="btn btn-primary">Login</button>
<button type="submit" class="btn btn-primary btn-sm">Login</button>
</div>
</div>
<!-- /.col -->

View File

@@ -9,52 +9,59 @@
<div class="card-body">
% if (config->{debug} == 1) {
<pre>
%= dumper $c->current_route
%= dumper $nut_data->{trt}
</pre>
<pre>
%= dumper $c->current_route
%= dumper $nut_data->{trt}
</pre>
% }
<h1><%=$title%></h1>
% if ( stash('modul')) {
%= $c->render_to_string(inline => stash('modul') );
<%= $c->render_to_string(inline => stash('modul') ); %>
% }
%if ($c->stash('first')) {
<br><p>
%=$c->render_to_string(inline =>$c->l($c->stash('first')))
<%=$c->render_to_string(inline =>$c->l($c->stash('first'))) %>
</p>
%} elsif ($c->stash('success')) {
<div class="">
<h2><%=$c->l('nut_Status_Report') %></h2><p>
%= $c->l($c->stash('success'));
</p>
<div class="text-success">
<h2><%=$c->l('nut_Status_Report') %></h2>
<div>
<%= $c->l($c->stash('success')); %>
</div>
</div>
<br />
<br>
%} elsif ($c->stash('error')) {
<div class="">
<h2><%=$c->l('nut_Error_Status_Report') %></h2><p>
%= $c->l($c->stash('error'));
</p>
<div class="text-danger">
<h2><%=$c->l('nut_Error_Status_Report') %></h2>
<div>
<%= $c->l($c->stash('error')); %>
</div>
</div>
<br />
<br>
%}
%#Routing to partials according to trt parameter.
%#This ought to be cascading if/then/elsif, but is easier to just stack the if/then's rather like a case statement'
<br>
% if ($nut_data->{trt} eq "STATUS") {
%= include 'partials/_nut_STATUS'
<%= include 'partials/_nut_STATUS' %>
%}
<br>
% if ($nut_data->{trt} eq "CONFIG") {
%= include 'partials/_nut_CONFIG'
%}
<%= include 'partials/_nut_CONFIG' %>
%}
</div>
%end

View File

@@ -26,7 +26,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -7,7 +7,7 @@
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %> </button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %> </button>
</div>
</div>
<%= hidden_field 'trt' => 'ADD' %>
@@ -47,7 +47,7 @@
% my $domain_name = $domain->{Domain}; # Domain name extracted from the data structure
% my $actionModify = qq{
% <a href="domains2?CsrfDef=$csrf_token&trt=UPD&Domain=$domain_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>
@@ -60,7 +60,7 @@
% my $domain_name = $domain->{Domain}; # Domain name extracted from the data structure
% $actionRemove = qq{
% <a href="domains2?CsrfDef=$csrf_token&trt=DEL&Domain=$domain_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>
@@ -112,7 +112,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-auto">
<button type="submit" class="btn btn-primary"><%= $btn2 %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn2 %></button>
</div>
</div>

View File

@@ -36,7 +36,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => $dom_datas->{trt} %>

View File

@@ -78,7 +78,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => $dom_datas->{trt} %>

View File

@@ -70,7 +70,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -59,7 +59,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -6,7 +6,7 @@
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %> </button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %> </button>
</div>
</div>
<%= hidden_field 'trt' => 'ADD' %>
@@ -39,7 +39,7 @@
% my $modify_text = l('MODIFY'); # Localized text
% my $actionModify = qq{
% <a href="groups2?CsrfDef=$csrf_token&trt=UPD&group=$group_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>
@@ -48,7 +48,7 @@
% my $remove_text = l('REMOVE'); # Localized text
% my $actionRemove = qq{
% <a href="groups2?CsrfDef=$csrf_token&trt=DEL&group=$group_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -79,7 +79,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -22,7 +22,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -5,7 +5,7 @@
<form action="/smanager/hostentriesd" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => $hos_datas->{trt} %>
@@ -47,7 +47,7 @@
%my $hostentries_name = $_->{'HostName'}; # hostentries name extracted from the data structure
%$actionModify = qq{
% <a href="hostentriesd?CsrfDef=$csrf_token&trt=UPD&Hostname=$hostentries_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>
@@ -57,7 +57,7 @@
%#my $hostentries_name = $_->{'HostName'}; # hostentries name extracted from the data structure
%$actionRemove = qq{
% <a href="hostentriesd?CsrfDef=$csrf_token&trt=DEL&Hostname=$hostentries_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -53,7 +53,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -77,7 +77,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -21,7 +21,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -20,7 +20,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -7,7 +7,7 @@
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %> </button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %> </button>
</div>
</div>
<%= hidden_field 'trt' => 'ADD'; %>
@@ -60,7 +60,7 @@
%my $ibays_entry_name = $ibay->key; # ibays_entry name extracted from the data structure
%$actionModify = qq{
% <a href="ibaysd?CsrfDef=$csrf_token&trt=UPD&ibay=$ibays_entry_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>
@@ -74,7 +74,7 @@
%if ($ibay->prop('PasswordSet') ne 'yes' && $needPassword) {
%$actionResetPw = qq{
% <a href="ibaysd?CsrfDef=$csrf_token&trt=PWD&ibay=$ibays_entry_name">
% <button type='button' class="btn btn-danger" title="$password_text - currently unset" >
% <button type='button' class="btn btn-danger btn-sm" title="$password_text - currently unset" >
% $password_text
% </button>
% </a>
@@ -82,7 +82,7 @@
% } else {
%$actionResetPw = qq{
% <a href="ibaysd?CsrfDef=$csrf_token&trt=PWD&ibay=$ibays_entry_name">
% <button type='button' class="btn btn-primary" title='$password_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$password_text' >
% $password_text
% </button>
% </a>
@@ -97,7 +97,7 @@
%my $ibays_entry_name = $ibay->key; # ibays_entry name extracted from the data structure
%$actionRemove = qq{
% <a href="ibaysd?CsrfDef=$csrf_token&trt=DEL&ibay=$ibays_entry_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -49,7 +49,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -107,7 +107,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -2,48 +2,67 @@
%# Generated by SM2Gen version:0.8 Chameleon version:4.5.4 On Python:3.12.3 at 2024-12-01 15:22:43
%#
<div>
<!-- reetp Move to JS file -->
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
-->
% if (config->{debug} == 1) {
<pre>
%= dumper $lets_data
<%= dumper $lets_data %>
</pre>
% }
% my $btn = l('lets_APPLY');
%= form_for "letsencryptu" => (method => 'POST') => begin
% param 'trt' => $lets_data->{trt} unless param 'trt';
%= hidden_field 'trt' => $lets_data->{trt}
<!-- reetp could change this to a form -->
<!-- <form action="/smanager/letsencryptu" method="POST"> -->
%# Inputs etc in here.
<h1 class=""><%=l('lets_Check_all_enabled_domains')%></h1>
<h1><%= l ('lets_Check_all_enabled_domains')%></h1>
<h2 class=""><%=l('lets_Loop_through_checking_the_letsencrypt')%></h2>
<span class="">
%=l('lets_Enabled_domains_check_result')
</span>
<span class="">
% param 'EnabledDomainsCheck' => $lets_data->{EnabledDomainsCheck} unless param 'EnabledDomainsCheck';
%= text_area 'EnabledDomainsCheck', cols=>40, rows=>10, Readonly=>'true'
</span>
<br>
<span class="">
%my $back_text = l('lets_Back'); # Localized text
%my $actionBack = qq{
% <a href="letsencryptd">
% <input class="" type='submit' value='$back_text'>
% </a>
%};
<%= $c->render_to_string(inline => $actionBack) %>
</span>
<h2><%= l ('lets_Loop_through_checking_the_letsencrypt')%></h2>
<br>
<!-- Domains being checked -->
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Enabled_domains_check_result') %>
</div>
<div class="col-auto">
% param 'EnabledDomainsCheck' => $lets_data->{EnabledDomainsCheck} unless param 'EnabledDomainsCheck';
%= text_area 'EnabledDomainsCheck', cols=>40, rows=>10, Readonly=>'true'
</div>
</div>
<br>
<!-- results box-->
% my $back_text = l('lets_Back'); # Localized text
%# param 'trt' => $lets_data->{trt} unless param 'trt';
%#= hidden_field 'trt' => $lets_data->{trt}
<div class="row g-3 align-items-center">
<div class="col-md-2">
<a href='letsencryptd' class="btn btn-primary btn-sm btn-sm" role="button"><%= $back_text %></a>
</div>
</div>
<!--
</form>
-->
%# Probably finally by a submit.
%end
</div>

View File

@@ -2,11 +2,14 @@
%# Generated by SM2Gen version:0.8 Chameleon version:4.5.4 On Python:3.12.3 at 2024-12-01 15:22:43
%#
<div>
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
-->
% if (config->{debug} == 1) {
<pre>
@@ -15,45 +18,60 @@
% }
% my $btn = l('lets_APPLY');
%= form_for "letsencryptu" => (method => 'POST') => begin
% param 'trt' => $lets_data->{trt} unless param 'trt';
%= hidden_field 'trt' => $lets_data->{trt}
<!-- <form action="/smanager/letsencrypt" method="POST"> -->
%# Inputs etc in here.
<h1 class=""><%=l('lets_Check_just_one_domain')%></h1>
<h1><%=l('lets_Check_just_one_domain')%></h1>
<h2 class=""><%=l('lets_Loop_through_and_check_the')%></h2>
<br>
<p><span class="">
%=l('lets_Domains_name')
</span>
<span class="">
<h2><%=l('lets_Loop_through_and_check_the')%></h2>
<br>
<!-- Domain being checked -->
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Domains_name') %>
</div>
<div class="col-auto">
% param 'OneDomainToCheck' => $lets_data->{OneDomainToCheck} unless param 'OneDomainToCheck';
%= text_field 'OneDomainToCheck', size => '50', class => "" , pattern=>'.*' , placeholder=>'OneDomainToCheck', Readonly=>'true'
<br>
</span>
</p>
</div>
</div>
<span class="">
%=l('lets_One_domain_check_result')
</span>
<span class="">
<br>
<!-- results box-->
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_One_domain_check_result') %>
</div>
<div class="col-auto">
% param 'OneDomainsCheck' => $lets_data->{OneDomainsCheck} unless param 'OneDomainsCheck';
%= text_area 'OneDomainsCheck', cols=>40, rows=>10, Readonly=>'true'
</span>
</div>
</div>
<br>
<span class="">
%my $back_text = l('lets_Back'); # Localized text
%my $actionBack = qq{
% <a href="letsencryptd">
% <input class="" type='submit' value='$back_text'>
% </a>
%};
<%= $c->render_to_string(inline => $actionBack) %>
</span>
% my $back_text = l('lets_Back'); # Localized text
%# param 'trt' => $lets_data->{trt} unless param 'trt';
%#= hidden_field 'trt' => $lets_data->{trt}
<div class="row g-3 align-items-center">
<div class="col-md-2">
<a href='letsencryptd' class="btn btn-primary btn-sm btn-sm" role="button"><%= $back_text %></a>
</div>
</div>
<!-- </form> -->
%# Probably finally by a submit.
%end
</div>

View File

@@ -2,151 +2,207 @@
%# Generated by SM2Gen version:0.8 Chameleon version:4.5.4 On Python:3.12.3 at 2024-12-01 15:22:43
%#
<div>
<!-- reetp Move to JS file -->
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
-->
% if (config->{debug} == 1) {
<pre>
%= dumper $lets_data
<%= dumper $lets_data %>
</pre>
% }
% my $btn = l('lets_APPLY');
%= form_for "letsencryptu" => (method => 'POST') => begin
% param 'trt' => $lets_data->{trt} unless param 'trt';
%= hidden_field 'trt' => $lets_data->{trt}
<br>
<!-- reetp could change this to a form -->
<!-- <form action="/smanager/letsencryptu" method="POST"> -->
%# my $btn = l('lets_APPLY');
%# param 'trt' => $lets_data->{trt} unless param 'trt';
%#= hidden_field 'trt' => $lets_data->{trt}
% my $linkbtn = l ('MODIFY');
%# Inputs etc in here.
%# reetp Needs some language translations?
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l('lets_CONFIG') %>
</div>
<div class="col-auto">
<a href='letsencryptd?trt=PARAMS' class="btn btn-outline-primary btn-sm" role="button"><%= $linkbtn %></a>
</div>
</div>
<div>
<br>
<a href='letsencryptd?trt=PARAMS' class="">
%= l('lets_CONFIG')
</a>
%#= link_to l('lets_CONFIG'), 'letsencryptd?trt=PARAMS' , class=> 'link link2'
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_CHECK_ALL_DOMAINS') %>
</div>
<div class="col-auto">
<a href='letsencryptd?trt=CHECKALLDOMAINS' class="btn btn-outline-primary btn-sm" role="button"><%= $linkbtn %></a>
</div>
</div>
<a href='letsencryptd?trt=CHECKALLDOMAINS' class="">
%= l('lets_CHECK_ALL_DOMAINS')
</a>
%#= link_to l('lets_CHECK_ALL_DOMAINS'), 'letsencryptd?trt=CHECKALLDOMAINS' , class=> 'link link3'
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_CHECK_ALL_ENABLED_DOMAINS') %>
</div>
<div class="col-auto">
<a href='letsencryptd?trt=CHECKALLENABLEDDOMAINS' class="btn btn-outline-primary btn-sm" role="button"><%= $linkbtn %></a>
</div>
</div>
<a href='letsencryptd?trt=CHECKALLENABLEDDOMAINS' class="">
%= l('lets_CHECK_ALL_ENABLED_DOMAINS')
</a>
%#= link_to l('lets_CHECK_ALL_ENABLED_DOMAINS'), 'letsencryptd?trt=CHECKALLENABLEDDOMAINS' , class=> 'link link4'
</div>
<!-- </form> -->
<h2 class=""><%=l('lets_For_this_Server')%></h2>
<br><br>
<h2><%=l('lets_For_this_Server') %></h2>
<p>
<span class="">
%=l('lets_Internal_IP')
</span>
<span class="">
% param 'InternalIP' => $lets_data->{InternalIP} unless param 'InternalIP';
%= text_field 'InternalIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'InternalIP', Readonly=>'true'
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_External_Interface_IP')
</span>
<span class="">
% param 'ExternalIP' => $lets_data->{ExternalIP} unless param 'ExternalIP';
%= text_field 'ExternalIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'ExternalIP', Readonly=>'true'
<br>
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Internal_IP') %>
</div>
<div class="col-auto">
% param 'InternalIP' => $lets_data->{InternalIP} unless param 'InternalIP';
%= text_field 'InternalIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'InternalIP', Readonly=>'true'
</div>
</div>
<p>
<span class="">
%=l('lets_Internet_IP')
</span>
<span class="">
% param 'InternetIP' => $lets_data->{InternetIP} unless param 'InternetIP';
%= text_field 'InternetIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'InternetIP', Readonly=>'true'
<br>
</span>
</p>
<br>
<h2 class=""><%=l('lets_Current_certificate_details')%></h2>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_External_Interface_IP') %>
</div>
<div class="col-auto">
% param 'ExternalIP' => $lets_data->{ExternalIP} unless param 'ExternalIP';
%= text_field 'ExternalIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'ExternalIP', Readonly=>'true'
</div>
</div>
<p>
<span class="">
%=l('lets_Issuer')
</span>
<span class="">
% param 'Issuer' => $lets_data->{Issuer} unless param 'Issuer';
%= text_field 'Issuer', size => '50', class => "" , pattern=>'.*' , placeholder=>'Issuer', Readonly=>'true'
<br>
</span>
</p>
<br>
<p>
<span class="">
%=l('lets_Expiry')
</span>
<span class="">
% param 'Expiry' => $lets_data->{Expiry} unless param 'Expiry';
%= text_field 'Expiry', size => '50', class => "" , pattern=>'.*' , placeholder=>'Expiry', Readonly=>'true'
<br>
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Internet_IP') %>
</div>
<div class="col-auto">
% param 'InternetIP' => $lets_data->{InternetIP} unless param 'InternetIP';
%= text_field 'InternetIP', size => '50', class => "" , pattern=>'.*' , placeholder=>'InternetIP', Readonly=>'true'
</div>
</div>
<p>
<span class="">
%=l('lets_Not_Before')
</span>
<span class="">
% param 'NotBefore' => $lets_data->{NotBefore} unless param 'NotBefore';
%= text_field 'NotBefore', size => '50', class => "" , pattern=>'.*' , placeholder=>'NotBefore', Readonly=>'true'
<br>
</span>
</p>
<br><br>
<h2 class=""><%=l('lets_List_of_Domains_and_Hosts')%></h2>
<h2><%=l('lets_Current_certificate_details') %></h2>
<br />
<table class="table table-bordered">
<thead class="">
<tr table-head-row>
<th class=""><%=l('lets_Domain_name_/_HOSTNAME')%></th>
<th class=""><%=l('lets_Brief_description')%></th>
<th class=""><%=l('lets_Content')%></th>
<th class=""><%=l('lets_LABEL_NAMESERVERS')%></th>
<th class=""><%=l('lets_LABEL_POINT')%></th>
<th class=""><%=l('lets_LABEL_LECERT')%></th>
<th class=""><%=l('lets_IS_IN_CERT')%></th>
<th class=""><%=l('lets_CHECK')%></th>
</tr>
</thead>
<tbody class="">
% my $control_data = $c->stash('DomainList');
% foreach my $row (@$control_data) {
<tr class="">
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-Domain name / HOSTNAME'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-Brief description'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-Content'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_NAMESERVERS'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_POINT'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_LECERT'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-IS_IN_CERT'})%></td>
<td class=""><%=$c->render_to_string(inline=>$row->{'Table1-CHECK'})%></td>
</tr>
%}
</tbody>
</table>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Issuer') %>
</div>
<div class="col-auto">
% param 'Issuer' => $lets_data->{Issuer} unless param 'Issuer';
%= text_field 'Issuer', size => '50', class => "" , pattern=>'.*' , placeholder=>'Issuer', Readonly=>'true'
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Expiry') %>
</div>
<div class="col-auto">
% param 'Expiry' => $lets_data->{Expiry} unless param 'Expiry';
%= text_field 'Expiry', size => '50', class => "" , pattern=>'.*' , placeholder=>'Expiry', Readonly=>'true'
</div>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_Not_Before') %>
</div>
<div class="col-auto">
% param 'NotBefore' => $lets_data->{NotBefore} unless param 'NotBefore';
%= text_field 'NotBefore', size => '50', class => "" , pattern=>'.*' , placeholder=>'NotBefore', Readonly=>'true'
</div>
</div>
<br><br>
<h2 class=""><%=l('lets_List_of_Domains_and_Hosts') %></h2>
<br>
% $linkbtn = l 'lets_CHECK';
<table class="table table-bordered">
<thead>
<tr table-head-row>
<th><%= l ('lets_Domain_name_/_HOSTNAME') %></th>
<th><%= l ('lets_Brief_description') %></th>
<th><%= l ('lets_Content') %></th>
<th><%= l ('lets_LABEL_NAMESERVERS') %></th>
<th><%= l ('lets_LABEL_POINT') %></th>
<th><%= l ('lets_LABEL_LECERT') %></th>
<th><%= l ('lets_IS_IN_CERT') %></th>
<th><%= l ('lets_CHECK') %></th>
</tr>
</thead>
<tbody>
% my $control_data = $c->stash('DomainList');
% foreach my $row (@$control_data) {
% my $link = $c->render_to_string(inline=>$row->{'Table1-CHECK'});
% my $type = $c->render_to_string(inline=>$row->{'Table1-TYPE'});
<tr>
% if ($type eq "Domain\n"){
<td><%=$c->render_to_string(inline=>$row->{'Table1-Domain name / HOSTNAME'}) %></td>
% }
% if ($type eq "Host\n") {
<td><i class="bi bi-arrow-return-right"> </i><%=$c->render_to_string(inline=>$row->{'Table1-Domain name / HOSTNAME'}) %></td>
% }
<td><%=$c->render_to_string(inline=>$row->{'Table1-Brief description'}) %></td>
<td><%=$c->render_to_string(inline=>$row->{'Table1-Content'}) %></td>
<td><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_NAMESERVERS'}) %></td>
<td><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_POINT'}) %></td>
<td><%=$c->render_to_string(inline=>$row->{'Table1-LABEL_LECERT'}) %></td>
<td><%=$c->render_to_string(inline=>$row->{'Table1-IS_IN_CERT'}) %></td>
% if ($link ne "") {
<td><a href= "<%= $link %>" class="btn btn-outline-primary btn-sm" role="button" > <%= $linkbtn %></a></td>
% } else {
<td>&nbsp</td>
% }
</tr>
% }
</tbody>
</table>
%# Probably finally by a submit.
%end
</div>

View File

@@ -2,129 +2,151 @@
%# Generated by SM2Gen version:0.8 Chameleon version:4.5.4 On Python:3.12.3 at 2024-12-01 15:22:43
%#
<div>
<!-- reetp This needs fixing -->
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
-->
% if (config->{debug} == 1) {
<pre>
%= dumper $lets_data
<%= dumper $lets_data %>
</pre>
% }
% my $btn = l('lets_APPLY');
%= form_for "letsencryptu" => (method => 'POST') => begin
<form action="/smanager/letsencryptu" method="POST">
% param 'trt' => $lets_data->{trt} unless param 'trt';
%= hidden_field 'trt' => $lets_data->{trt}
%# Inputs etc in here.
<h2 class=""><%=l('lets_Manage_letsencrypt-config_settings:')%></h2>
<h2 class=""><%=l('lets_Manage_letsencrypt-config_settings:') %></h2>
<p class="">
%=l('lets_CONFIG_LETSENCRYPT')
</p>
<p>
<span class="">
%=l('lets_SERVICE_STATUS')
</span>
<span class="">
%# my @status_options = [['Disabled' => 'disabled'], ['Enabled' => 'enabled'], ['TEST' => 'test']];
% my @status_options = selected_field([['Disabled' => 'disabled'], ['Enabled' => 'enabled'], ['TEST' => 'test']], $lets_data->{status});
%# param 'status' => $lets_data->{status} unless param 'status';
%= select_field 'status' => @status_options, class => ""
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_HOOKSCRIPT_STATUS')
</span>
<span class="">
% my @hookScript_options = [['Disabled' => 'disabled'], ['Enabled' => 'enabled']];
% param 'hookScript' => $lets_data->{hookScript} unless param 'hookScript';
%= select_field 'hookScript' => @hookScript_options, class => ""
<div>
<%= l ('lets_CONFIG_LETSENCRYPT') %>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_SERVICE_STATUS') %>
</div>
<div class="col-auto">
% my @status_options = selected_field([['Disabled' => 'disabled'], ['Enabled' => 'enabled'], ['TEST' => 'test']], $lets_data->{status});
%= select_field 'status' => @status_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_HOSTOVERRIDE_STATUS')
</span>
<span class="">
% my @hostOverride_options = [['Disabled' => 'disabled'], ['Yes' => 'yes']];
% param 'hostOverride' => $lets_data->{hostOverride} unless param 'hostOverride';
%= select_field 'hostOverride' => @hostOverride_options, class => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_HOOKSCRIPT_STATUS') %>
</div>
<div class="col-auto">
% my @hookScript_options = [['Disabled' => 'disabled'], ['Enabled' => 'enabled']];
% param 'hookScript' => $lets_data->{hookScript} unless param 'hookScript';
%= select_field 'hookScript' => @hookScript_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_ACCEPT_TERMS_STATUS')
</span>
<span class="">
% my @ACCEPT_TERMS_options = [['Disabled' => 'disabled'], ['Yes' => 'yes']];
% param 'ACCEPT_TERMS' => $lets_data->{ACCEPT_TERMS} unless param 'ACCEPT_TERMS';
%= select_field 'ACCEPT_TERMS' => @ACCEPT_TERMS_options, class => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_HOSTOVERRIDE_STATUS') %>
</div>
<div class="col-auto">
% my @hostOverride_options = [['Disabled' => 'disabled'], ['Yes' => 'yes']];
% param 'hostOverride' => $lets_data->{hostOverride} unless param 'hostOverride';
%= select_field 'hostOverride' => @hostOverride_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_API_STATUS')
</span>
<span class="">
% my @API_options = [['2' => '2']];
% param 'API' => $lets_data->{API} unless param 'API';
%= select_field 'API' => @API_options, class => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_ACCEPT_TERMS_STATUS') %>
</div>
<div class="col-auto">
% my @ACCEPT_TERMS_options = [['Disabled' => 'disabled'], ['Yes' => 'yes']];
% param 'ACCEPT_TERMS' => $lets_data->{ACCEPT_TERMS} unless param 'ACCEPT_TERMS';
%= select_field 'ACCEPT_TERMS' => @ACCEPT_TERMS_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_KEYSIZE_STATUS')
</span>
<span class="">
% my @keysize_options = [['2048' => '2048'], ['3072' => '3072'], ['4096' => '4096']];
% param 'keysize' => $lets_data->{keysize} unless param 'keysize';
%= select_field 'keysize' => @keysize_options, class => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_API_STATUS') %>
</div>
<div class="col-auto">
% my @API_options = [['2' => '2']];
% param 'API' => $lets_data->{API} unless param 'API';
%= select_field 'API' => @API_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_CONFIGUREMODE_STATUS')
</span>
<span class="">
% my @configure_options = [['ALL' => 'all'], ['Domains' => 'domains'], ['HOSTS' => 'hosts'], ['NONE' => 'none']];
% param 'configure' => $lets_data->{configure} unless param 'configure';
%= select_field 'configure' => @configure_options, class => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_KEYSIZE_STATUS') %>
</div>
<div class="col-auto">
% my @keysize_options = [['2048' => '2048'], ['3072' => '3072'], ['4096' => '4096']];
% param 'keysize' => $lets_data->{keysize} unless param 'keysize';
%= select_field 'keysize' => @keysize_options, class => "form-select"
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('lets_EMAIL')
</span>
<span class="">
% param 'email' => $lets_data->{email} unless param 'email';
%=email_field 'email', class => ""
</span>
</p>
<span class="">
%= submit_button l('lets_Save'), class => ""
</span>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('lets_CONFIGUREMODE_STATUS') %>
</div>
<div class="col-auto">
% my @configure_options = [['ALL' => 'all'], ['Domains' => 'domains'], ['HOSTS' => 'hosts'], ['NONE' => 'none']];
% param 'configure' => $lets_data->{configure} unless param 'configure';
%= select_field 'configure' => @configure_options, class => "form-select"
</div>
</div>
%# Probably finally by a submit.
%end
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="email_address" class="col-form-label"><%= l ('lets_EMAIL') %></label>
</div>
<div class="col-auto">
% param 'email' => $lets_data->{email} unless param 'email';
<input type="email" name="email" id="email_address" class="form-control" aria-describedby="Email Address" value="<%= $lets_data->{email} %>">
</div>
</div>
<br>
% my $btn = l('lets_APPLY');
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>

View File

@@ -13,31 +13,30 @@
% }
% if ($ret{ret} eq "") {
<br>
<%= l "ln_FIRSTPAGE_DESC" %>
<BR>
<div>
<%= l "ln_FIRSTPAGE_DESC" %>
</div>
% } elsif (index($ret{ret},"SUCCESS") != -1) {
<div class="">
<h2> Operation Status Report</h2>
<%= $c->l($ret{ret},$var1,$var2,$var3,$var4,$var5,$var6); %>
<div>
<!-- <h2> Operation Status Report</h2> -->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% } else {
<div class="">
<h2> Operation Status Report - Error</h2>
<%= $c->l($ret{ret},$var1,$var2,$var3,$var4,$var5,$var6); %>
<div class="text-danger">
<!-- <h2> Operation Status Report - Error</h2> -->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% }
<br>
% my $btn = l('ADD');
% my $network_db = esmith::NetworksDB::UTF8->open() || die "Couldn't open NetworksDB db";
% if (config->{debug} == 1) {
<div>
<%= dumper $c->current_route %>
<%= dumper $c->stash("ret") %>
</div>
% if (config->{debug} == 1) {
<div>
<%= dumper $c->current_route %>
<%= dumper $c->stash("ret") %>
</div>
% }
<form action="/smanager/localnetworksb" method="POST">
@@ -84,11 +83,14 @@
<br><br>
% my $btn = l('ADD');
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>

View File

@@ -6,12 +6,12 @@
% my $router = $ln_datas->{router};
% if (config->{debug} == 1) {
<div>
<pre>
<%= dumper $c->current_route %>
<%= dumper $c->stash("ret") %>
<%= dumper %$ln_datas %>
<%= dumper $deletehosts %>
</div>
</pre>
% }
<form action="/smanager/localnetworkse" method="POST">
@@ -62,28 +62,24 @@
% if ($deletehosts) {
<br>
<b>tell me if you find this!</b>
<b>Please opoen a bug and tell me</b>
<%= $c->l("ln_REMOVE_HOSTS_DESC") %>
<div>
<%= $c->l("ln_REMOVE_HOSTS_DESC") %>
</div>
<br>
<span class="">
<%= $c->l("ln_REMOVE_HOSTS_LABEL") %>
</span>
<span class="">
<%= check_box deletehost=>1, checked=>1 %>
</span>
<div class="text-danger align-bottom">
<%= $c->l("ln_REMOVE_HOSTS_LABEL") %>&nbsp&nbsp<input type="checkbox" name="deletehost">
</div>
<br><br>
% }
<%= hidden_field localnetwork=>$localnetwork %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field localnetwork=>$localnetwork %>
</form>
</div>

View File

@@ -39,7 +39,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
@@ -78,7 +78,7 @@
%my $csrf_token = "TOKEN"; # CSRF token for security
%$actionRemove = qq{
% <a href="localnetworksd?CsrfDef=$csrf_token&trt=DEL&localnetwork=$local_network_entry">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -38,7 +38,7 @@
<!-- /.col -->
<div class="col-4">
<div class="d-grid gap-2">
<button type="submit" class="btn btn-primary">Sign In</button>
<button type="submit" class="btn btn-primary btn-sm">Sign In</button>
</div>
</div>
<!-- /.col -->

View File

@@ -1,13 +1,13 @@
% layout 'AdminLTE', title => "Sme server 2 - emailaccess";
%# layout 'AdminLTE', title => "Sme server 2 - emailaccess";
% content_for 'module' => begin
%# content_for 'module' => begin
<div class="card-body">
<!-- <div class="card-body"> -->
% if (config->{debug} == 1) {
<pre>
%= dumper $c->current_route
%= dumper $mai_datas
<%= dumper $c->current_route %>
<%= dumper $mai_data %>
</pre>
% }
@@ -18,11 +18,12 @@
</div>
% }
<h1><%= $title%></h1>
<!-- <h1><%#= $title%></h1> -->
<h2><%= $c->l('mai_DESC_STATE_ACCESS_BUTTON') %></h2>
<br>
<form action="/smanager/emailsettingd" method="POST">
<form action="/smanager/emailsettingsu" method="POST">
<div>
<%= l 'mai_DESC_POP_ACCESS_CONTROL' %>
@@ -83,7 +84,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
@@ -92,4 +93,5 @@
<br>
</div>
%end
%#end

View File

@@ -1,13 +1,13 @@
% layout 'AdminLTE', title => "Sme server 2 - emaildeliver";
%# layout 'AdminLTE', title => "Sme server 2 - emaildeliver";
% content_for 'module' => begin
%# content_for 'module' => begin
<div class="card-body">
<!-- <div class="card-body"> -->
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
<%= dumper $mai_datas %>
<%= dumper $mai_data %>
</pre>
% }
@@ -19,11 +19,12 @@
</div>
% }
<h1><%= $title %></h1>
<!-- <h1><%#= $title%></h1> -->
<h2><%= $c->l('mai_DESC_STATE_DELIVERY_BUTTON') %></h2>
<br>
<form action="/smanager/emailsettingd" method="POST">
<form action="/smanager/emailsettingsu" method="POST">
<h2><%= l 'mai_TITLE_UNKNOWN' %></h2>
@@ -40,7 +41,7 @@
<%= l 'mai_LABEL_UNKNOWN' %>
</div>
<div class="col-auto">
% param 'EmailUnknownUser' => $mai_datas->{emailunknownuser} unless param 'EmailUnknownUser';
% param 'EmailUnknownUser' => $mai_data->{emailunknownuser} unless param 'EmailUnknownUser';
<%= select_field 'EmailUnknownUser' => $c->get_emailunknownuser_opt(), class => "form-select" %>
</div>
</div>
@@ -58,14 +59,14 @@
<br>
% param 'DelegateMailServer' => $mai_datas->{delegatemailserver} unless param 'DelegateMailServer';
% param 'DelegateMailServer' => $mai_data->{delegatemailserver} unless param 'DelegateMailServer';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputDelegateMailServer" class="col-form-label"><%= l 'mai_LABEL_DELEGATE' %></label>
</div>
<div class="col-auto">
<input type="text" name="DelegateMailServer" id="inputDelegateMailServer" class="form-control" aria-describedby="DelegateMailServer" value="<%= $mai_datas->{delegatemailserver} %>">
<input type="text" name="DelegateMailServer" id="inputDelegateMailServer" class="form-control" aria-describedby="DelegateMailServer" value="<%= $mai_data->{delegatemailserver} %>">
</div>
</div>
@@ -82,20 +83,20 @@
<br>
% param 'SMTPSmartHost' => $mai_datas->{smtpsmarthost} unless param 'SMTPSmartHost';
% param 'SMTPSmartHost' => $mai_data->{smtpsmarthost} unless param 'SMTPSmartHost';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputSMTPSmartHost" class="col-form-label"><%= l 'mai_LABEL_SMARTHOST' %></label>
</div>
<div class="col-auto">
<input type="text" name="SMTPSmartHost" id="inputSMTPSmartHost" class="form-control" aria-describedby="SMTPSmartHost" value="<%= $mai_datas->{smtpsmarthost} %>">
<input type="text" name="SMTPSmartHost" id="inputSMTPSmartHost" class="form-control" aria-describedby="SMTPSmartHost" value="<%= $mai_data->{smtpsmarthost} %>">
</div>
</div>
<br>
% param 'SMTPAUTHPROXY_status' => $mai_datas->{smtpauthproxystatus} unless param 'SMTPAUTHPROXY_status';
% param 'SMTPAUTHPROXY_status' => $mai_data->{smtpauthproxystatus} unless param 'SMTPAUTHPROXY_status';
<div class="row g-3 align-items-center">
<div class="col-md-2">
@@ -108,27 +109,27 @@
<br>
% param 'SMTPAUTHPROXY_Userid' => $mai_datas->{smtpauthproxyuserid} unless param 'SMTPAUTHPROXY_Userid';
% param 'SMTPAUTHPROXY_Userid' => $mai_data->{smtpauthproxyuserid} unless param 'SMTPAUTHPROXY_Userid';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputSMTPAuthproxy" class="col-form-label"><%= l 'mai_LABEL_SMARTHOST_SMTPAUTH_USERID' %></label>
</div>
<div class="col-auto">
<input type="text" name="SMTPAUTHPROXY_Userid" id="inputSMTPAuthproxy" class="form-control" aria-describedby="SMTPAuthproxy" value="<%= $mai_datas->{smtpauthproxyuserid} %>">
<input type="text" name="SMTPAUTHPROXY_Userid" id="inputSMTPAuthproxy" class="form-control" aria-describedby="SMTPAuthproxy" value="<%= $mai_data->{smtpauthproxyuserid} %>">
</div>
</div>
<br>
% param 'SMTPAUTHPROXY_Passwd' => $mai_datas->{smtpauthproxypassword} unless param 'SMTPAUTHPROXY_Passwd';
% param 'SMTPAUTHPROXY_Passwd' => $mai_data->{smtpauthproxypassword} unless param 'SMTPAUTHPROXY_Passwd';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="password" class="col-form-label"><%= l 'mai_LABEL_SMARTHOST_SMTPAUTH_PASSWD' %></label>
</div>
<div class="col-auto">
<input type="password" name="SMTPAUTHPROXY_Passwd" id="password" class="form-control" aria-describedby="SMTPAuthProxyPassword" value="<%= $mai_datas->{smtpauthproxypassword} %>">
<input type="password" name="SMTPAUTHPROXY_Passwd" id="password" class="form-control" aria-describedby="SMTPAuthProxyPassword" value="<%= $mai_data->{smtpauthproxypassword} %>">
</div>
<div class="col-auto">
<span id="togglePassword" class="bi bi-eye"></span>
@@ -142,10 +143,11 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>
%end
%#end

View File

@@ -1,13 +1,13 @@
% layout 'AdminLTE', title => "Sme server 2 - emailfilter";
%# layout 'AdminLTE', title => "Sme server 2 - emailfilter";
% content_for 'module' => begin
%# content_for 'module' => begin
<div class="card-body">
<!-- <div class="card-body"> -->
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
<%= dumper $mai_datas %>
<%= dumper $mai_data %>
</pre>
% }
@@ -18,11 +18,12 @@
</div>
% }
<h1><%= $title%></h1>
<!-- <h1><%#= $title%></h1> -->
<h2><%= $c->l('mai_DESC_STATE_FILTERING_BUTTON') %></h2>
<br>
<form action="/smanager/emailsettingd" method="POST">
<form action="/smanager/emailsettingsu" method="POST">
<div>
<%= l 'mai_DESC_VIRUS_SCAN' %>
@@ -35,7 +36,7 @@
<%= l 'mai_LABEL_VIRUS_SCAN' %>
</div>
<div class="col-auto">
% param 'VirusStatus' => $mai_datas->{virusstatus} unless param 'VirusStatus';
% param 'VirusStatus' => $mai_data->{virusstatus} unless param 'VirusStatus';
<%= select_field 'VirusStatus' => [[(l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
@@ -53,7 +54,7 @@
<%= l 'mai_LABEL_SPAM_SCAN' %>
</div>
<div class="col-auto">
% param 'Spamstatus' => $mai_datas->{spamstatus} unless param 'Spamstatus';
% param 'Spamstatus' => $mai_data->{spamstatus} unless param 'Spamstatus';
<%= select_field 'Spamstatus' => [[(l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
@@ -65,7 +66,7 @@
<%= l 'mai_LABEL_SPAM_SENSITIVITY' %>
</div>
<div class="col-auto">
% param 'SpamSensitivity' => $mai_datas->{spamsensitivity} unless param 'SpamSensitivity';
% param 'SpamSensitivity' => $mai_data->{spamsensitivity} unless param 'SpamSensitivity';
<%= select_field 'SpamSensitivity' => $c->get_spam_sensitivity_opt(), class => "form-select" %>
</div>
</div>
@@ -77,7 +78,7 @@
<%= l 'mai_LABEL_SPAM_TAGLEVEL' %>
</div>
<div class="col-auto">
% param 'SpamTagLevel' => $mai_datas->{spamtaglevel} unless param 'SpamTagLevel';
% param 'SpamTagLevel' => $mai_data->{spamtaglevel} unless param 'SpamTagLevel';
<%= select_field 'SpamTagLevel' => $c->get_spam_level_options(), class => "form-select" %>
</div>
</div>
@@ -89,7 +90,7 @@
<%= l 'mai_LABEL_SPAM_REJECTLEVEL' %>
</div>
<div class="col-auto">
% param 'SpamRejectLevel' => $mai_datas->{spamrejectlevel} unless param 'SpamRejectLevel';
% param 'SpamRejectLevel' => $mai_data->{spamrejectlevel} unless param 'SpamRejectLevel';
<%= select_field 'SpamRejectLevel' => $c->get_spam_level_options(), class => "form-select" %>
</div>
</div>
@@ -101,7 +102,7 @@
<%= l 'mai_LABEL_SORTSPAM' %>
</div>
<div class="col-auto">
% param 'SpamSortSpam' => $mai_datas->{spamsortspam} unless param 'SpamSortSpam';
% param 'SpamSortSpam' => $mai_data->{spamsortspam} unless param 'SpamSortSpam';
<%= select_field 'SpamSortSpam' => [[(l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
@@ -119,14 +120,14 @@
<%= l 'mai_LABEL_SPAM_SUBJECTTAG' %>
</div>
<div class="col-auto">
% param 'SpamSubjectTag' => $mai_datas->{spamsubjecttag} unless param 'SpamSubjectTag';
% param 'SpamSubjectTag' => $mai_data->{spamsubjecttag} unless param 'SpamSubjectTag';
<%= select_field 'SpamSubjectTag' => [[(l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
<br>
% param 'SpamSubject' => $mai_datas->{spamsubject} unless param 'SpamSubject';
% param 'SpamSubject' => $mai_data->{spamsubject} unless param 'SpamSubject';
<div class="row g-3 align-items-center">
<div class="col-md-1">
@@ -134,7 +135,7 @@
</div>
<div class="col-auto">
<!-- text_field 'Soft' -->
<input type="text" name="SpamSubject" id="inputSpamSubjectTag" class="form-control" aria-describedby="SpamSubjectTag" value="<%= $mai_datas->{spamsubject} %>">
<input type="text" name="SpamSubject" id="inputSpamSubjectTag" class="form-control" aria-describedby="SpamSubjectTag" value="<%= $mai_data->{spamsubject} %>">
</div>
</div>
@@ -165,11 +166,12 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>
%end
%#end

View File

@@ -0,0 +1,206 @@
% if (config->{debug} == 1) {
<pre>
<%= dumper $mai_data %>
<br>
</pre>
% }
<h2><%= $c->l('mai_DESC_STATE_ACCESS_BUTTON') %></h2>
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_POP_ACCESS_CONTROL' %>
</div>
<div class="col-auto">
<%= $c->get_current_pop3_access( TRUE ) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_IMAP_ACCESS_CONTROL' %>
</div>
<div class="col-auto">
<%= $c->get_current_imap_access( TRUE ) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_WEBMAIL' %>
</div>
<div class="col-auto">
<%= $c->get_current_webmail_status( TRUE ) %>
</div>
</div>
<br>
% my $btn = l('mai_DESC_STATE_ACCESS_BUTTON');
<%= hidden_field 'trt' => 'ACC' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_VIRUS_SCAN' %>
</div>
<div class="col-auto">
<%= $c->get_virus_status(TRUE) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_SPAM_SCAN' %>
</div>
<div class="col-auto">
<%= $c->get_spam_status(TRUE) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_BLOCK_EXECUTABLE_CONTENT' %>
</div>
<div class="col-auto">
<%= $c->get_patterns_status(TRUE) %>
</div>
</div>
<br>
% $btn = l('mai_DESC_STATE_FILTERING_BUTTON');
<%= hidden_field 'trt' => 'FIL' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_MODE' %>
</div>
<div class="col-auto">
<%= $mai_data->{fetchmailmethod} %>
</div>
</div>
% my $smtp_mesg;
% $smtp_mesg=l('SMTP port %u allow client to authenticate:');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('qpsmtpd','TCPPort',25)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_auth( TRUE ) %>
</div>
</div>
% $smtp_mesg=l('SMTPS SSL/TLS auth: port %u status:');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('sqpsmtpd','TCPPort',465)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_ssl_auth( TRUE, 's', FALSE ) %>
</div>
</div>
% $smtp_mesg=l 'Submission port %u status:';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= sprintf($smtp_mesg,$c->get_db_prop('uqpsmtpd','TCPPort',587)); %>
</div>
<div class="col-auto">
<%= $c->get_current_smtp_ssl_auth( TRUE,'u', FALSE ) %>
</div>
</div>
<br>
% $btn = l('mai_DESC_STATE_RECEPTION_BUTTON');
<%= hidden_field 'trt' => 'REC' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
<br><br>
<!--<hr class="" />-->
<form action="/smanager/emailsettings" method="POST">
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_UNKNOWN' %>
</div>
<div class="col-auto">
<%= $c->get_emailunknownuser_status( TRUE ) %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_DELEGATE' %>
</div>
<div class="col-auto">
<%= $c->get_value('DelegateMailServer') %>
</div>
</div>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_SMARTHOST' %>
</div>
<div class="col-auto">
<%= $c->get_value('SMTPSmartHost') %>
</div>
</div>
<br>
% $btn = l('mai_DESC_STATE_DELIVERY_BUTTON');
<%= hidden_field 'trt' => 'DEL' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<br>
</form>

View File

@@ -1,16 +1,16 @@
% layout 'AdminLTE', title => "Sme server 2 - emailreceive";
%# layout 'AdminLTE', title => "Sme server 2 - emailreceive";
% content_for 'module' => begin
%# content_for 'module' => begin
% use constant FALSE => 0;
% use constant TRUE => 1;
%# use constant FALSE => 0;
%# use constant TRUE => 1;
<div class="card-body">
<!-- <div class="card-body"> -->
% if (config->{debug} == 1) {
<pre>
<<%= dumper $c->current_route %>
<<%= dumper $mai_datas %>
<<%= dumper $mai_data %>
<<%= dumper $c->param('SMTPAuth') %>
</pre>
% }
@@ -22,30 +22,26 @@
</div>
% }
<h1><%= $title %></h1>
<!--<h1><%#= $title %></h1> -->
<h2><%= $c->l('mai_DESC_STATE_RECEPTION_BUTTON') %></h2>
<br>
<form action="/smanager/emailsettingd" method="POST">
<form action="/smanager/emailsettingsu" method="POST">
<div>
<%= l 'mai_DESC_MODE' %>
</div>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'mai_LABEL_MODE' %>
</div>
<div class="col-auto">
% param 'FetchmailMethod' => $mai_datas->{fetchmailmethod} unless param 'FetchmailMethod';
<!--
<pre>
<%= dumper $mai_datas->{fetchmailmethod} %>
<%= dumper $c->get_retrieval_opt() %>
<%= param 'FetchmailMethod' %>
</pre>
-->
% param 'FetchmailMethod' => $mai_data->{fetchmailmethod} unless param 'FetchmailMethod';
<%= select_field 'FetchmailMethod' => $c->get_retrieval_opt(), class =>"form-select" %>
</div>
</div>
@@ -72,7 +68,6 @@
<br>
<div>
<%= l "SMTPS port (465) will require implicit SSL/TLS then authenticate to send." %>
</div>
@@ -86,8 +81,6 @@
<br>
% my $smtp_mesg=l('SMTP port %u allow client to authenticate:');
% param 'SMTPAuth' => $c->get_current_smtp_auth( FALSE ) unless param 'SMTPAuth';
@@ -96,15 +89,6 @@
<%= sprintf($smtp_mesg,$c->get_db_prop('qpsmtpd','TCPPort',25)); %>
</div>
<div class="col-auto">
<!--
<pre>
<%= dumper $c->get_smtp_auth_opt() %>
<%= dumper $c->get_current_smtp_auth(FALSE) %>
<%= dumper $c->get_db_prop("qpsmtpd","Authentication") %>
<%= param 'SMTPAuth' %>
</pre>
-->
<%= select_field 'SMTPAuth' => $c->get_smtp_auth_opt(), class => "form-select" %>
</div>
</div>
@@ -158,14 +142,14 @@
<br>
% param 'SecondaryMailServer' => $mai_datas->{secondarymailserver} unless param 'SecondaryMailServer';
% param 'SecondaryMailServer' => $mai_data->{secondarymailserver} unless param 'SecondaryMailServer';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputSecondaryMailServer" class="col-form-label"><%= l 'mai_LABEL_SECONDARY' %></label>
</div>
<div class="col-auto">
<input type="text" name="SecondaryMailServer" id="inputSecondaryMailServer" class="form-control" aria-describedby="SecondaryMailServer" value="<%= $mai_datas->{secondarymailserver} %>">
<input type="text" name="SecondaryMailServer" id="inputSecondaryMailServer" class="form-control" aria-describedby="SecondaryMailServer" value="<%= $mai_data->{secondarymailserver} %>">
</div>
</div>
@@ -175,7 +159,7 @@
<%= l 'mai_DESC_FETCH_PERIOD' %>
</div>
% param 'FreqOffice' => $mai_datas->{freqoffice} unless param 'FreqOffice';
% param 'FreqOffice' => $mai_data->{freqoffice} unless param 'FreqOffice';
<div class="row g-3 align-items-center">
<div class="col-md-2">
@@ -188,7 +172,7 @@
<br>
% param 'FreqOutside' => $mai_datas->{freqoutside} unless param 'FreqOutside';
% param 'FreqOutside' => $mai_data->{freqoutside} unless param 'FreqOutside';
<div class="row g-3 align-items-center">
<div class="col-md-2">
@@ -201,7 +185,7 @@
<br>
% param 'FreqWeekend' => $mai_datas->{freqweekend} unless param 'FreqWeekend';
% param 'FreqWeekend' => $mai_data->{freqweekend} unless param 'FreqWeekend';
<div class="row g-3 align-items-center">
<div class="col-md-2">
@@ -214,27 +198,27 @@
<br>
% param 'SecondaryMailAccount' => $mai_datas->{secondarymailaccount} unless param 'SecondaryMailAccount';
% param 'SecondaryMailAccount' => $mai_data->{secondarymailaccount} unless param 'SecondaryMailAccount';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputSecondaryMailAccount" class="col-form-label"><%= l 'mai_LABEL_POP_ACCOUNT' %></label>
</div>
<div class="col-auto">
<input type="text" name="SecondaryMailAccount" id="inputSecondaryMailAccount" class="form-control" aria-describedby="SecondaryMailAccount" value="<%= $mai_datas->{secondarymailaccount} %>">
<input type="text" name="SecondaryMailAccount" id="inputSecondaryMailAccount" class="form-control" aria-describedby="SecondaryMailAccount" value="<%= $mai_data->{secondarymailaccount} %>">
</div>
</div>
<br>
% param 'SecondaryMailPassword' => $mai_datas->{secondarymailpassword} unless param 'SecondaryMailPassword';
% param 'SecondaryMailPassword' => $mai_data->{secondarymailpassword} unless param 'SecondaryMailPassword';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="password" class="col-form-label"><%= l 'mai_LABEL_POP_PASS' %></label>
</div>
<div class="col-auto">
<input type="password" name="SecondaryMailPassword" id="password" class="form-control" aria-describedby="SecondaryMailPassword" value="<%= $mai_datas->{secondarymailpassword} %>">
<input type="password" name="SecondaryMailPassword" id="password" class="form-control" aria-describedby="SecondaryMailPassword" value="<%= $mai_data->{secondarymailpassword} %>">
</div>
<div class="col-auto">
<span id="togglePassword" class="bi bi-eye"></span>
@@ -244,7 +228,7 @@
<br>
% param 'SpecifyHeader' => $mai_datas->{specifyheader} unless param 'SpecifyHeader';
% param 'SpecifyHeader' => $mai_data->{specifyheader} unless param 'SpecifyHeader';
<div class="row g-3 align-items-center">
<div class="col-md-2">
@@ -257,30 +241,32 @@
<br>
% param 'SecondaryMailEnvelope' => $mai_datas->{secondarymailenvelope} unless param 'SecondaryMailEnvelope';
% param 'SecondaryMailEnvelope' => $mai_data->{secondarymailenvelope} unless param 'SecondaryMailEnvelope';
<div class="row g-3 align-items-center">
<div class="col-md-2">
<label for="inputSecondaryMailEnvelope" class="col-form-label"><%= l 'mai_LABEL_SORT_HEADER' %></label>
</div>
<div class="col-auto">
<input type="text" name="SecondaryMailEnvelope" id="inputSecondaryEnvelope" class="form-control" aria-describedby="SecondaryMailEnvelope" value="<%= $mai_datas->{secondarymailenvelope} %>">
<input type="text" name="SecondaryMailEnvelope" id="inputSecondaryEnvelope" class="form-control" aria-describedby="SecondaryMailEnvelope" value="<%= $mai_data->{secondarymailenvelope} %>">
</div>
</div>
<br>
% my $btn = l('SAVE');
% param 'trt' => $mai_data->{trt} unless param 'trt';
<%= hidden_field 'trt' => 'REC' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>
%end
%#end

View File

@@ -2,162 +2,205 @@
%# Generated by SM2Gen version:0.9(20Jan2025) Chameleon version:4.5.4 On Python:3.12.3 at 2025-01-20 16:21:33
%#
<div>
<!-- reetp This needs fixing -->
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
% if (config->{debug} == 1) {
-->
% if (config->{debug} == 0) {
<pre>
%= dumper $nut_data
</pre>
% }
% my $btn = l('nut_APPLY');
%= form_for "nutupsu" => (method => 'POST') => begin
% param 'trt' => $nut_data->{trt} unless param 'trt';
%= hidden_field 'trt' => $nut_data->{trt}
<form action="/smanager/nutupsu" method="POST">
%# Inputs etc in here.
<h2 class=""><%=l('nut_Manage_Nutups-config_settings:')%></h2>
<!-- reetp - autocomplete="off" ? -->
<p>
<span class="">
%=l('nut_Nut_status')
</span>
<span class="">
<h2><%=l('nut_Manage_Nutups-config_settings:')%></h2>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('nut_Nut_status') %>
</div>
<div class="col-auto">
%# my @status_options = [['Disabled' => 'disabled'], ['Enabled' => 'enabled']];
%# param 'status' => $nut_data->{status} unless param 'status';
% my @status_options = selected_field([['Disabled' => 'disabled'], ['Enabled' => 'enabled']], $nut_data->{status});
%= select_field 'status' => @status_options, class => "", id => ""
% my @status_options = selected_field([['Disabled' => 'disabled'], ['Enabled' => 'enabled']], $nut_data->{status});
<%= select_field 'status' => @status_options, class => "form-select" %>
</div>
</div>
<br>
</span>
</p>
<p>
<span class="">
%=l('nut_Nut_mode')
</span>
<span class="">
% my @Nutmode_options = [['Standalone' => 'standalone'], ['Net Server' => 'netserver'], ['Net Client ' => 'netclient']];
% param 'Nutmode' => $nut_data->{Nutmode} unless param 'Nutmode';
%= select_field 'Nutmode' => @Nutmode_options, class => "", id => ""
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('nut_Nut_mode') %>
</div>
<div class="col-auto">
% my @Nutmode_options = [['Standalone' => 'standalone'], ['Net Server' => 'netserver'], ['Net Client ' => 'netclient']];
% param 'Nutmode' => $nut_data->{Nutmode} unless param 'Nutmode';
<%= select_field 'Nutmode' => @Nutmode_options, class => "form-select" %>
</div>
</div>
<br><br>
<h2><%=l('nut_if_Net_Server')%></h2>
<br>
</span>
</p>
<div class="">
<h2 class=""><%=l('nut_if_Net_Server')%></h2>
<p>
<span class="">
%=l('nut_MasterUPS_UPSNAME@IP')
</span>
<span class="">
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputMasterUPSName" class="col-form-label"><%= l ('nut_MasterUPS_UPSNAME@IP') %></label>
</div>
<div class="col-auto">
% param 'MasterUPS_Name' => $nut_data->{MasterUPS_Name} unless param 'MasterUPS_Name';
%= text_field 'MasterUPS_Name', size => '50', class => "" , pattern=>'.*' , placeholder=>'ups@localhost'
<br>
</span>
</p>
<input type="text" name="MasterUPS_Name" pattern=".*" size="50" id="inputMasterUPSName" class="form-control" aria-describedby="Master UPS Name" placeholder="ups@localhost" value="<%= $nut_data->{MasterUPS_Name} %>" >
</div>
</div>
<p>
<span class="">
%=l('nut_MasterUPS_Password')
</span>
<span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="MasterUPSPassword" class="col-form-label"><%= l ('nut_MasterUPS_Password') %></label>
</div>
<div class="col-auto">
% param 'MasterUPS_Password' => $nut_data->{MasterUPS_Password} unless param 'MasterUPS_Password';
%=password_field 'MasterUPS_Password', class => ""
</span>
</p>
<input type="password" name="MasterUPS_Password" id="MasterUPSPassword" class="form-control" aria-describedby="Master UPS Password" value="<%= $nut_data->{MasterUPS_Password} %>">
</div>
<!-- reetp fix toggle password -->
<!-- <div class="col-auto">
<span id="togglePassword" class="bi bi-eye"></span>
</div>
-->
</div>
<p>
<span class="">
%=l('nut_UPS_Model')
</span>
<span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l ('nut_UPS_Model') %>
</div>
<div class="col-auto">
% my @UPS_Model_options = $c->get_model_options();
% param 'UPS_Model' => $nut_data->{UPS_Model} unless param 'UPS_Model';
%= select_field 'UPS_Model' => \@UPS_Model_options, class => "", id => ""
<br>
</span></p>
%= select_field 'UPS_Model' => \@UPS_Model_options, class => "form-select"
</div>
</div>
<p><span class="">
%=l('nut_UPS_Device')
</span><span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputUPSDevice" class="col-form-label"><%= l ('nut_UPS_Device') %></label>
</div>
<div class="col-auto">
% param 'UPS_Device' => $nut_data->{UPS_Device} unless param 'UPS_Device';
%= text_field 'UPS_Device', size => '50', class => "" , pattern=>'.*' , placeholder=>'auto (for usb)'
<br></span></p>
<input type="text" name="UPS_Device" pattern=".*" size="50" id="inputUPSDevice" class="form-control" aria-describedby="UPS Device" placeholder="auto (for usb)" value="<%= $nut_data->{UPS_Device} %>" >
</div>
</div>
<div class="">
<h2 class=""><%=l('nut_if_Net_Client')%></h2>
<p>
<span class="">
%=l('nut_SlaveUPS_UPSNAME@IP')
</span>
<span class="">
<br><br>
<h2><%=l('nut_if_Net_Client')%></h2>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputSlaveUPSDevice" class="col-form-label"><%= l ('nut_SlaveUPS_UPSNAME@IP') %></label>
</div>
<div class="col-auto">
% param 'SlaveUPS_Name' => $nut_data->{SlaveUPS_Name} unless param 'SlaveUPS_Name';
%= text_field 'SlaveUPS_Name', size => '50', class => "" , pattern=>'.*' , placeholder=>'upsname@IP'
<br>
</span>
</p>
<p>
<span class="">
%=l('nut_SlaveUPS_Password')
</span>
<span class="">
% param 'SlaveUPS_Password' => $nut_data->{SlaveUPS_Password} unless param 'SlaveUPS_Password';
%=password_field 'SlaveUPS_Password', class => ""
</span>
</p>
<input type="text" name="SlaveUPS_Name" pattern=".*" size="50" id="inputSlaveUPSDevice" class="form-control" aria-describedby="Slave UPS Name" placeholder="upsname@IP" value="<%= $nut_data->{SlaveUPS_Name} %>" >
</div>
</div>
<div class="">
` <h2 class=""><%=l('nut_if_genericups')%></h2>
<p>
<span class="">
%=l('nut_UPS_Generic_Type')
</span>
<span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="SlaveUPSPassword" class="col-form-label"><%= l ('nut_SlaveUPS_Password') %></label>
</div>
<div class="col-auto">
% param 'SlaveUPS_Pass' => $nut_data->{SlaveUPS_Pass} unless param 'SlaveUPS_Pass';
<input type="password" name="SlaveUPS_Pass" id="SlaveUPSPassword" class="form-control" aria-describedby="Slave UPS Password" value="<%= $nut_data->{SlaveUPS_Pass} %>">
</div>
<!-- reetp fix toggle password -->
<!-- <div class="col-auto">
<span id="togglePassword" class="bi bi-eye"></span>
</div>
-->
</div>
<br><br>
<h2><%=l('nut_if_genericups')%></h2>
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputUPSGenericType" class="col-form-label"><%= l ('nut_UPS_Generic_Type') %></label>
</div>
<div class="col-auto">
% param 'UPS_gen_Type' => $nut_data->{UPS_gen_Type} unless param 'UPS_gen_Type';
%= text_field 'UPS_gen_Type', size => '50', class => "" , pattern=>'.*' , placeholder=>'UPS_gen_Type'
<br>
</span>
</p>
<input type="text" name="UPS_gen_Type" pattern=".*" size="50" id="inputUPSGenericType" class="form-control" aria-describedby="UPS Generic Type" placeholder="UPS_Gen_Type" value="<%= $nut_data->{UPS_gen_Type} %>" >
</div>
</div>
<p>
<span class="">
%=l('nut_UPS_Generic_Manufacturer')
</span>
<span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputUPSManufacturer" class="col-form-label"><%= l ('nut_UPS_Generic_Manufacturer') %></label>
</div>
<div class="col-auto">
% param 'UPS_gen_Mfr' => $nut_data->{UPS_gen_Mfr} unless param 'UPS_gen_Mfr';
%= text_field 'UPS_gen_Mfr', size => '50', class => "" , pattern=>'.*' , placeholder=>'UPS_gen_Mfr'
<br>
</span>
</p>
<input type="text" name="UPS_gen_Mfr" pattern=".*" size="50" id="inputUPSManufacturer" class="form-control" aria-describedby="UPS Generic Manufacturer" placeholder="UPS_sen_Mfr" value="<%= $nut_data->{UPS_gen_Mfr} %>" >
</div>
</div>
<p>
<span class="">
%=l('nut_UPS_Generic_Model')
</span>
<span class="">
<br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<label for="inputUPSModel" class="col-form-label"><%= l ('nut_UPS_Generic_Model') %></label>
</div>
<div class="col-auto">
% param 'UPS_gen_Model' => $nut_data->{UPS_gen_Model} unless param 'UPS_gen_Model';
%= text_field 'UPS_gen_Model', size => '50', class => "" , pattern=>'.*' , placeholder=>'UPS_gen_Model'
<br>
</span>
</p>
` </div>
<input type="text" name="UPS_gen_Model" pattern=".*" size="50" id="inputUPSModel" class="form-control" aria-describedby="UPS Generic Model" placeholder="UPS_gen_Model" value="<%= $nut_data->{UPS_gen_Model} %>" >
</div>
</div>
<span class="">
%= submit_button l('nut_Save'), class => ""
</span>
<br>
% param 'trt' => $nut_data->{trt} unless param 'trt';
<%= hidden_field 'trt' => $nut_data->{trt} %>
% my $btn = l ('nut_Save');
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
%# Probably finally by a submit.
%end
</form>
<br>
</div>

View File

@@ -2,12 +2,15 @@
%# Generated by SM2Gen version:0.9(20Jan2025) Chameleon version:4.5.4 On Python:3.12.3 at 2025-01-20 16:21:33
%#
<div>
<!--
<script>
window.onload = function() {
SelectInput();
};
</script>
-->
% if (config->{debug} == 1) {
<pre>
%= dumper $nut_data
@@ -32,11 +35,11 @@
</div>
<h2 class=""><%=l('nut_Status_of_the_controlled_UPS')%></h2>
<h2><%= l ('nut_Status_of_the_controlled_UPS')%></h2>
<p class="">
%=l('nut_Descriptive_paragraph')
</p>
<div >
<%= l ('nut_Descriptive_paragraph') %>
</div>
<!--
<span class="">

View File

@@ -1,45 +1,107 @@
<h1>UPS Status</h1>
%= stylesheet '/css/nut_ups-status-page.css'
<div class="container-md">
<div>
<h2>Device Information</h2>
<table class="table table-bordered">
<tr><td>Manufacturer:</td><td><%= $nut_data->{'ups_data'}->{'device.mfr'} %></td></tr>
<tr><td>Model:</td><td><%= $nut_data->{'ups_data'}->{'device.model'} %></td></tr>
<tr><td>Serial:</td><td><%= $nut_data->{'ups_data'}->{'device.serial'} %></td></tr>
<tr><td>Type:</td><td><%= $nut_data->{'ups_data'}->{'device.type'} %></td></tr>
</table>
</div>
<div>
<h2>Device Information</h2>
<table class="table table-bordered">
<tr>
<td>Manufacturer:</td>
<td><%= $nut_data->{'ups_data'}->{'device.mfr'} %></td>
</tr>
<tr>
<td>Model:</td>
<td><%= $nut_data->{'ups_data'}->{'device.model'} %></td>
</tr>
<tr>
<td>Serial:</td>
<td><%= $nut_data->{'ups_data'}->{'device.serial'} %></td>
</tr>
<tr>
<td>Type:</td>
<td><%= $nut_data->{'ups_data'}->{'device.type'} %></td>
</tr>
</table>
</div>
<div>
<h2>Battery Status</h2>
<table class="table table-bordered">
<tr><td>Charge:</td><td><%= $nut_data->{'ups_data'}->{'battery.charge'} %>%</td></tr>
<tr><td>Runtime:</td><td><%= sprintf("%.2f", $nut_data->{'ups_data'}->{'battery.runtime'} / 60) %> minutes</td></tr>
<tr><td>Voltage:</td><td><%= $nut_data->{'ups_data'}->{'battery.voltage'} %>V</td></tr>
<tr><td>Type:</td><td><%= $nut_data->{'ups_data'}->{'battery.type'} %></td></tr>
</table>
</div>
<br>
<div>
<h2>Input Power</h2>
<table class="table table-bordered">
<tr><td>Voltage:</td><td><%= $nut_data->{'ups_data'}->{'input.voltage'} %>V</td></tr>
<tr><td>Nominal Voltage:</td><td><%= $nut_data->{'ups_data'}->{'input.voltage.nominal'} %>V</td></tr>
<tr><td>Sensitivity:</td><td><%= $nut_data->{'ups_data'}->{'input.sensitivity'} %></td></tr>
<tr><td>Transfer High:</td><td><%= $nut_data->{'ups_data'}->{'input.transfer.high'} %>V</td></tr>
<tr><td>Transfer Low:</td><td><%= $nut_data->{'ups_data'}->{'input.transfer.low'} %>V</td></tr>
</table>
</div>
<div>
<h2>Battery Status</h2>
<table class="table table-bordered">
<tr>
<td>Charge:</td>
<td><%= $nut_data->{'ups_data'}->{'battery.charge'} %>%</td>
</tr>
<tr>
<td>Runtime:</td>
<td><%= sprintf("%.2f", $nut_data->{'ups_data'}->{'battery.runtime'} / 60) %> minutes</td>
</tr>
<tr>
<td>Voltage:</td>
<td><%= $nut_data->{'ups_data'}->{'battery.voltage'} %>V</td>
</tr>
<tr>
<td>Type:</td>
<td><%= $nut_data->{'ups_data'}->{'battery.type'} %></td>
</tr>
</table>
</div>
<div>
<h2>UPS Status</h2>
<table class="table table-bordered">
<tr><td>Status:</td><td><%= $nut_data->{'ups_data'}->{'ups.status'} %></td></tr>
<tr><td>Load:</td><td><%= $nut_data->{'ups_data'}->{'ups.load'} %>%</td></tr>
<tr><td>Beeper:</td><td><%= $nut_data->{'ups_data'}->{'ups.beeper.status'} %></td></tr>
<tr><td>Firmware:</td><td><%= $nut_data->{'ups_data'}->{'ups.firmware'} %></td></tr>
<tr><td>Test Result:</td><td><%= $nut_data->{'ups_data'}->{'ups.test.result'} %></td></tr>
</table>
</div>
<br>
<div>
<h2>Input Power</h2>
<table class="table table-bordered">
<tr>
<td>Voltage:</td>
<td><%= $nut_data->{'ups_data'}->{'input.voltage'} %>V</td>
</tr>
<tr>
<td>Nominal Voltage:</td>
<td><%= $nut_data->{'ups_data'}->{'input.voltage.nominal'} %>V</td>
</tr>
<tr>
<td>Sensitivity:</td>
<td><%= $nut_data->{'ups_data'}->{'input.sensitivity'} %></td>
</tr>
<tr>
<td>Transfer High:</td>
<td><%= $nut_data->{'ups_data'}->{'input.transfer.high'} %>V</td>
</tr>
<tr>
<td>Transfer Low:</td>
<td><%= $nut_data->{'ups_data'}->{'input.transfer.low'} %>V</td>
</tr>
</table>
</div>
<br>
<div>
<h2>UPS Status</h2>
<table class="table table-bordered">
<tr>
<td>Status:</td>
<td><%= $nut_data->{'ups_data'}->{'ups.status'} %></td>
</tr>
<tr>
<td>Load:</td>
<td><%= $nut_data->{'ups_data'}->{'ups.load'} %>%</td>
</tr>
<tr>
<td>Beeper:</td>
<td><%= $nut_data->{'ups_data'}->{'ups.beeper.status'} %></td>
</tr>
<tr>
<td>Firmware:</td>
<td><%= $nut_data->{'ups_data'}->{'ups.firmware'} %></td>
</tr>
<tr>
<td>Test Result:</td>
<td><%= $nut_data->{'ups_data'}->{'ups.test.result'} %></td>
</tr>
</table>
</div>
</div>

View File

@@ -7,20 +7,6 @@
<br>
% if ($ret{'ret'} eq "") {
% } elsif (index($ret{ret},"SUCCESS") != -1) {
<div class="">
<!--<h2> Operation Status Report</h2>-->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% } else {
<div class="">
<!--<h2> Operation Status Report - Error</h2>-->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% }
% if (config->{debug} == 1) {
<pre>
<%= dumper $c->current_route %>
@@ -28,6 +14,24 @@
</pre>
% }
% if ($ret{'ret'} eq "") {
<div>
<%= $c->render_to_string(inline => l('pf_FIRST_PAGE_DESCRIPTION')); %>
</div>
% } elsif (index($ret{ret},"SUCCESS") != -1) {
<div>
<!--<h2> Operation Status Report</h2>-->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% } else {
<div class="text-danger">
<!--<h2> Operation Status Report - Error</h2>-->
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% }
<br>
<h2><%= l "pf_CREATE_RULE" %></h2>
<form action="/smanager/portforwardingb" method="POST">
@@ -110,7 +114,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -90,7 +90,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -1,11 +1,5 @@
<div>
<form action="/smanager/portforwardinga" method="POST">
<br>
% my $retref = $c->stash("ret");
% my %ret = $retref ? %$retref : (ret => "");
% my @vars = split(/,/, $ret{vars} // '');
@@ -14,24 +8,25 @@
% my $numtcpforwards = @$tcpforwards;
% my $numudpforwards = @$udpforwards;
% if ($c->app->config->{debug}) {
<pre>
%= dumper { ret_data => \%ret }
</pre>
% }
% if ($c->app->config->{debug}) {
<pre>
<%= dumper { ret_data => \%ret } %>
</pre>
% }
% if ($ret{ret} eq "") {
<%= $c->render_to_string(inline => l('pf_FIRST_PAGE_DESCRIPTION')); %>
<div>
<%= $c->render_to_string(inline => l('pf_FIRST_PAGE_DESCRIPTION')); %>
</div>
% } elsif (index($ret{ret},"SUCCESS") != -1) {
<br>
<div>
<div>
<h2> Operation Status Report</h2>
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
% } else {
% } else {
<br>
<div class="text-danger">
<div class="text-danger">
<h2> Operation Status Report - Error</h2>
<%= $c->render_to_string(inline => l($ret{ret}, @vars[0..6])) %>
</div>
@@ -39,26 +34,28 @@
<br>
<form action="/smanager/portforwardinga" method="POST">
% my $btn = l('pf_CREATE_RULE');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
<br>
% if ($empty) {
<br>
<%= l 'pf_NO_FORWARDS' %>
% } else {
<br>
<%= l 'pf_SHOW_FORWARDS' %>
<br><br>
<table class="table table-bordered">
<br>
<%= l 'pf_SHOW_FORWARDS' %>
<br><br>
<table class="table table-bordered">
<thead>
<tr>
<th><%= l 'pf_LABEL_PROTOCOL' %></th>
@@ -95,7 +92,7 @@
% my $csrf_token = "TOKEN"; # CSRF token for security
% my $actionRemove = qq{
% <a href="portforwardingd?CsrfDef=$csrf_token&trt=DEL&sport=$sport&proto=$proto">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>
@@ -103,12 +100,12 @@
<td class="text-center"><%= $c->render_to_string(inline => $actionRemove) %></td>
</tr>
% }
% }
% }
% }
% }
% }
</tbody>
</table>
</tbody>
</table>
<%= hidden_field 'trt' => $pf_datas->{trt} %>
</div>

View File

@@ -53,7 +53,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -30,7 +30,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -9,7 +9,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
@@ -54,7 +54,7 @@
% my $printer_name = $printer->key;
% my $actionRemove = qq{
% <a href="printers2?CsrfDef=$csrf_token&trt=DEL&&printer=$printer_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -37,7 +37,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -14,7 +14,7 @@
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -6,7 +6,7 @@
<%= $c->render_to_string(inline => l('pse_DESCRIPTION')); %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
<%= hidden_field 'trt' => 'ADD' %>
@@ -53,7 +53,7 @@
%my $pseudonyms_entry_name = $pseudonym->key; # pseudonyms_entry name extracted from the data structure
%$actionModify = qq{
% <a href="pseudonyms2?CsrfDef=$csrf_token&trt=UPD&pseudonym=$pseudonyms_entry_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>
@@ -66,7 +66,7 @@
%my $pseudonyms_entry_name = $pseudonym->key; # pseudonyms_entry name extracted from the data structure
%$actionRemove = qq{
% <a href="pseudonyms2?CsrfDef=$csrf_token&trt=DEL&pseudonym=$pseudonyms_entry_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
% </a>

View File

@@ -62,7 +62,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -71,7 +71,7 @@
% my $quota_user_name = $user->key; # quotas_entry name extracted from the data structure
% my $actionModify = qq{
% <a href="quotad?CsrfDef=$csrf_token&trt=UPD&user=$quota_user_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
% </a>

View File

@@ -85,7 +85,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -31,7 +31,7 @@
</div>
<div class="col-auto">
<button type="submit" class="btn btn-primary">Theme</button>
<button type="submit" class="btn btn-primary btn-sm">Theme</button>
</div>
</div>
</form>

View File

@@ -40,7 +40,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-danger"><%= $btn %></button>
<button type="submit" class="btn btn-danger btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -5,7 +5,7 @@
<form action="/smanager/useraccounts" method="POST">
<br>
<div>
<button type="submit" class="btn btn-primary"><%= $btn %> </button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %> </button>
</div>
</form>
@@ -63,14 +63,14 @@
% if ($useraccounts_user_name eq 'admin') {
%$actionModify = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=UPS&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$modify_text'>
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text'>
% $modify_text
% </button>
%</a>
%};
%$actionResetPw = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=PWS&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$password_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$password_text' >
% $password_text
% </button>
%</a>
@@ -78,7 +78,7 @@
% } else {
%$actionModify = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=UPD&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$modify_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$modify_text' >
% $modify_text
% </button>
%</a>
@@ -93,14 +93,14 @@
<!-- Sets BOTH columns - possibly leave out Reset Password here?-->
%$actionLock = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=PWD&user=$useraccounts_user_name">
% <button type='button' class="btn btn-danger" title="$password_text - currently unset">
% <button type='button' class="btn btn-danger btn-sm" title="$password_text - currently unset">
% Unlock
% </button>
%</a>
%};
%$actionResetPw = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=PWD&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title="$password_text - currently unset">
% <button type='button' class="btn btn-primary btn-sm" title="$password_text - currently unset">
% $password_text
% </button>
%</a>
@@ -109,14 +109,14 @@
% } elsif ($useraccounts_user_name ne 'admin') {
%$actionLock = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=LCK&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$lock_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$lock_text' >
% $lock_text
% </button>
%</a>
%};
%$actionResetPw = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=PWD&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$password_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$password_text' >
% $password_text
% </button>
%</a>
@@ -126,7 +126,7 @@
% if ( $removable eq 'yes' ) {
%$actionRemove = qq{
%<a href="useraccountsd?CsrfDef=$csrf_token&trt=DEL&user=$useraccounts_user_name">
% <button type='button' class="btn btn-primary" title='$remove_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$remove_text' >
% $remove_text
% </button>
%</a>
@@ -136,7 +136,7 @@
<!-- If webmail disabled??? -->
% $actionroundcube = qq{
%<a href="roundcubepanel?CsrfDef=$csrf_token&url=https://$thisdomain/roundcube?_user=$useraccounts_user_name&height=600px">
% <button type='button' class="btn btn-primary" title='$roundcube_text' >
% <button type='button' class="btn btn-primary btn-sm" title='$roundcube_text' >
% $roundcube_text
% </button>
%</a>

View File

@@ -42,7 +42,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -75,7 +75,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -64,7 +64,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -279,7 +279,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -105,7 +105,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= l 'SAVE' %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= l 'SAVE' %></button>
</div>
</div>

View File

@@ -66,7 +66,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -2,10 +2,6 @@
% content_for 'module' => begin
<!-- should be moved -->
%= javascript '/js/qmailanalog.js'
<div class="card-body">
% if (config->{debug} == 1) {
@@ -60,7 +56,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -40,7 +40,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>

View File

@@ -277,7 +277,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -59,7 +59,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -106,7 +106,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -101,7 +101,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -25,7 +25,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -92,7 +92,7 @@
<div class="row g-3 align-items-center">
<div class="col-md-1">
<button type="submit" class="btn btn-primary"><%= $btn %></button>
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>

View File

@@ -5,117 +5,141 @@
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
% if ( $notif ) {
<br>
<span class="">
%= $notif
</span>
%}
<br>
<div class="text-warn">
<%= $notif %>
</div>
<br>
% }
% if ( $c->is_empty('updates') ) {
<br>
<div class=""><h2>
%=l 'yum_TITLE_UPTODATE'
</h2>
%=l 'yum_DESC_UPTODATE'
</div>
<br>
%}
<br>
<div>
<h2><%=l 'yum_TITLE_UPTODATE' %></h2>
<br>
<%=l 'yum_DESC_UPTODATE' %>
</div>
<br>
% }
% if ( $c->non_empty('updates') ) {
<br>
<div class="">
<h2>
%=l 'yum_TITLE_UPDATES_AVAILABLE'
</h2>
%=l 'yum_DESC_UPDATES_AVAILABLE'
</div>
<br>
<br>
<div>
<h2><%= l 'yum_TITLE_UPDATES_AVAILABLE' %></h2>
<%= l 'yum_DESC_UPDATES_AVAILABLE' %>
</div>
<br>
%= form_for 'yum' => (method => 'POST') => begin
%= hidden_field 'trt' => 'UPDT'
%= submit_button $c->l('yum_BUTTON_INSTALL_UPDATES'), class => ""
% end
%}
<form action="/smanager/yum" method="POST">
% my $btnInUp = $c->l('yum_BUTTON_INSTALL_UPDATES');
<%= hidden_field 'trt' => 'UPDT' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnInUp %></button>
</div>
</div>
</form>
% }
% if ( $c->non_empty('available') ) {
%= form_for 'yum' => (method => 'POST') => begin
<br>
%= hidden_field 'trt' => 'INST'
%= submit_button $c->l('yum_BUTTON_INSTALL_AVAILABLE'), class => ""
% end
%}
<form action="/smanager/yum" method="POST">
<br>
% my $btnInAv = $c->l('yum_BUTTON_INSTALL_AVAILABLE');
<%= hidden_field 'trt' => 'INST' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnInAv %></button>
</div>
</div>
</form>
% }
% if ( $c->non_empty('installed') ) {
%= form_for 'yum' => (method => 'POST') => begin
<br>
%= hidden_field 'trt' => 'REMO'
%= submit_button $c->l('yum_BUTTON_REMOVE'), class => ""
% end
%}
<form action="/smanager/yum" method="POST">
<br>
% my $btnInRm = $c->l('yum_BUTTON_REMOVE');
<%= hidden_field 'trt' => 'REMO' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnInRm %></button>
</div>
</div>
% }
</form>
<br>
<!--<br><hr class=""><br>-->
%= form_for 'yum' => (method => 'POST') => begin
<form action="/smanager/yum" method="POST">
<p>
<span class="">
%=l 'yum_LABEL_YUM_STATUS'
</span>
<span class="">
%= $c->get_status('status', 'localise')
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-2 border-bottom">
<%= l 'yum_LABEL_YUM_STATUS' %>
</div>
<div class="col-auto border-bottom">
<%= $c->get_status('status', 'localise') %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_PACKAGEFUNCTIONS'
</span>
<span class="">
%= $c->get_status('PackageFunctions', 'localise')
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-2 border-bottom">
<%= l 'yum_LABEL_YUM_PACKAGEFUNCTIONS' %>
</div>
<div class="col-auto border-bottom">
<%= $c->get_status('PackageFunctions', 'localise') %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_DELTARPMPROCESS'
</span>
<span class="">
%= $c->get_status('DeltaRpmProcess', 'localise')
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-2 border-bottom">
<%= l 'yum_LABEL_YUM_DELTARPMPROCESS' %>
</div>
<div class="col-auto border-bottom">
<%= $c->get_status('DeltaRpmProcess', 'localise') %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_DOWNLOADONLY'
</span>
<span class="">
%= $c->get_status('DownloadOnly', 'localise')
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-2 border-bottom">
<%= l 'yum_LABEL_YUM_DOWNLOADONLY' %>
</div>
<div class="col-auto border-bottom">
<%= $c->get_status('DownloadOnly', 'localise') %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_AUTOINSTALLUPDATES'
</span>
<span class="">
%= $c->get_status('AutoInstallUpdates', 'localise')
</span>
</p>
<div class="row g-3 align-items-center">
<div class="col-md-2 border-bottom">
<%= l 'yum_LABEL_YUM_AUTOINSTALLUPDATES' %>
</div>
<div class="col-auto border-bottom">
<%= $c->get_status('AutoInstallUpdates', 'localise') %>
</div>
</div>
%= hidden_field 'trt' => 'CONF'
<br>
%= submit_button $c->l('yum_BUTTON_CONFIGURATION'), class => ""
<br>
% end
% my $btnConfig = $c->l('yum_BUTTON_CONFIGURATION');
<%= hidden_field 'trt' => 'CONF' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnConfig %></button>
</div>
</div>
</form>
</div>

View File

@@ -5,105 +5,157 @@
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
% if ( $notif ) {
<br>
<div class="">
%= $notif
</div>
%}
<br>
<div class="text-warn">
<%= $notif %>
</div>
<br>
% }
%= form_for 'yumd' => (method => 'POST') => begin
<p>
<span class="">
%=l 'yum_LABEL_YUM_STATUS'
</span>
<span class="">
% param 'yum_check4updates' => $c->get_status('check4updates') unless param 'yum_check4updates';
%= select_field 'yum_check4updates' => $c->get_check_freq_opt()
</span>
</p>
<form action="/smanager/yumd" method="POST">
<br>
%=l 'yum_DESC_YUM_PACKAGEFUNCTIONS'
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_YUM_STATUS' %>
</div>
<div class="col-auto">
% param 'yum_check4updates' => $c->get_status('check4updates') unless param 'yum_check4updates';
<%= select_field 'yum_check4updates' => $c->get_check_freq_opt(), class => "form-select" %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_PACKAGEFUNCTIONS'
</span>
<span class="">
% param 'yum_PackageFunctions' => $c->get_status('PackageFunctions') unless param 'yum_PackageFunctions';
%= select_field 'yum_PackageFunctions' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']]
</span>
</p>
<br>
<br>
%=l 'yum_DESC_ENABLED_REPOSITORIES'
<%= l 'yum_DESC_YUM_PACKAGEFUNCTIONS' %>
<p>
<span class="">
%=l 'yum_LABEL_ENABLED_REPOSITORIES'
</span>
<span class="">
% param 'SelectedRepositories' => $c->get_repository_current_options() unless param 'SelectedRepositories';
%= select_field 'SelectedRepositories' => $c->get_repository_options2(), class => "", multiple => '1'
</span>
</p>
<br><br>
<br>
%=l 'yum_DESC_YUM_DELTARPMPROCESS'
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_YUM_PACKAGEFUNCTIONS' %>
</div>
<div class="col-auto">
% param 'yum_PackageFunctions' => $c->get_status('PackageFunctions') unless param 'yum_PackageFunctions';
<%= select_field 'yum_PackageFunctions' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
<p>
<span class="">
%=l 'yum_LABEL_YUM_DELTARPMPROCESS'
</span>
<span class="">
% param 'yum_DeltaRpmProcess' => $c->get_status('DeltaRpmProcess') unless param 'yum_DeltaRpmProcess';
%= select_field 'yum_DeltaRpmProcess' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']]
</span>
</p>
<br>
<br>
%=l 'yum_DESC_YUM_DOWNLOADONLY'
<%= l 'yum_DESC_ENABLED_REPOSITORIES' %>
<p>
<span class="">
%=l 'yum_LABEL_YUM_DOWNLOADONLY'
</span>
<span class="">
% param 'yum_DownloadOnly' => $c->get_status('DownloadOnly') unless param 'yum_DownloadOnly';
%= select_field 'yum_DownloadOnly' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']]
</span>
</p>
<br><br>
<br>
%=l 'yum_DESC_YUM_AUTOINSTALLUPDATES'
<br>
<p>
<span class="">
%=l 'yum_LABEL_YUM_AUTOINSTALLUPDATES'
</span>
<span class="">
% param 'yum_AutoInstallUpdates' => $c->get_status('AutoInstallUpdates') unless param 'yum_AutoInstallUpdates';
%= select_field 'yum_AutoInstallUpdates' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']]
</span>
</p>
%= hidden_field 'trt' => 'CONF'
<br>
<!--<div class="">-->
%= submit_button $c->l('SAVE'), class => ""
<!--</div>-->
% end
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_ENABLED_REPOSITORIES' %>
</div>
<div class="col-auto">
% param 'SelectedRepositories' => $c->get_repository_current_options() unless param 'SelectedRepositories';
<%= select_field 'SelectedRepositories' => $c->get_repository_options2(), multiple => '1', size => "16", class => "form-select" %>
</div>
</div>
<br>
<%= dumper $c->get_repository_options2() %>
<br>
<%= dumper $c->get_repository_current_options () %>
<br>
<%= dumper $c->every_param('SelectedRepositories') %>
<br>
%# my @repo ();
%# my %repositories = $c->get_repository_options2();
<%#= dumper %repositories %>
%# foreach my @repository (keys %$repositories) {
<%#= dumper @repository %>
<br>
%# my $repoName = $_->{Name};
%# my $repoStatus = $_ -> {Status};
%# }
<br>
<%= l 'yum_DESC_YUM_DELTARPMPROCESS' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_YUM_DELTARPMPROCESS' %>
</div>
<div class="col-auto">
% param 'yum_DeltaRpmProcess' => $c->get_status('DeltaRpmProcess') unless param 'yum_DeltaRpmProcess';
<%= select_field 'yum_DeltaRpmProcess' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
<br>
<%= l 'yum_DESC_YUM_DOWNLOADONLY' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_YUM_DOWNLOADONLY' %>
</div>
<div class="col-auto">
% param 'yum_DownloadOnly' => $c->get_status('DownloadOnly') unless param 'yum_DownloadOnly';
<%= select_field 'yum_DownloadOnly' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
<br>
<%= l 'yum_DESC_YUM_AUTOINSTALLUPDATES' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<%= l 'yum_LABEL_YUM_AUTOINSTALLUPDATES' %>
</div>
<div class="col-auto">
% param 'yum_AutoInstallUpdates' => $c->get_status('AutoInstallUpdates') unless param 'yum_AutoInstallUpdates';
<%= select_field 'yum_AutoInstallUpdates' => [[ $c->l('DISABLED') => 'disabled'], [ $c->l('ENABLED') => 'enabled']], class => "form-select" %>
</div>
</div>
<br>
% my $btnSave = $c->l('SAVE');
<%= hidden_field 'trt' => 'CONF' %>
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnSave %></button>
</div>
</div>
</form>
</div>

View File

@@ -5,61 +5,79 @@
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
% if ( $notif ) {
<br>
<div class="">
%= $notif
</div>
%}
<br>
<br>
<div class="text-warn">
<%= $notif %>
</div>
<br>
% }
%= form_for 'yumd' => (method => 'POST') => begin
<form action="/smanager/yumd" method="POST">
%=l 'yum_HEADER_AVAILABLE_SOFTWARE'
<br><br>
% if ($c->non_empty('available','group')) {
%=l 'yum_DESC_AVAILABLE_GROUPS'
<p>
<span class="">
%=l 'yum_LABEL_AVAILABLE_GROUPS'
</span>
<span class="">
% param 'SelectedGroups' => $c->get_names2('updates','group') unless param 'SelectedGroups';
%= select_field 'SelectedGroups' => $c->get_options2('available', 'group'), class => "", multiple => "1"
</span>
</p>
%}
<br>
% if ($c->non_empty('available','packages')) {
%=l 'yum_DESC_AVAILABLE_PACKAGES'
<p>
<span class="">
%=l 'yum_LABEL_AVAILABLE_PACKAGES'
</span>
<span class="">
% param 'SelectedPackages' => $c->get_names2('updates','package') unless param 'SelectedPackages';
%= select_field 'SelectedPackages' => $c->get_options2('available', 'package'), class => "", multiple => "1"
</span>
</p>
%}
<%= l 'yum_HEADER_AVAILABLE_SOFTWARE' %>
<!-- $c->print_skip_header() -->
<br><br>
%= hidden_field 'trt' => 'INST'
<br><br>
<!-- <div class="">-->
%= submit_button $c->l('yum_INSTALL_SOFTWARE'), class => ""
<!--</div>-->
% if ($c->non_empty('available','group')) {
<%=l 'yum_DESC_AVAILABLE_GROUPS' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'yum_LABEL_AVAILABLE_GROUPS' %>
</div>
<div class="col-md-3">
% param 'SelectedGroups' => $c->get_names2('updates','group') unless param 'SelectedGroups';
<%= select_field 'SelectedGroups' => $c->get_options2('available', 'group'), class => "form-select", size => "10", multiple => "1" %>
</div>
</div>
% }
<br><br>
% if ($c->non_empty('available','packages')) {
<%= l 'yum_DESC_AVAILABLE_PACKAGES' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%=l 'yum_LABEL_AVAILABLE_PACKAGES' %>
</div>
<div class="col-md-3">
% param 'SelectedPackages' => $c->get_names2('updates','package') unless param 'SelectedPackages';
%= select_field 'SelectedPackages' => $c->get_options2('available', 'package'), class => "form-select", size => "10", multiple => "1"
</div>
</div>
% }
<!-- $c->print_skip_header() -->
<br>
<%= hidden_field 'trt' => 'INST' %>
% my $btnSave = $c->l('yum_INSTALL_SOFTWARE');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btnSave %></button>
</div>
</div>
</form>
% end
</div>

View File

@@ -9,35 +9,39 @@
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
% if ( $notif ) {
<br>
<div class="text-warn">
<%= $notif %>
</div>
<br>
% }
<form action="/smanager/yum" method="POST">
<br>
<div class="">
%= $notif
</div>
%}
<h2>Please Wait - Yum Running (<%= $c->get_yum_status_page() %>)</h2>
%= form_for 'yum' => (method => 'POST') => begin
<BR><center><H2>Please Wait - Yum Running (<%= $c->get_yum_status_page() %>)</H2></center>
<%= $c->render_to_string(inline => $c->format_yum_log()) %>
%= hidden_field 'trt' => 'LOGF'
<br>
<!-- div class="">
prc= submit_button $c->l('NEXT'), class => ""
</div -->
% end
</form>
</div>

View File

@@ -1,62 +1,84 @@
% layout 'AdminLTE', title => "Sme server 2 - yum_update";
% layout 'AdminLTE', title => "Sme server 2 - yum_remove";
% content_for 'module' => begin
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
<br>
% if ( $notif ) {
<br><div class="">
%= $notif
</div>
%}
<br>
<div class="text-warn">
<%= $notif %>
</div>
<br>
% }
%= form_for 'yumd' => (method => 'POST') => begin
<form action="/smanager/yumd" method="POST">
%=l 'yum_HEADER_INSTALLED_SOFTWARE'
<%= l 'yum_HEADER_INSTALLED_SOFTWARE' %>
<br>
% if ($c->non_empty('installed','group')) {
%=l 'yum_DESC_INSTALLED_GROUPS'
<p>
<span class="">
%=l 'yum_LABEL_INSTALLED_GROUPS'
</span>
<span class="">
%= select_field 'SelectedGroups' => $c->get_options2('installed', 'group'), class => "", multiple => "1"
</span></p>
%}
<br>
% if ($c->non_empty('installed','packages')) {
%=l 'yum_DESC_INSTALLED_PACKAGES'
<p>
<span class="">
%=l 'yum_LABEL_INSTALLED_PACKAGES'
</span>
<span class="">
%= select_field 'SelectedPackages' => $c->get_options2('installed', 'package'), class => "", multiple => "1"
</span>
</p>
%}
<br>
<!--subroutine src="print_skip_header()" /-->
% if ($c->non_empty('installed','group')) {
%= hidden_field 'trt' => 'REMO'
<br>
<!--<div class="">-->
%= submit_button $c->l('REMOVE'), class => ""
<!--</div>-->
<%=l 'yum_DESC_INSTALLED_GROUPS' %>
% end
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%= l 'yum_LABEL_INSTALLED_GROUPS' %>
</div>
<div class="col-md-3">
%# param 'SelectedGroups' => $c->get_names2('updates','group') unless param 'SelectedGroups';
<%= select_field 'SelectedGroups' => $c->get_options2('installed', 'group'), class => "form-select", size => "10", multiple => "1" %>
</div>
</div>
% }
<br><br>
% if ($c->non_empty('installed','packages')) {
<%= l 'yum_DESC_INSTALLED_PACKAGES' %>
<br><br>
<div class="row g-3 align-items-center">
<div class="col-md-1">
<%=l 'yum_LABEL_INSTALLED_PACKAGES' %>
</div>
<div class="col-md-3">
%# param 'SelectedPackages' => $c->get_names2('updates','package') unless param 'SelectedPackages';
%= select_field 'SelectedPackages' => $c->get_options2('installed', 'package'), class => "form-select", size => "10", multiple => "1"
</div>
</div>
% }
<!--subroutine src="print_skip_header()" /-->
<br>
<%= hidden_field 'trt' => 'REMO' %>
% my $btn = $c->l('REMOVE');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
</div>

View File

@@ -5,43 +5,52 @@
<div class="card-body">
% if (config->{debug} == 1) {
<p>
%= dumper $c->current_route
%= dumper $yum_datas
</p>
<pre>
<%= dumper $c->current_route %>
<%= dumper $yum_datas %>
</pre>
% }
<h1><%= $title%></h1>
% if ( $notif ) {
<br><div class="">
%= $notif
</div>
%}
<br>
<div class="text-warn">
<%= $notif %>
</div>
% }
%= form_for 'yumd' => (method => 'POST') => begin
<form action="/smanager/yumd" method="POST">
%=l 'yum_DESC_AVAILABLE_UPDATES'
<div>
<%=l 'yum_DESC_AVAILABLE_UPDATES' %>
</div>
<p>
<span class="">
%=l 'yum_LABEL_AVAILABLE_UPDATES'
</span>
<span class="">
% param 'SelectedPackages' => $c->get_names2('updates','package') unless param 'SelectedPackages';
%= select_field 'SelectedPackages' => $c->get_options2('updates', 'package'), class => "", multiple => "1"
</span>
</p>
<div>
<%=l 'yum_LABEL_AVAILABLE_UPDATES' %>
</div>
<!-- $c->print_skip_header() -->
<div>
% param 'SelectedPackages' => $c->get_names2('updates','package') unless param 'SelectedPackages';
<%= select_field 'SelectedPackages' => $c->get_options2('updates', 'package'), class => "form-select", multiple => "1" %>
</div>
%= hidden_field 'trt' => 'UPDT'
<br>
<!--<div class="">-->
%= submit_button $c->l('yum_INSTALL_UPDATES'), class => ""
<!--</div>-->
<!-- $c->print_skip_header() -->
<%= hidden_field 'trt' => 'UPDT' %>
<br>
% $btn = $c->l('yum_INSTALL_UPDATES');
<div class="row g-3 align-items-center">
<div class="col-md-2">
<button type="submit" class="btn btn-primary btn-sm"><%= $btn %></button>
</div>
</div>
</form>
% end
</div>

View File

@@ -1,6 +1,7 @@
%define name smeserver-manager-AdminLTE
%define version 11.0.0
%define release 37
%define release 43
Summary: AdminLTE is an html framework for admin consoles - this rpm adds it to smeserver manager2
Name: %{name}
Version: %{version}
@@ -16,7 +17,7 @@ BuildArchitectures: noarch
BuildRoot: /var/tmp/%{name}-%{version}-%{release}-buildroot
BuildRequires: smeserver-devtools
Requires: smeserver-release >= 11.0
Requires: smeserver-manager >= 11.0.0-91
Requires: smeserver-manager >= 11.0.0-101
Requires: smeserver-lib >= 11.0.0-13
Requires: e-smith-manager >= 2.4.0-22
@@ -28,6 +29,33 @@ AdminLTE is an html framework for admin consoles
wget https://github.com/ColorlibHQ/AdminLTE/archive/master.zip
%changelog
* Sun Jul 06 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-43.sme
- Make buttons smaller
- Fix mail_data instances
- Update email templates
- Lots of tweaks including reduced button sizes
- refactor CSS and JS files
* Thu Jun 26 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-42.sme
- Finish Software updater
* Thu Jun 19 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-41.sme
- Work on NutUPS
- Work on DateTime
- Work on Letsencrypt
- Fix usr panel typo
* Wed Jun 18 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-40.sme
- Finish Letsencrypt panels
- fix CSS and _usr files typo
* Tue Jun 17 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-39.sme
- Start Letsencrypt panels
* Fri Jun 13 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-38.sme
- More formatting for LocalNetworks
- More formatting for PortForwards
* Fri Jun 13 2025 John Crisp <jcrisp@safeandsoundit.co.uk> 11.0.0-37.sme
- Finish portforwarding to work with [SME:13043]