-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathgroups_detail.php
88 lines (68 loc) · 2.57 KB
/
groups_detail.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php
$active_page = 'groups';
require_once 'functions.php';
include_once 'config.php';
session_secure_start();
require_once 'l10n/'.$_SESSION['language'].'.php';
$export_type = $_POST['export_type'];
$display_or_download = $_POST['submit'];
if($display_or_download == "download") {
// Set filename or create one depending on GET parameters
if($filename_download == null)
$filename_download = "nextcloud-grouplist_".date('Y-m-d_Hi').".csv";
// Set default column headers or no column headers depending on selection
$headers = $_POST['csv_headers'] == 'default'
? 'group,loginID,displayname'
: 'no_headers';
// Create and populate CSV file with selected group data and set filename variable
$file = build_csv_file(build_group_data('array', 'csv', ','), $headers);
// Start download using supplied or generated filename
download_file($file, $mime_type, $filename_download, $_SESSION['temp_folder']);
exit();
}
echo "<html lang='{$_SESSION['language']}'>";
?>
<head>
<link rel="stylesheet" type="text/css" href="style.php">
<meta charset="UTF-8">
<title>Nextcloud Userexport</title>
<script>
/**
* Source of the following function 'sortTable':
* https://stackoverflow.com/a/49041392
*
* sort table columns on header click
*
*/
function sortTable() {
const getCellValue = (tr, idx) => tr.children[idx].innerText || tr.children[idx].textContent;
const comparer = (idx, asc) => (a, b) => ((v1, v2) =>
v1 !== '' && v2 !== '' && !isNaN(v1) && !isNaN(v2) ? v1 - v2 : v1.toString().localeCompare(v2)
)(getCellValue(asc ? a : b, idx), getCellValue(asc ? b : a, idx));
document.querySelectorAll('th').forEach(th => th.addEventListener('click', (() => {
const table = th.closest('table');
Array.from(table.querySelectorAll('tr:nth-child(n+2)'))
.sort(comparer(Array.from(th.parentNode.children).indexOf(th), this.asc = !this.asc))
.forEach(tr => table.appendChild(tr) );
})));
}
</script>
</head>
<body>
<?php
include 'navigation.php';
if(!$_SESSION['authenticated']) {
header('Content-Type: text/html; charset=utf-8');
exit('<br>'.L10N_CONNECTION_NEEDED);
}
print_status_overview();
/**
* Display results page either as HTML table or comma separated values (CSV)
*/
if($export_type == 'table')
echo build_table_group_data();
else
echo build_group_data(null, null, ',');
?>
</body>
</html>