mirror of
https://github.com/usmannasir/cyberpanel.git
synced 2025-11-11 15:56:11 +01:00
additional n8n functions
This commit is contained in:
107
websiteFunctions/dockerviews.py
Normal file
107
websiteFunctions/dockerviews.py
Normal file
@@ -0,0 +1,107 @@
|
|||||||
|
import json
|
||||||
|
import docker
|
||||||
|
from django.http import HttpResponse
|
||||||
|
from .models import DockerSites
|
||||||
|
from .website import ACLManager
|
||||||
|
from django.shortcuts import redirect
|
||||||
|
from plogical.CyberCPLogFileWriter import CyberCPLogFileWriter as logging
|
||||||
|
|
||||||
|
def loadLoginPage(request):
|
||||||
|
return redirect('/login')
|
||||||
|
|
||||||
|
class DockerManager:
|
||||||
|
def __init__(self):
|
||||||
|
self.client = docker.from_env()
|
||||||
|
|
||||||
|
def get_container(self, container_id):
|
||||||
|
try:
|
||||||
|
return self.client.containers.get(container_id)
|
||||||
|
except docker.errors.NotFound:
|
||||||
|
return None
|
||||||
|
except Exception as e:
|
||||||
|
logging.writeToFile(f"Error getting container {container_id}: {str(e)}")
|
||||||
|
return None
|
||||||
|
|
||||||
|
def require_login(view_func):
|
||||||
|
def wrapper(request, *args, **kwargs):
|
||||||
|
try:
|
||||||
|
userID = request.session['userID']
|
||||||
|
return view_func(request, userID, *args, **kwargs)
|
||||||
|
except KeyError:
|
||||||
|
return redirect(loadLoginPage)
|
||||||
|
return wrapper
|
||||||
|
|
||||||
|
@require_login
|
||||||
|
def startContainer(request, userID):
|
||||||
|
try:
|
||||||
|
data = json.loads(request.body)
|
||||||
|
container_id = data.get('container_id')
|
||||||
|
site_name = data.get('name')
|
||||||
|
|
||||||
|
# Verify ownership
|
||||||
|
docker_site = DockerSites.objects.get(SiteName=site_name)
|
||||||
|
if not ACLManager.checkOwnership(docker_site.admin.domain, userID):
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Unauthorized access'}))
|
||||||
|
|
||||||
|
# Get and start container
|
||||||
|
docker_manager = DockerManager()
|
||||||
|
container = docker_manager.get_container(container_id)
|
||||||
|
|
||||||
|
if not container:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Container not found'}))
|
||||||
|
|
||||||
|
container.start()
|
||||||
|
return HttpResponse(json.dumps({'status': 1}))
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': str(e)}))
|
||||||
|
|
||||||
|
@require_login
|
||||||
|
def stopContainer(request, userID):
|
||||||
|
try:
|
||||||
|
data = json.loads(request.body)
|
||||||
|
container_id = data.get('container_id')
|
||||||
|
site_name = data.get('name')
|
||||||
|
|
||||||
|
# Verify ownership
|
||||||
|
docker_site = DockerSites.objects.get(SiteName=site_name)
|
||||||
|
if not ACLManager.checkOwnership(docker_site.admin.domain, userID):
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Unauthorized access'}))
|
||||||
|
|
||||||
|
# Get and stop container
|
||||||
|
docker_manager = DockerManager()
|
||||||
|
container = docker_manager.get_container(container_id)
|
||||||
|
|
||||||
|
if not container:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Container not found'}))
|
||||||
|
|
||||||
|
container.stop()
|
||||||
|
return HttpResponse(json.dumps({'status': 1}))
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': str(e)}))
|
||||||
|
|
||||||
|
@require_login
|
||||||
|
def restartContainer(request, userID):
|
||||||
|
try:
|
||||||
|
data = json.loads(request.body)
|
||||||
|
container_id = data.get('container_id')
|
||||||
|
site_name = data.get('name')
|
||||||
|
|
||||||
|
# Verify ownership
|
||||||
|
docker_site = DockerSites.objects.get(SiteName=site_name)
|
||||||
|
if not ACLManager.checkOwnership(docker_site.admin.domain, userID):
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Unauthorized access'}))
|
||||||
|
|
||||||
|
# Get and restart container
|
||||||
|
docker_manager = DockerManager()
|
||||||
|
container = docker_manager.get_container(container_id)
|
||||||
|
|
||||||
|
if not container:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': 'Container not found'}))
|
||||||
|
|
||||||
|
container.restart()
|
||||||
|
return HttpResponse(json.dumps({'status': 1}))
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return HttpResponse(json.dumps({'status': 0, 'error_message': str(e)}))
|
||||||
@@ -209,24 +209,25 @@ app.controller('ListDockersitecontainer', function ($scope, $http) {
|
|||||||
$scope.cyberpanelLoading = false;
|
$scope.cyberpanelLoading = false;
|
||||||
$('#cyberpanelLoading').show();
|
$('#cyberpanelLoading').show();
|
||||||
|
|
||||||
var url;
|
var url = "/docker/";
|
||||||
switch(action) {
|
switch(action) {
|
||||||
case 'start':
|
case 'start':
|
||||||
url = "/docker/StartContainerAPP";
|
url += "startContainer";
|
||||||
break;
|
break;
|
||||||
case 'stop':
|
case 'stop':
|
||||||
url = "/docker/StopContainerAPP";
|
url += "stopContainer";
|
||||||
break;
|
break;
|
||||||
case 'restart':
|
case 'restart':
|
||||||
url = "/docker/RestartContainerAPP";
|
url += "restartContainer";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
console.error("Unknown action:", action);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var data = {
|
var data = {
|
||||||
'name': $('#sitename').html(),
|
'name': $('#sitename').html(),
|
||||||
'id': $scope.selectedContainer.id
|
'container_id': $scope.selectedContainer.id
|
||||||
};
|
};
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
@@ -235,38 +236,55 @@ app.controller('ListDockersitecontainer', function ($scope, $http) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
$http.post(url, data, config).then(ListInitialData, cantLoadInitialData);
|
$http.post(url, data, config).then(
|
||||||
|
function(response) {
|
||||||
|
$scope.cyberpanelLoading = true;
|
||||||
|
$('#cyberpanelLoading').hide();
|
||||||
|
|
||||||
function ListInitialData(response) {
|
if (response.data.status === 1) {
|
||||||
$scope.cyberpanelLoading = true;
|
new PNotify({
|
||||||
$('#cyberpanelLoading').hide();
|
title: 'Success!',
|
||||||
|
text: 'Container ' + action + ' successful.',
|
||||||
if (response.data.status === 1) {
|
type: 'success'
|
||||||
new PNotify({
|
});
|
||||||
title: 'Success!',
|
|
||||||
text: 'Container ' + action + ' successful.',
|
// Update container status after action
|
||||||
type: 'success'
|
$scope.selectedContainer.status = action === 'stop' ? 'stopped' : 'running';
|
||||||
});
|
|
||||||
// Refresh container info after action
|
// Refresh container info
|
||||||
$scope.Lunchcontainer($scope.selectedContainer.id);
|
$scope.Lunchcontainer($scope.selectedContainer.id);
|
||||||
} else {
|
} else {
|
||||||
|
new PNotify({
|
||||||
|
title: 'Operation Failed!',
|
||||||
|
text: response.data.error_message || 'An unknown error occurred.',
|
||||||
|
type: 'error'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function(error) {
|
||||||
|
$scope.cyberpanelLoading = true;
|
||||||
|
$('#cyberpanelLoading').hide();
|
||||||
|
|
||||||
new PNotify({
|
new PNotify({
|
||||||
title: 'Operation Failed!',
|
title: 'Operation Failed!',
|
||||||
text: response.data.error_message,
|
text: 'Connection disrupted or server error occurred.',
|
||||||
type: 'error'
|
type: 'error'
|
||||||
});
|
});
|
||||||
|
|
||||||
|
console.error("Error during container action:", error);
|
||||||
}
|
}
|
||||||
}
|
);
|
||||||
|
};
|
||||||
|
|
||||||
function cantLoadInitialData(response) {
|
// Update the container selection when actions are triggered
|
||||||
$scope.cyberpanelLoading = true;
|
$scope.setSelectedContainer = function(container) {
|
||||||
$('#cyberpanelLoading').hide();
|
$scope.selectedContainer = container;
|
||||||
new PNotify({
|
};
|
||||||
title: 'Operation Failed!',
|
|
||||||
text: 'Connection disrupted, refresh the page.',
|
// Update the button click handlers to set selected container
|
||||||
type: 'error'
|
$scope.handleAction = function(action, container) {
|
||||||
});
|
$scope.setSelectedContainer(container);
|
||||||
}
|
$scope.cAction(action);
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.openSettings = function(container) {
|
$scope.openSettings = function(container) {
|
||||||
|
|||||||
@@ -403,13 +403,13 @@
|
|||||||
<h2 id="domainNamePage" class="d-flex justify-content-between align-items-center">
|
<h2 id="domainNamePage" class="d-flex justify-content-between align-items-center">
|
||||||
<span>{% trans "Currently managing: " %} {$ web.name $}</span>
|
<span>{% trans "Currently managing: " %} {$ web.name $}</span>
|
||||||
<div class="btn-group" role="group" aria-label="Container Actions">
|
<div class="btn-group" role="group" aria-label="Container Actions">
|
||||||
<button class="btn btn-success btn-sm" ng-click="cAction('start')" ng-if="web.status !== 'running'" title="Start Container">
|
<button class="btn btn-success btn-sm" ng-click="handleAction('start', web)" ng-if="web.status !== 'running'" title="Start Container">
|
||||||
<i class="fa fa-play"></i> Start
|
<i class="fa fa-play"></i> Start
|
||||||
</button>
|
</button>
|
||||||
<button class="btn btn-warning btn-sm" ng-click="cAction('restart')" ng-if="web.status === 'running'" title="Restart Container">
|
<button class="btn btn-warning btn-sm" ng-click="handleAction('restart', web)" ng-if="web.status === 'running'" title="Restart Container">
|
||||||
<i class="fa fa-refresh"></i> Restart
|
<i class="fa fa-refresh"></i> Restart
|
||||||
</button>
|
</button>
|
||||||
<button class="btn btn-danger btn-sm" ng-click="cAction('stop')" ng-if="web.status === 'running'" title="Stop Container">
|
<button class="btn btn-danger btn-sm" ng-click="handleAction('stop', web)" ng-if="web.status === 'running'" title="Stop Container">
|
||||||
<i class="fa fa-stop"></i> Stop
|
<i class="fa fa-stop"></i> Stop
|
||||||
</button>
|
</button>
|
||||||
<button class="btn btn-primary btn-sm" ng-click="openSettings(web)" title="Container Settings">
|
<button class="btn btn-primary btn-sm" ng-click="openSettings(web)" title="Container Settings">
|
||||||
|
|||||||
@@ -179,6 +179,11 @@ urlpatterns = [
|
|||||||
path('ListDockerSites', views.ListDockerSites, name='ListDockerSites'),
|
path('ListDockerSites', views.ListDockerSites, name='ListDockerSites'),
|
||||||
path('fetchDockersite', views.fetchDockersite, name='fetchDockersite'),
|
path('fetchDockersite', views.fetchDockersite, name='fetchDockersite'),
|
||||||
|
|
||||||
|
# Docker Container Actions
|
||||||
|
path('docker/startContainer', views.startContainer, name='startContainer'),
|
||||||
|
path('docker/stopContainer', views.stopContainer, name='stopContainer'),
|
||||||
|
path('docker/restartContainer', views.restartContainer, name='restartContainer'),
|
||||||
|
|
||||||
# SSH Configs
|
# SSH Configs
|
||||||
path('getSSHConfigs', views.getSSHConfigs, name='getSSHConfigs'),
|
path('getSSHConfigs', views.getSSHConfigs, name='getSSHConfigs'),
|
||||||
path('deleteSSHKey', views.deleteSSHKey, name='deleteSSHKey'),
|
path('deleteSSHKey', views.deleteSSHKey, name='deleteSSHKey'),
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ from websiteFunctions.models import wpplugins
|
|||||||
from websiteFunctions.website import WebsiteManager
|
from websiteFunctions.website import WebsiteManager
|
||||||
from websiteFunctions.pluginManager import pluginManager
|
from websiteFunctions.pluginManager import pluginManager
|
||||||
from django.views.decorators.csrf import csrf_exempt
|
from django.views.decorators.csrf import csrf_exempt
|
||||||
|
from .dockerviews import startContainer, stopContainer, restartContainer
|
||||||
|
|
||||||
def loadWebsitesHome(request):
|
def loadWebsitesHome(request):
|
||||||
val = request.session['userID']
|
val = request.session['userID']
|
||||||
|
|||||||
Reference in New Issue
Block a user