first commit

This commit is contained in:
root
2023-12-19 11:32:13 +01:00
commit 8ea55ac5e2
11 changed files with 314 additions and 0 deletions

12
templates/arch/base.html Normal file
View File

@@ -0,0 +1,12 @@
<html>
<head>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.3.1/dist/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/popper.js@1.14.7/dist/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.3.1/dist/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.1.2/socket.io.js"></script>
</head>
<body>
{% block content %}{% endblock %}
</body>
</html>

36
templates/arch/index.html Normal file
View File

@@ -0,0 +1,36 @@
{% extends 'base.html' %}
{% block content %}
<div class="card">
<div class="card-header">
Select Playbook and arguments
</div>
<div class="card-body">
<form id="ansibleForm">
<label for="os">Playbook</label>
<select id="playbook" class="form-control" name="playbook" placeholder="Profile" required>
{%for file in list %}
<option value={{ file }}>{{ file }}</option>
{%endfor%}
</select><br>
<label for="nom">Arguments</label>
<input type="text" name="arguments" class="form-control" placeholder="-e "><br>
<label for="nom">Hosts</label>
<input type="text" name="arguments" class="form-control" placeholder="/path/to/inventory"><br>
<button type="submit" class="btn btn-primary"onclick="submitForm()">Executer</button>
</form>
</div>
</div>
<script>
var socket = io.connect('http://' + document.domain + ':' + location.port);
function submitForm() {
var playbook = document.forms["ansibleForm"]["playbook"].value;
var hosts = document.forms["ansibleForm"]["hosts"].value;
var arguments = document.forms["ansibleForm"]["arguments"].value;
socket.emit('submit_playbook', { playbook: playbook, hosts: hosts });
window.location.href = "/run";
}
</script>
{% endblock %}

View File

@@ -0,0 +1,23 @@
<!-- templates/run.html -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Ansible Output</title>
</head>
<body>
<div id="output"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.1.1/socket.io.js"></script>
<script>
var socket = io.connect('http://' + document.domain + ':' + location.port);
socket.on('ansible_output', function(data) {
var outputDiv = document.getElementById('output');
outputDiv.innerHTML += data.data + '<br>';
});
</script>
</body>
</html>

View File

@@ -0,0 +1,37 @@
{% extends 'base.html' %}
{% block content %}
<div class="card">
<div class="card-header">
Running playbook
</div>
<div class="card-body">
Command to run : <code>ansible-playbook {{ playbook }} {{ argument }}</code>
</div>
</div>
<div class="card">
<div class="card-header">
Output
</div>
<div class="card-body">
Test
</div>
</div>
<pre id="output"></pre>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.1.2/socket.io.js"></script>
<script>
var socket = io.connect('http://' + document.domain + ':' + location.port);
socket.on('output', function(data) {
document.getElementById('output').textContent += data.data;
});
function executeCommand() {
socket.emit('execute_command', "ansible-playbook {{ playbook }} {{ argument }}");
}
</script>
{% endblock %}