2023-10-29 17:03:55 +00:00
|
|
|
function loadAdminPage() {
|
|
|
|
var html = `
|
|
|
|
|
|
|
|
<div id="myModal" class="modal">
|
|
|
|
<div class="modal-content">
|
|
|
|
<span class="close" onclick="closeModal();">×</span>
|
|
|
|
<div id="modal-content-real"></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="form-group newline">
|
|
|
|
<button class="form-control btn" name="admin_menu_return_button" id="admin_menu_return_button" onclick="AdminPageRedirect();"><img src="${root}/assets/trash.svg" class="btn_logo"></img><p2 id="admin_menu_return_button_text">Return</p2></button>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="form-group newline">
|
|
|
|
<hr>
|
|
|
|
</div>
|
|
|
|
|
2023-10-30 12:30:01 +00:00
|
|
|
<div class="form-group newline">
|
|
|
|
<button class="form-control btn" type="submit" name="tautulliSyncButton" id="tautulliSyncButton" onclick="syncTautulli();"><img src="${root}/assets/synchronize.svg" class="btn_logo"></img><p2 id="tautulliSyncButtonImage">Sync with Tautulli</p2></button>
|
|
|
|
</div>
|
|
|
|
|
2023-10-29 17:03:55 +00:00
|
|
|
<div class='form-group newline'>
|
|
|
|
<h3>
|
|
|
|
Wrapperr users
|
|
|
|
</h3>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="users-module" id="users-module">
|
|
|
|
|
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
|
|
|
document.getElementById("setup").innerHTML = html;
|
|
|
|
getUsers();
|
|
|
|
}
|
|
|
|
|
|
|
|
function getUsers() {
|
|
|
|
var xhttp = new XMLHttpRequest();
|
|
|
|
xhttp.onreadystatechange = function() {
|
|
|
|
if (this.readyState == 4) {
|
|
|
|
try {
|
|
|
|
var result= JSON.parse(this.responseText);
|
|
|
|
} catch(error) {
|
|
|
|
alert('Failed to parse API response.');
|
|
|
|
console.log('Failed to parse API response. Error: ' + this.responseText);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(result.error) {
|
|
|
|
alert(result.error);
|
|
|
|
} else {
|
|
|
|
placeUsers(result.data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
xhttp.withCredentials = true;
|
|
|
|
xhttp.open("post", api_url + "get/users");
|
|
|
|
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
|
|
|
|
xhttp.setRequestHeader("Authorization", cookie);
|
|
|
|
xhttp.send();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
function placeUsers(usersArray) {
|
|
|
|
userModule = document.getElementById("users-module")
|
|
|
|
|
2023-10-30 12:30:01 +00:00
|
|
|
userModule.innerHTML = `
|
2023-10-29 17:03:55 +00:00
|
|
|
<div class="user-headers">
|
2023-10-30 12:30:01 +00:00
|
|
|
<div class="user-header-short">ID</div>
|
2023-10-29 17:03:55 +00:00
|
|
|
<div class="user-header">Username</div>
|
|
|
|
<div class="user-header">Friendly name</div>
|
|
|
|
<div class="user-header">Email</div>
|
2023-10-30 12:30:01 +00:00
|
|
|
<div class="user-header-short">Active</div>
|
2023-11-16 18:34:22 +00:00
|
|
|
<div class="user-header">Tautulli servers</div>
|
2023-10-29 17:03:55 +00:00
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
|
|
|
usersArray.forEach(user => {
|
|
|
|
var historyDiv = "";
|
|
|
|
if(user.wrappings.length > 0) {
|
|
|
|
historyDiv = `
|
|
|
|
<div class="user-logbutton">
|
|
|
|
<button class="form-control btn" name="historyButton" id="historyButton" onclick="getHistory(${user.user_id});" style="width: 2em; height: 2em; padding: 0.25em;"><img src="${root}/assets/document.svg" class="btn_solo"></img><p2 id="historyButtonImage"></p2></button>
|
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
}
|
|
|
|
|
2023-10-30 12:30:01 +00:00
|
|
|
var active_state_class = ""
|
|
|
|
if(user.user_active) {
|
|
|
|
active_state_class = "user-active-true"
|
|
|
|
} else {
|
|
|
|
active_state_class = "user-active-false"
|
|
|
|
}
|
|
|
|
|
2023-11-16 18:34:22 +00:00
|
|
|
var tautulliServersString = ""
|
|
|
|
user.user_tautulli_servers.forEach(server => {
|
|
|
|
tautulliServersString += `<div class="tautulli-server-badge" title="${server}">${server}</div>`
|
|
|
|
});
|
|
|
|
|
2023-10-29 17:03:55 +00:00
|
|
|
var html = `
|
|
|
|
<div class="user-object">
|
|
|
|
<div class="user-details">
|
|
|
|
<div class="user-userid">${user.user_id}</div>
|
|
|
|
<div class="user-username">${user.user_name}</div>
|
|
|
|
<div class="user-friendlyname">${user.user_friendly_name}</div>
|
|
|
|
<div class="user-email">${user.user_email}</div>
|
2023-10-30 12:30:01 +00:00
|
|
|
<div class="user-active">
|
|
|
|
<div class="${active_state_class}">
|
|
|
|
${user.user_active}
|
|
|
|
</div>
|
|
|
|
</div>
|
2023-11-16 18:34:22 +00:00
|
|
|
<div class="user-tautulli-servers">${tautulliServersString}</div>
|
2023-10-29 17:03:55 +00:00
|
|
|
</div>
|
|
|
|
|
|
|
|
${historyDiv}
|
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
|
|
|
userModule.innerHTML += html;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getHistory(userId) {
|
|
|
|
var xhttp = new XMLHttpRequest();
|
|
|
|
xhttp.onreadystatechange = function() {
|
|
|
|
if (this.readyState == 4) {
|
|
|
|
try {
|
|
|
|
var result= JSON.parse(this.responseText);
|
|
|
|
} catch(error) {
|
|
|
|
alert('Failed to parse API response.');
|
|
|
|
console.log('Failed to parse API response. Error: ' + this.responseText);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(result.error) {
|
|
|
|
alert(result.error);
|
|
|
|
} else {
|
|
|
|
placeHistory(result.data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
xhttp.withCredentials = true;
|
|
|
|
xhttp.open("post", api_url + "get/users/" + userId);
|
|
|
|
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
|
|
|
|
xhttp.setRequestHeader("Authorization", cookie);
|
|
|
|
xhttp.send();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
function placeHistory(userObject) {
|
|
|
|
var modal = document.getElementById("myModal");
|
|
|
|
var modalContent = document.getElementById("modal-content-real");
|
|
|
|
modal.style.display = "block";
|
|
|
|
|
|
|
|
userObject.wrappings.forEach(entry => {
|
|
|
|
var date = new Date(entry.entry_date);
|
|
|
|
var html = `
|
|
|
|
<div class="user-history">
|
|
|
|
<div class="user-history-date">${date}</div>
|
|
|
|
<div class="user-history-ip">${entry.entry_ip}</div>
|
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
|
|
|
modalContent.innerHTML += html;
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function closeModal() {
|
|
|
|
var modal = document.getElementById("myModal");
|
2023-10-29 17:23:15 +00:00
|
|
|
var modalContent = document.getElementById("modal-content-real");
|
2023-10-29 17:03:55 +00:00
|
|
|
modal.style.display = "none";
|
2023-10-29 17:23:15 +00:00
|
|
|
modalContent.innerHTML = "";
|
2023-10-30 12:30:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function syncTautulli() {
|
|
|
|
var xhttp = new XMLHttpRequest();
|
|
|
|
xhttp.onreadystatechange = function() {
|
|
|
|
if (this.readyState == 4) {
|
|
|
|
try {
|
|
|
|
var result= JSON.parse(this.responseText);
|
|
|
|
} catch(error) {
|
|
|
|
alert('Failed to parse API response.');
|
|
|
|
console.log('Failed to parse API response. Error: ' + this.responseText);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(result.error) {
|
|
|
|
alert(result.error);
|
|
|
|
} else {
|
|
|
|
placeUsers(result.data);
|
|
|
|
alert(result.message)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
xhttp.withCredentials = true;
|
|
|
|
xhttp.open("post", api_url + "sync/users");
|
|
|
|
xhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
|
|
|
|
xhttp.setRequestHeader("Authorization", cookie);
|
|
|
|
xhttp.send();
|
|
|
|
return;
|
2023-10-29 17:03:55 +00:00
|
|
|
}
|