add missing function

This commit is contained in:
usmannasir
2025-04-04 15:13:57 +05:00
parent 867d5abea9
commit 2ad810d628
5 changed files with 10417 additions and 1587 deletions

View File

@@ -2674,14 +2674,10 @@ app.controller('listWebsites', function ($scope, $http, $window) {
// Call it immediately
$scope.getFurtherWebsitesFromDB();
$scope.showWPSites = function(index) {
$scope.selectedWebsite = $scope.WebSitesList[index];
if (!$scope.selectedWebsite.wp_sites) {
$scope.showWPSites = function(domain) {
var url = '/websites/fetchWPDetails';
var data = {
domain: $scope.selectedWebsite.domain,
websiteName: $scope.selectedWebsite.domain
domain: domain
};
$http({
@@ -2693,92 +2689,10 @@ app.controller('listWebsites', function ($scope, $http, $window) {
'X-CSRFToken': getCookie('csrftoken')
}
}).then(function(response) {
console.log('WP Details Response:', response);
// Check if response is HTML (login page)
if (typeof response.data === 'string' && response.data.includes('<!DOCTYPE html>')) {
console.log('Received HTML response, redirecting to login');
window.location.href = '/login';
return;
}
if (response.data && response.data.status === 1) {
try {
// If single site, wrap in array
var sites = Array.isArray(response.data.data) ? response.data.data : [response.data.data];
$scope.selectedWebsite.wp_sites = sites.map(function(site) {
return {
id: site.id || $scope.selectedWebsite.domain,
title: site.title || site.domain || $scope.selectedWebsite.domain,
url: site.url || 'http://' + $scope.selectedWebsite.domain,
version: site.version || 'Unknown',
phpVersion: site.php_version || 'Unknown',
theme: site.theme || 'Unknown',
activePlugins: site.active_plugins || 0,
searchIndex: site.search_index === 'enabled',
debugging: site.debugging === 'enabled',
passwordProtection: site.password_protection === 'enabled',
maintenanceMode: site.maintenance_mode === 'enabled'
};
});
$scope.selectedWebsite.showWPSites = true;
} catch (e) {
console.error('Error processing WordPress data:', e);
// Create default site on error
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
}
} else {
// Create default site if no data
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
}
alert(JSON.stringify(response.data, null, 2));
}).catch(function(error) {
console.error('WP Details Error:', error);
// Create default site on error
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
alert('Error fetching WordPress sites: ' + JSON.stringify(error));
});
} else {
$scope.selectedWebsite.showWPSites = !$scope.selectedWebsite.showWPSites;
}
};
$scope.visitSite = function(url) {
@@ -6648,14 +6562,10 @@ app.controller('manageAliasController', function ($scope, $http, $timeout, $wind
}
$scope.showWPSites = function(index) {
$scope.selectedWebsite = $scope.WebSitesList[index];
if (!$scope.selectedWebsite.wp_sites) {
$scope.showWPSites = function(domain) {
var url = '/websites/fetchWPDetails';
var data = {
domain: $scope.selectedWebsite.domain,
websiteName: $scope.selectedWebsite.domain
domain: domain
};
$http({
@@ -6667,92 +6577,10 @@ app.controller('manageAliasController', function ($scope, $http, $timeout, $wind
'X-CSRFToken': getCookie('csrftoken')
}
}).then(function(response) {
console.log('WP Details Response:', response);
// Check if response is HTML (login page)
if (typeof response.data === 'string' && response.data.includes('<!DOCTYPE html>')) {
console.log('Received HTML response, redirecting to login');
window.location.href = '/login';
return;
}
if (response.data && response.data.status === 1) {
try {
// If single site, wrap in array
var sites = Array.isArray(response.data.data) ? response.data.data : [response.data.data];
$scope.selectedWebsite.wp_sites = sites.map(function(site) {
return {
id: site.id || $scope.selectedWebsite.domain,
title: site.title || site.domain || $scope.selectedWebsite.domain,
url: site.url || 'http://' + $scope.selectedWebsite.domain,
version: site.version || 'Unknown',
phpVersion: site.php_version || 'Unknown',
theme: site.theme || 'Unknown',
activePlugins: site.active_plugins || 0,
searchIndex: site.search_index === 'enabled',
debugging: site.debugging === 'enabled',
passwordProtection: site.password_protection === 'enabled',
maintenanceMode: site.maintenance_mode === 'enabled'
};
});
$scope.selectedWebsite.showWPSites = true;
} catch(e) {
console.error('Error processing WordPress data:', e);
// Create default site on error
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
}
} else {
// Create default site if no data
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
}
alert(JSON.stringify(response.data, null, 2));
}).catch(function(error) {
console.error('WP Details Error:', error);
// Create default site on error
$scope.selectedWebsite.wp_sites = [{
id: $scope.selectedWebsite.domain,
title: $scope.selectedWebsite.domain,
url: 'http://' + $scope.selectedWebsite.domain,
version: 'Unknown',
phpVersion: 'Unknown',
theme: 'Unknown',
activePlugins: 0,
searchIndex: false,
debugging: false,
passwordProtection: false,
maintenanceMode: false
}];
$scope.selectedWebsite.showWPSites = true;
alert('Error fetching WordPress sites: ' + JSON.stringify(error));
});
} else {
$scope.selectedWebsite.showWPSites = !$scope.selectedWebsite.showWPSites;
}
};
$scope.updateSetting = function(wp, setting) {

View File

@@ -101,7 +101,7 @@
<span ng-bind="web.admin" style="text-transform: none"></span>
</div>
<div class="col-md-3 content-box-header">
<i class="p fa fa-wordpress btn-icon text-muted" ng-click="showWPSites($index)"
<i class="p fa fa-wordpress btn-icon text-muted" ng-click="showWPSites(web.domain)"
data-toggle="tooltip" data-placement="right" title="Show WordPress Sites">&emsp;</i>
<span ng-if="web.wp_sites && web.wp_sites.length > 0" style="text-transform: none">
{$ web.wp_sites.length $} WordPress Sites

View File

@@ -51,6 +51,7 @@ urlpatterns = [
path('AddWPsiteforRemoteBackup', views.AddWPsiteforRemoteBackup, name='AddWPsiteforRemoteBackup'),
path('UpdateRemoteschedules', views.UpdateRemoteschedules, name='UpdateRemoteschedules'),
path('ScanWordpressSite', views.ScanWordpressSite, name='ScanWordpressSite'),
path('fetchWPDetails', views.fetchWPDetails, name='fetchWPDetails'),
# AddPlugin
path('ConfigurePlugins', views.ConfigurePlugins, name='ConfigurePlugins'),

View File

@@ -1842,3 +1842,12 @@ def Dockersitehome(request, dockerapp):
return wm.Dockersitehome(request, userID, None)
except KeyError:
return redirect(loadLoginPage)
def fetchWPDetails(request):
try:
userID = request.session['userID']
data = json.loads(request.body)
wm = WebsiteManager()
return wm.fetchWPSitesForDomain(userID, data)
except KeyError:
return redirect(loadLoginPage)

File diff suppressed because it is too large Load Diff