2023-06-03 17:36:38 +00:00
|
|
|
{% extends ../base.html %}
|
|
|
|
|
|
|
|
{% block meta %}
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
{% block title %}Crafty Controller - {{ translate('serverDetails', 'serverDetails', data['lang']) }}{% end %}
|
|
|
|
|
|
|
|
{% block content %}
|
2023-06-03 22:10:39 +00:00
|
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/css/bootstrap-select.min.css">
|
2023-06-03 17:36:38 +00:00
|
|
|
<div class="content-wrapper">
|
|
|
|
|
|
|
|
<!-- Page Title Header Starts-->
|
|
|
|
<div class="row page-title-header">
|
|
|
|
<div class="col-12">
|
|
|
|
<div class="page-header">
|
|
|
|
<h4 class="page-title">
|
|
|
|
{{ translate('serverDetails', 'serverDetails', data['lang']) }} - {{
|
|
|
|
data['server_stats']['server_id']['server_name'] }}
|
|
|
|
<br />
|
|
|
|
<small>UUID: {{ data['server_stats']['server_id']['server_uuid'] }}</small>
|
|
|
|
</h4>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<!-- Page Title Header Ends-->
|
|
|
|
|
|
|
|
{% include "parts/details_stats.html" %}
|
|
|
|
|
|
|
|
<div class="row">
|
|
|
|
|
|
|
|
<div class="col-sm-12 grid-margin">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-body pt-0">
|
|
|
|
{% include "parts/server_controls_list.html" %}
|
|
|
|
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-8 col-sm-8">
|
|
|
|
{% if data['new_webhook'] == True %}
|
|
|
|
<form class="forms-sample" method="post" id="new_webhook_form"
|
|
|
|
action="/panel/new_webhook?id={{ data['server_stats']['server_id']['server_id'] }}">
|
2023-06-03 22:10:39 +00:00
|
|
|
{% else %}
|
2023-06-04 02:40:39 +00:00
|
|
|
<form class="forms-sample" method="post" id="webhook_form"
|
2023-06-03 22:10:39 +00:00
|
|
|
action="/panel/edit_webhook?id={{ data['server_stats']['server_id']['server_id'] }}&sch_id={{ data['webhook']['id'] }}">
|
|
|
|
{% end %}
|
|
|
|
<select class="form-select form-control form-control-lg select-css" id="webhook_type" name="webhook_type">
|
2023-10-05 22:05:12 +00:00
|
|
|
<option value="{{data['webhook']['webhook_type']}}">{{data['webhook']['webhook_type']}}</option>
|
2023-06-03 22:10:39 +00:00
|
|
|
{% for type in data['providers'] %}
|
2023-10-05 22:05:12 +00:00
|
|
|
{% if type != data['webhook']['webhook_type'] %}
|
2023-06-03 22:10:39 +00:00
|
|
|
<option value="{{type}}">{{type}}</option>
|
2023-10-05 22:05:12 +00:00
|
|
|
{%end%}
|
2023-06-03 22:10:39 +00:00
|
|
|
{% end %}
|
2023-06-03 17:36:38 +00:00
|
|
|
</select>
|
|
|
|
<br>
|
|
|
|
<br>
|
2023-06-03 22:10:39 +00:00
|
|
|
<div class="form-group">
|
2023-06-03 22:38:44 +00:00
|
|
|
<label for="name">{{ translate('webhooks', 'name' , data['lang']) }}</label>
|
2023-06-03 22:10:39 +00:00
|
|
|
<input type="input" class="form-control" name="name" id="name_input"
|
|
|
|
value="{{ data['webhook']['name']}}" maxlength="30" placeholder="Name" required>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2023-06-03 22:38:44 +00:00
|
|
|
<label for="url">{{ translate('webhooks', 'url', data['lang']) }}</label>
|
2023-06-03 22:10:39 +00:00
|
|
|
<input type="input" class="form-control" name="url" id="url"
|
|
|
|
value="{{ data['webhook']['url']}}" placeholder="https://webhooks.craftycontrol.com/fakeurl" required>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2023-06-03 22:38:44 +00:00
|
|
|
<label for="bot_name">{{ translate('webhooks', 'bot_name' , data['lang']) }}</label>
|
2023-06-03 22:10:39 +00:00
|
|
|
<input type="input" class="form-control" name="bot_name" id="bot_name_input"
|
|
|
|
value="{{ data['webhook']['bot_name']}}" maxlength="30" placeholder="Crafty Controller" required>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2023-06-03 22:38:44 +00:00
|
|
|
<label for="trigger">{{ translate('webhooks', 'trigger', data['lang']) }}</label>
|
2023-06-03 22:10:39 +00:00
|
|
|
<select class="form-control selectpicker show-tick" name="trigger" id="trigger-select" data-icon-base="fas" data-tick-icon="fa-check" multiple data-style="custom-picker">
|
|
|
|
{% for trigger in data['triggers'] %}
|
|
|
|
{% if trigger in data["webhook"]["trigger"] %}
|
2023-09-28 21:47:03 +00:00
|
|
|
<option value="{{trigger}}" selected>{{translate('webhooks', trigger , data['lang'])}}</option>
|
2023-06-03 22:10:39 +00:00
|
|
|
{% else %}
|
2023-09-28 21:47:03 +00:00
|
|
|
<option value="{{trigger}}">{{translate('webhooks', trigger , data['lang'])}}</option>
|
2023-06-03 22:10:39 +00:00
|
|
|
{% end %}
|
|
|
|
{% end %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2023-06-03 22:38:44 +00:00
|
|
|
<label for="body">{{ translate('webhooks', 'webhook_body', data['lang']) }}</label>
|
2023-06-03 22:10:39 +00:00
|
|
|
<textarea id="body-input" name="body" rows="4" cols="50">
|
|
|
|
{{ data["webhook"]["body"] }}
|
|
|
|
</textarea>
|
|
|
|
</div>
|
2023-09-28 23:07:03 +00:00
|
|
|
<div class="form-group">
|
|
|
|
<label for="bot_name">{{ translate('webhooks', 'color' , data['lang']) }}</label>
|
|
|
|
<input type="color" class="form-control" name="color" id="color" value='{{data["webhook"]["color"]}}'>
|
|
|
|
</div>
|
2023-09-29 00:00:38 +00:00
|
|
|
<div class="form-group">
|
|
|
|
<div class="custom-control custom-switch">
|
|
|
|
<input type="checkbox" class="custom-control-input" id="enabled" name="enabled" {% if data['webhook']['enabled'] %}checked{%end%}
|
|
|
|
value="1">
|
|
|
|
<label for="enabled" class="custom-control-label">{{ translate('webhooks', 'enabled', data['lang']) }}</label>
|
|
|
|
</div>
|
2023-06-03 22:10:39 +00:00
|
|
|
</div>
|
2023-06-03 17:36:38 +00:00
|
|
|
<button type="submit" class="btn btn-success mr-2"><i class="fas fa-save"></i> {{
|
|
|
|
translate('serverConfig', 'save', data['lang']) }}</button>
|
|
|
|
<button type="reset"
|
2023-06-03 22:10:39 +00:00
|
|
|
onclick="location.href=`/panel/server_detail?id={{ data['server_stats']['server_id']['server_id'] }}&subpage=webhooks`"
|
2023-06-03 17:36:38 +00:00
|
|
|
class="btn btn-light"><i class="fas fa-times"></i> {{ translate('serverConfig', 'cancel',
|
|
|
|
data['lang']) }}</button>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
2023-06-03 22:10:39 +00:00
|
|
|
<style>
|
2023-09-29 00:00:38 +00:00
|
|
|
.custom-control-input:checked~.custom-control-label::before {
|
|
|
|
color: black !important;
|
|
|
|
background-color: blueviolet !important;
|
|
|
|
border-color: var(--outline) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.custom-control-label::before {
|
|
|
|
background-color: white !important;
|
|
|
|
top: calc(-0.2rem);
|
|
|
|
}
|
|
|
|
|
|
|
|
.custom-switch .custom-control-label::after {
|
|
|
|
top: calc(-0.125rem + 1px);
|
|
|
|
}
|
2023-06-03 22:10:39 +00:00
|
|
|
#body-input {
|
|
|
|
background-color: var(--card-banner-bg);
|
|
|
|
outline-color: var(--outline);
|
|
|
|
color: var(--base-text);
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
</style>
|
2023-06-03 17:36:38 +00:00
|
|
|
<!-- content-wrapper ends -->
|
|
|
|
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
{% block js %}
|
|
|
|
<script>
|
2023-09-29 00:00:38 +00:00
|
|
|
$(function () {
|
|
|
|
$('.form-check-input').bootstrapToggle({
|
|
|
|
on: '',
|
|
|
|
off: ''
|
|
|
|
});
|
|
|
|
})
|
2023-06-03 17:36:38 +00:00
|
|
|
|
|
|
|
//used to get cookies from browser - this is part of tornados xsrf protection - it's for extra security
|
|
|
|
function getCookie(name) {
|
|
|
|
var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
|
|
|
|
return r ? r[1] : undefined;
|
|
|
|
}
|
|
|
|
|
|
|
|
function replacer(key, value) {
|
|
|
|
if (key != "start_time" && key != "cron_string" && key != "interval_type") {
|
|
|
|
if (typeof value == "boolean") {
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
console.log(key)
|
|
|
|
if (key === "interval" && value === ""){
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (key === "command" && typeof(value === "integer")){
|
|
|
|
return value.toString();
|
|
|
|
}else {
|
|
|
|
return (isNaN(value) ? value : +value);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (value === "" && key == "start_time"){
|
|
|
|
return "00:00";
|
|
|
|
}else{
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const serverId = new URLSearchParams(document.location.search).get('id');
|
2023-06-03 22:10:39 +00:00
|
|
|
const webhookId = new URLSearchParams(document.location.search).get('webhook_id');
|
2023-06-03 17:36:38 +00:00
|
|
|
$(document).ready(function () {
|
|
|
|
console.log("ready!");
|
2023-06-03 22:10:39 +00:00
|
|
|
console.log('ready for JS!');
|
|
|
|
$('.selectpicker').selectpicker("refresh");
|
|
|
|
$("#new_webhook_form").on("submit", async function (e) {
|
2023-06-03 17:36:38 +00:00
|
|
|
e.preventDefault();
|
|
|
|
var token = getCookie("_xsrf")
|
2023-06-03 22:10:39 +00:00
|
|
|
let webhookForm = document.getElementById("new_webhook_form");
|
|
|
|
let select_val = JSON.stringify($('#trigger-select').val());
|
|
|
|
select_val = JSON.parse(select_val);
|
2023-06-03 17:36:38 +00:00
|
|
|
|
2023-06-03 22:10:39 +00:00
|
|
|
let formData = new FormData(webhookForm);
|
2023-06-03 17:36:38 +00:00
|
|
|
//Create an object from the form data entries
|
|
|
|
let formDataObject = Object.fromEntries(formData.entries());
|
|
|
|
//We need to make sure these are sent regardless of whether or not they're checked
|
|
|
|
formDataObject.enabled = $("#enabled").prop('checked');
|
2023-06-03 22:10:39 +00:00
|
|
|
formDataObject.trigger = select_val;
|
|
|
|
|
2023-06-03 17:36:38 +00:00
|
|
|
console.log(formDataObject);
|
|
|
|
// Format the plain form data as JSON
|
|
|
|
let formDataJsonString = JSON.stringify(formDataObject, replacer);
|
|
|
|
|
2023-06-03 22:10:39 +00:00
|
|
|
let res = await fetch(`/api/v2/servers/${serverId}/webhook/`, {
|
2023-06-03 17:36:38 +00:00
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'X-XSRFToken': token,
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: formDataJsonString,
|
|
|
|
});
|
|
|
|
let responseData = await res.json();
|
|
|
|
if (responseData.status === "ok") {
|
2023-06-03 22:10:39 +00:00
|
|
|
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
|
2023-06-03 17:36:38 +00:00
|
|
|
} else {
|
|
|
|
|
|
|
|
bootbox.alert({
|
|
|
|
title: responseData.status,
|
|
|
|
message: responseData.error
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-06-04 02:40:39 +00:00
|
|
|
$("#webhook_form").on("submit", async function (e) {
|
2023-06-03 17:36:38 +00:00
|
|
|
e.preventDefault();
|
2023-06-03 22:10:39 +00:00
|
|
|
var token = getCookie("_xsrf");
|
2023-06-04 02:40:39 +00:00
|
|
|
let webhookForm = document.getElementById("webhook_form");
|
2023-06-03 22:10:39 +00:00
|
|
|
let select_val = JSON.stringify($('#trigger-select').val());
|
|
|
|
select_val = JSON.parse(select_val);
|
2023-06-03 17:36:38 +00:00
|
|
|
|
2023-06-03 22:10:39 +00:00
|
|
|
let formData = new FormData(webhookForm);
|
2023-06-03 17:36:38 +00:00
|
|
|
//Create an object from the form data entries
|
|
|
|
let formDataObject = Object.fromEntries(formData.entries());
|
|
|
|
//We need to make sure these are sent regardless of whether or not they're checked
|
|
|
|
formDataObject.enabled = $("#enabled").prop('checked');
|
2023-06-03 22:10:39 +00:00
|
|
|
formDataObject.trigger = select_val;
|
2023-09-28 23:07:03 +00:00
|
|
|
if(formDataObject.webhook_type != "Discord"){
|
|
|
|
delete formDataObject.color
|
|
|
|
}
|
2023-06-03 22:10:39 +00:00
|
|
|
|
2023-06-03 17:36:38 +00:00
|
|
|
console.log(formDataObject);
|
|
|
|
// Format the plain form data as JSON
|
|
|
|
let formDataJsonString = JSON.stringify(formDataObject, replacer);
|
|
|
|
|
2023-06-04 02:40:39 +00:00
|
|
|
let res = await fetch(`/api/v2/servers/${serverId}/webhook/${webhookId}`, {
|
2023-06-03 17:36:38 +00:00
|
|
|
method: 'PATCH',
|
|
|
|
headers: {
|
|
|
|
'X-XSRFToken': token,
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: formDataJsonString,
|
|
|
|
});
|
|
|
|
let responseData = await res.json();
|
|
|
|
if (responseData.status === "ok") {
|
2023-06-03 22:10:39 +00:00
|
|
|
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
|
2023-06-03 17:36:38 +00:00
|
|
|
} else {
|
|
|
|
|
|
|
|
bootbox.alert({
|
2023-06-04 02:40:39 +00:00
|
|
|
title: responseData.status,
|
|
|
|
message: responseData.error
|
2023-06-03 17:36:38 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2023-09-28 23:07:03 +00:00
|
|
|
|
|
|
|
function hexToDiscordInt(hexColor) {
|
|
|
|
// Remove the hash at the start if it's there
|
|
|
|
const sanitizedHex = hexColor.startsWith('#') ? hexColor.slice(1) : hexColor;
|
|
|
|
|
|
|
|
// Convert the hex to an integer
|
|
|
|
return parseInt(sanitizedHex, 16);
|
|
|
|
}
|
2023-06-03 17:36:38 +00:00
|
|
|
</script>
|
2023-10-18 18:13:03 +00:00
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/js/bootstrap-select.min.js"
|
|
|
|
integrity="sha384-WVuhHRQyp0Fr6bNQzs5+Mr0MPezgB/f3WF4WektQV+WjdGT+OSc5txndPAYdX707" crossorigin="anonymous"></script>
|
2023-06-03 17:36:38 +00:00
|
|
|
|
|
|
|
{% end %}
|