Initial Commit
This commit is contained in:
parent
067899af68
commit
5cd558eb6c
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
# Ignore the dev_files directory
|
||||||
|
_NEW
|
4
Home/.gitignore
vendored
Normal file
4
Home/.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# Ignore everything in this directory
|
||||||
|
*
|
||||||
|
# Except this file
|
||||||
|
!.gitignore
|
680
assets/css/styles.css
Normal file
680
assets/css/styles.css
Normal file
@ -0,0 +1,680 @@
|
|||||||
|
@charset "utf-8";
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------
|
||||||
|
Simple reset
|
||||||
|
--------------------------*/
|
||||||
|
|
||||||
|
*{
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
font-family: system-ui;
|
||||||
|
}
|
||||||
|
|
||||||
|
html {
|
||||||
|
/* Full height */
|
||||||
|
height: 100%;
|
||||||
|
/* The image used */
|
||||||
|
background-image: url("../../images/background.jpg");
|
||||||
|
|
||||||
|
background-color: #373743;
|
||||||
|
/* Center and scale the image nicely */
|
||||||
|
background-position: center center;
|
||||||
|
background-size: cover;
|
||||||
|
|
||||||
|
font: 14px normal Arial, Helvetica, sans-serif;
|
||||||
|
z-index: -4;
|
||||||
|
overflow-y: scroll;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------
|
||||||
|
File manager
|
||||||
|
-------------------------*/
|
||||||
|
|
||||||
|
.filemanager {
|
||||||
|
width: 95%;
|
||||||
|
max-width:1340px;
|
||||||
|
position: relative;
|
||||||
|
margin: 30px auto 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media all and (max-width: 965px) {
|
||||||
|
.filemanager {
|
||||||
|
margin: 30px auto 0;
|
||||||
|
padding: 1px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .header {
|
||||||
|
font-size: large;
|
||||||
|
height: 30px;
|
||||||
|
background-color: beige;
|
||||||
|
text-align: center;
|
||||||
|
padding-top: 5px;
|
||||||
|
}
|
||||||
|
#nowWatched {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fancybox-slide {
|
||||||
|
padding: 20px 50px !important;
|
||||||
|
}
|
||||||
|
/*-------------------------
|
||||||
|
Breadcrumps
|
||||||
|
-------------------------*/
|
||||||
|
|
||||||
|
.filemanager .breadcrumbs {
|
||||||
|
color: #ffffff;
|
||||||
|
margin-left:20px;
|
||||||
|
font-size: 13px;
|
||||||
|
font-weight: 700;
|
||||||
|
line-height: 35px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .breadcrumbs a:link, .breadcrumbs a:visited {
|
||||||
|
color: #ffffff;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .breadcrumbs a:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .breadcrumbs .arrow {
|
||||||
|
color: #6a6a72;
|
||||||
|
font-size: 13px;
|
||||||
|
font-weight: 700;
|
||||||
|
line-height: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------
|
||||||
|
Search box
|
||||||
|
-------------------------*/
|
||||||
|
|
||||||
|
.filemanager .search {
|
||||||
|
position: absolute;
|
||||||
|
padding-right: 30px;
|
||||||
|
cursor: pointer;
|
||||||
|
right: 0;
|
||||||
|
font-size: 17px;
|
||||||
|
color: #ffffff;
|
||||||
|
display: block;
|
||||||
|
width: 40px;
|
||||||
|
height: 40px;
|
||||||
|
margin-top: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .search:before {
|
||||||
|
content: '';
|
||||||
|
position: absolute;
|
||||||
|
margin-top:12px;
|
||||||
|
width: 10px;
|
||||||
|
height: 11px;
|
||||||
|
border-radius: 50%;
|
||||||
|
border: 2px solid #ffffff;
|
||||||
|
right: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .search:after {
|
||||||
|
content: '';
|
||||||
|
width: 3px;
|
||||||
|
height: 10px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
border-radius: 2px;
|
||||||
|
position: absolute;
|
||||||
|
top: 23px;
|
||||||
|
right: 6px;
|
||||||
|
-webkit-transform: rotate(-45deg);
|
||||||
|
transform: rotate(-45deg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .search input[type=search] {
|
||||||
|
border-radius: 2px;
|
||||||
|
color: #4D535E;
|
||||||
|
background-color: #FFF;
|
||||||
|
width: 250px;
|
||||||
|
height: 44px;
|
||||||
|
margin-left: -215px;
|
||||||
|
padding-left: 20px;
|
||||||
|
text-decoration-color: #4d535e;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: 400;
|
||||||
|
line-height: 20px;
|
||||||
|
display: none;
|
||||||
|
outline: none;
|
||||||
|
border: none;
|
||||||
|
padding-right: 10px;
|
||||||
|
-webkit-appearance: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-input-placeholder { /* WebKit browsers */
|
||||||
|
color: #4d535e;
|
||||||
|
}
|
||||||
|
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
|
||||||
|
color: #4d535e;
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
::-moz-placeholder { /* Mozilla Firefox 19+ */
|
||||||
|
color: #4d535e;
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
:-ms-input-placeholder { /* Internet Explorer 10+ */
|
||||||
|
color: #4d535e;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------
|
||||||
|
Content area
|
||||||
|
-------------------------*/
|
||||||
|
|
||||||
|
.filemanager .data {
|
||||||
|
margin-top: 35px;
|
||||||
|
z-index: -3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data.animated {
|
||||||
|
-webkit-animation: showSlowlyElement 700ms; /* Chrome, Safari, Opera */
|
||||||
|
animation: showSlowlyElement 700ms; /* Standard syntax */
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li {
|
||||||
|
border-radius: 3px;
|
||||||
|
background-color: #373743;
|
||||||
|
width: 307px;
|
||||||
|
height: 118px;
|
||||||
|
list-style-type: none;
|
||||||
|
margin: 10px;
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 0.3em;
|
||||||
|
z-index: 1;
|
||||||
|
cursor: pointer;
|
||||||
|
box-sizing: border-box;
|
||||||
|
transition: 0.3s background-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li:hover {
|
||||||
|
background-color: #42424E;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li a {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li .name {
|
||||||
|
color: #ffffff;
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: 700;
|
||||||
|
line-height: 20px;
|
||||||
|
width: 150px;
|
||||||
|
white-space: nowrap;
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
top: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li .details {
|
||||||
|
color: #b6c1c9;
|
||||||
|
font-size: 13px;
|
||||||
|
font-weight: 400;
|
||||||
|
width: 55px;
|
||||||
|
/*height: 10px;*/
|
||||||
|
top: 75%;
|
||||||
|
white-space: nowrap;
|
||||||
|
position: absolute;
|
||||||
|
display: inline-block;
|
||||||
|
margin: 0.3em 2em 0em -5.7em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .data li .watchStatus {
|
||||||
|
width: 55px;
|
||||||
|
top: 75%;
|
||||||
|
white-space: nowrap;
|
||||||
|
position: absolute;
|
||||||
|
display: inline-block;
|
||||||
|
margin-left: 180px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .nothingfound {
|
||||||
|
background-color: #373743;
|
||||||
|
border-radius: 10px;
|
||||||
|
width: 23em;
|
||||||
|
height: 21em;
|
||||||
|
margin: 0 auto;
|
||||||
|
display: none;
|
||||||
|
font-family: Arial;
|
||||||
|
-webkit-animation: showSlowlyElement 700ms; /* Chrome, Safari, Opera */
|
||||||
|
animation: showSlowlyElement 700ms; /* Standard syntax */
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .nothingfound .nofiles {
|
||||||
|
margin: 30px auto;
|
||||||
|
top: 3em;
|
||||||
|
border-radius: 50%;
|
||||||
|
position:relative;
|
||||||
|
background-color: #d72f6e;
|
||||||
|
width: 11em;
|
||||||
|
height: 11em;
|
||||||
|
line-height: 11.4em;
|
||||||
|
}
|
||||||
|
.filemanager .nothingfound .nofiles:after {
|
||||||
|
content: '×';
|
||||||
|
position: absolute;
|
||||||
|
color: #ffffff;
|
||||||
|
font-size: 14em;
|
||||||
|
margin: -24px 9px;
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.filemanager .nothingfound span {
|
||||||
|
margin: 0 auto auto 5em;
|
||||||
|
color: #ffffff;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: 700;
|
||||||
|
line-height: 20px;
|
||||||
|
height: 13px;
|
||||||
|
position: relative;
|
||||||
|
top: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media all and (max-width:965px) {
|
||||||
|
|
||||||
|
.filemanager .data li {
|
||||||
|
width: 100%;
|
||||||
|
margin: 5px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Chrome, Safari, Opera */
|
||||||
|
@-webkit-keyframes showSlowlyElement {
|
||||||
|
100% { transform: scale(1); opacity: 1; }
|
||||||
|
0% { transform: scale(1.2); opacity: 0; }
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Standard syntax */
|
||||||
|
@keyframes showSlowlyElement {
|
||||||
|
100% { transform: scale(1); opacity: 1; }
|
||||||
|
0% { transform: scale(1.2); opacity: 0; }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------
|
||||||
|
Icons
|
||||||
|
-------------------------*/
|
||||||
|
|
||||||
|
.icon {
|
||||||
|
font-size: 23px;
|
||||||
|
}
|
||||||
|
.icon.folder {
|
||||||
|
display: inline-block;
|
||||||
|
margin: 1em 0.3em 0em 1em;
|
||||||
|
background-color: transparent;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.icon.folder:before {
|
||||||
|
content: '';
|
||||||
|
float: left;
|
||||||
|
background-color: #7ba1ad;
|
||||||
|
|
||||||
|
width: 1.5em;
|
||||||
|
height: 0.45em;
|
||||||
|
|
||||||
|
margin-left: 0.07em;
|
||||||
|
margin-bottom: -0.07em;
|
||||||
|
|
||||||
|
border-top-left-radius: 0.1em;
|
||||||
|
border-top-right-radius: 0.1em;
|
||||||
|
|
||||||
|
box-shadow: 1.25em 0.25em 0 0em #7ba1ad;
|
||||||
|
}
|
||||||
|
.icon.folder:after {
|
||||||
|
content: '';
|
||||||
|
float: left;
|
||||||
|
clear: left;
|
||||||
|
|
||||||
|
background-color: #a0d4e4;
|
||||||
|
width: 3em;
|
||||||
|
height: 2.25em;
|
||||||
|
|
||||||
|
border-radius: 0.1em;
|
||||||
|
}
|
||||||
|
.icon.folder.full:before {
|
||||||
|
height: 0.55em;
|
||||||
|
}
|
||||||
|
.icon.folder.full:after {
|
||||||
|
height: 2.15em;
|
||||||
|
box-shadow: 0 -0.12em 0 0 #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file {
|
||||||
|
width: 2.5em;
|
||||||
|
height: 3em;
|
||||||
|
line-height: 3em;
|
||||||
|
text-align: center;
|
||||||
|
border-radius: 0.25em;
|
||||||
|
color: #FFF;
|
||||||
|
display: inline-block;
|
||||||
|
margin: 0.9em 1.2em 0.8em 1.3em;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #A4A7AC inset;
|
||||||
|
}
|
||||||
|
.icon.file:first-line {
|
||||||
|
font-size: 13px;
|
||||||
|
font-weight: 700;
|
||||||
|
}
|
||||||
|
.icon.file:after {
|
||||||
|
content: '';
|
||||||
|
position: absolute;
|
||||||
|
z-index: -1;
|
||||||
|
border-width: 0;
|
||||||
|
border-bottom: 2.6em solid #DADDE1;
|
||||||
|
border-right: 2.22em solid rgba(0, 0, 0, 0);
|
||||||
|
top: -34.5px;
|
||||||
|
right: -4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-avi,
|
||||||
|
.icon.file.f-flv,
|
||||||
|
.icon.file.f-mkv,
|
||||||
|
.icon.file.f-mov,
|
||||||
|
.icon.file.f-mpeg,
|
||||||
|
.icon.file.f-mpg,
|
||||||
|
.icon.file.f-mp4,
|
||||||
|
.icon.file.f-m4v,
|
||||||
|
.icon.file.f-wmv {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #7e70ee inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-avi:after,
|
||||||
|
.icon.file.f-flv:after,
|
||||||
|
.icon.file.f-mkv:after,
|
||||||
|
.icon.file.f-mov:after,
|
||||||
|
.icon.file.f-mpeg:after,
|
||||||
|
.icon.file.f-mpg:after,
|
||||||
|
.icon.file.f-mp4:after,
|
||||||
|
.icon.file.f-m4v:after,
|
||||||
|
.icon.file.f-wmv:after {
|
||||||
|
border-bottom-color: #5649c1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-mp2,
|
||||||
|
.icon.file.f-mp3,
|
||||||
|
.icon.file.f-m3u,
|
||||||
|
.icon.file.f-wma,
|
||||||
|
.icon.file.f-xls,
|
||||||
|
.icon.file.f-xlsx {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #5bab6e inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-mp2:after,
|
||||||
|
.icon.file.f-mp3:after,
|
||||||
|
.icon.file.f-m3u:after,
|
||||||
|
.icon.file.f-wma:after,
|
||||||
|
.icon.file.f-xls:after,
|
||||||
|
.icon.file.f-xlsx:after {
|
||||||
|
border-bottom-color: #448353;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-doc,
|
||||||
|
.icon.file.f-docx,
|
||||||
|
.icon.file.f-psd{
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #03689b inset;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-doc:after,
|
||||||
|
.icon.file.f-docx:after,
|
||||||
|
.icon.file.f-psd:after {
|
||||||
|
border-bottom-color: #2980b9;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-gif,
|
||||||
|
.icon.file.f-jpg,
|
||||||
|
.icon.file.f-jpeg,
|
||||||
|
.icon.file.f-pdf,
|
||||||
|
.icon.file.f-png {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #e15955 inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-gif:after,
|
||||||
|
.icon.file.f-jpg:after,
|
||||||
|
.icon.file.f-jpeg:after,
|
||||||
|
.icon.file.f-pdf:after,
|
||||||
|
.icon.file.f-png:after {
|
||||||
|
border-bottom-color: #c6393f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-deb,
|
||||||
|
.icon.file.f-dmg,
|
||||||
|
.icon.file.f-gz,
|
||||||
|
.icon.file.f-rar,
|
||||||
|
.icon.file.f-zip,
|
||||||
|
.icon.file.f-7z {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #867c75 inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-deb:after,
|
||||||
|
.icon.file.f-dmg:after,
|
||||||
|
.icon.file.f-gz:after,
|
||||||
|
.icon.file.f-rar:after,
|
||||||
|
.icon.file.f-zip:after,
|
||||||
|
.icon.file.f-7z:after {
|
||||||
|
border-bottom-color: #685f58;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-html,
|
||||||
|
.icon.file.f-rtf,
|
||||||
|
.icon.file.f-xml,
|
||||||
|
.icon.file.f-xhtml {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #a94bb7 inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-html:after,
|
||||||
|
.icon.file.f-rtf:after,
|
||||||
|
.icon.file.f-xml:after,
|
||||||
|
.icon.file.f-xhtml:after {
|
||||||
|
border-bottom-color: #d65de8;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-js {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #d0c54d inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-js:after {
|
||||||
|
border-bottom-color: #a69f4e;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file.f-css,
|
||||||
|
.icon.file.f-saas,
|
||||||
|
.icon.file.f-scss {
|
||||||
|
box-shadow: 1.74em -2.1em 0 0 #44afa6 inset;
|
||||||
|
}
|
||||||
|
.icon.file.f-css:after,
|
||||||
|
.icon.file.f-saas:after,
|
||||||
|
.icon.file.f-scss:after {
|
||||||
|
border-bottom-color: #30837c;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*----------------------------
|
||||||
|
The Demo Footer
|
||||||
|
-----------------------------*/
|
||||||
|
|
||||||
|
|
||||||
|
footer {
|
||||||
|
|
||||||
|
width: 770px;
|
||||||
|
font: normal 16px Arial, Helvetica, sans-serif;
|
||||||
|
padding: 15px 35px;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -420px;
|
||||||
|
|
||||||
|
background-color:#1f1f1f;
|
||||||
|
background-image:linear-gradient(to bottom, #1f1f1f, #101010);
|
||||||
|
|
||||||
|
border-radius:2px 2px 0 0;
|
||||||
|
box-shadow: 0 -1px 4px rgba(0,0,0,0.4);
|
||||||
|
z-index:1;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer a.tz{
|
||||||
|
font-weight:normal;
|
||||||
|
font-size:16px !important;
|
||||||
|
text-decoration:none !important;
|
||||||
|
display:block;
|
||||||
|
margin-right: 300px;
|
||||||
|
text-overflow:ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
color:#bfbfbf !important;
|
||||||
|
z-index:1;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer a.tz:before{
|
||||||
|
content: '';
|
||||||
|
width: 138px;
|
||||||
|
height: 20px;
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
bottom: -3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer .close{
|
||||||
|
position: absolute;
|
||||||
|
cursor: pointer;
|
||||||
|
width: 8px;
|
||||||
|
height: 8px;
|
||||||
|
top:10px;
|
||||||
|
right:10px;
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer #tzine-actions{
|
||||||
|
position: absolute;
|
||||||
|
top: 8px;
|
||||||
|
width: 500px;
|
||||||
|
right: 50%;
|
||||||
|
margin-right: -650px;
|
||||||
|
text-align: right;
|
||||||
|
z-index: 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer #tzine-actions iframe{
|
||||||
|
display: inline-block;
|
||||||
|
height: 21px;
|
||||||
|
width: 95px;
|
||||||
|
position: relative;
|
||||||
|
float: left;
|
||||||
|
margin-top: 11px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1024px) {
|
||||||
|
#bsaHolder, footer{ display:none;}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Popup Test */
|
||||||
|
|
||||||
|
.popup {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
cursor: pointer;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The actual popup */
|
||||||
|
.popup .popuptext {
|
||||||
|
visibility: hidden;
|
||||||
|
width: 160px;
|
||||||
|
background-color: #555;
|
||||||
|
color: #fff;
|
||||||
|
text-align: center;
|
||||||
|
border-radius: 6px;
|
||||||
|
padding: 8px 0;
|
||||||
|
position: absolute;
|
||||||
|
z-index: 1;
|
||||||
|
bottom: 125%;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -80px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Popup arrow */
|
||||||
|
.popup .popuptext::after {
|
||||||
|
content: "";
|
||||||
|
position: absolute;
|
||||||
|
top: 100%;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -5px;
|
||||||
|
border-width: 5px;
|
||||||
|
border-style: solid;
|
||||||
|
border-color: #555 transparent transparent transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Toggle this class - hide and show the popup */
|
||||||
|
.popup .show {
|
||||||
|
visibility: visible;
|
||||||
|
-webkit-animation: fadeIn 1s;
|
||||||
|
animation: fadeIn 1s;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add animation (fade in the popup) */
|
||||||
|
@-webkit-keyframes fadeIn {
|
||||||
|
from {opacity: 0;}
|
||||||
|
to {opacity: 1;}
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes fadeIn {
|
||||||
|
from {opacity: 0;}
|
||||||
|
to {opacity:1 ;}
|
||||||
|
}
|
||||||
|
|
||||||
|
.button {
|
||||||
|
background-color: #373743;
|
||||||
|
border: none;
|
||||||
|
color: white;
|
||||||
|
padding: 15px 32px;
|
||||||
|
margin-left: 10px;
|
||||||
|
margin-top:40px;
|
||||||
|
text-align: center;
|
||||||
|
text-decoration: none;
|
||||||
|
display: inline-block;
|
||||||
|
width: 200px;
|
||||||
|
font-size: 16px;
|
||||||
|
cursor: pointer;
|
||||||
|
border-radius: 3px;
|
||||||
|
cursor: pointer;
|
||||||
|
box-sizing: border-box;
|
||||||
|
transition: 0.3s background-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button:hover {
|
||||||
|
background-color: #42424E;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fancybox-content {
|
||||||
|
min-height: 700px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* michu naming fixes:*/
|
||||||
|
|
||||||
|
.filemanager .data li .name {
|
||||||
|
width: 194px;
|
||||||
|
top: 22px;
|
||||||
|
white-space: inherit;
|
||||||
|
margin-left: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon.file {
|
||||||
|
margin: 0.9em 0.6em 0.8em 0.6em;
|
||||||
|
/*margin: 5px 0px 0px -60px;*/
|
||||||
|
}
|
440
assets/js/script.js
Normal file
440
assets/js/script.js
Normal file
@ -0,0 +1,440 @@
|
|||||||
|
$(function(){
|
||||||
|
|
||||||
|
var filemanager = $('.filemanager'),
|
||||||
|
breadcrumbs = $('.breadcrumbs'),
|
||||||
|
fileList = filemanager.find('.data');
|
||||||
|
|
||||||
|
// Start by fetching the file data from scan.php with an AJAX request
|
||||||
|
$.get('scan.php', function(data) {
|
||||||
|
|
||||||
|
var response = [data],
|
||||||
|
currentPath = '',
|
||||||
|
breadcrumbsUrls = [];
|
||||||
|
|
||||||
|
var folders = [],
|
||||||
|
files = [];
|
||||||
|
|
||||||
|
// This event listener monitors changes on the URL. We use it to
|
||||||
|
// capture back/forward navigation in the browser.
|
||||||
|
|
||||||
|
$(window).on('hashchange', function(){
|
||||||
|
|
||||||
|
goto(window.location.hash);
|
||||||
|
|
||||||
|
// We are triggering the event. This will execute
|
||||||
|
// this function on page load, so that we show the correct folder:
|
||||||
|
|
||||||
|
}).trigger('hashchange');
|
||||||
|
|
||||||
|
|
||||||
|
// Hiding and showing the search box
|
||||||
|
filemanager.find('.search').click(function(){
|
||||||
|
|
||||||
|
var search = $(this);
|
||||||
|
|
||||||
|
search.find('span').hide();
|
||||||
|
search.find('input[type=search]').show().focus();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// Listening for keyboard input on the search field.
|
||||||
|
// We are using the "input" event which detects cut and paste
|
||||||
|
// in addition to keyboard input.
|
||||||
|
|
||||||
|
filemanager.find('input').on('input', function(e){
|
||||||
|
|
||||||
|
folders = [];
|
||||||
|
files = [];
|
||||||
|
|
||||||
|
var value = this.value.trim();
|
||||||
|
|
||||||
|
if(value.length) {
|
||||||
|
|
||||||
|
filemanager.addClass('searching');
|
||||||
|
|
||||||
|
// Update the hash on every key stroke
|
||||||
|
window.location.hash = 'search=' + value.trim();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
filemanager.removeClass('searching');
|
||||||
|
window.location.hash = encodeURIComponent(currentPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
}).on('keyup', function(e){
|
||||||
|
|
||||||
|
// Clicking 'ESC' button triggers focusout and cancels the search
|
||||||
|
var search = $(this);
|
||||||
|
|
||||||
|
if(e.keyCode == 27) {
|
||||||
|
search.trigger('focusout');
|
||||||
|
}
|
||||||
|
|
||||||
|
}).focusout(function(e){
|
||||||
|
|
||||||
|
// Cancel the search
|
||||||
|
var search = $(this);
|
||||||
|
|
||||||
|
if(!search.val().trim().length) {
|
||||||
|
|
||||||
|
window.location.hash = encodeURIComponent(currentPath);
|
||||||
|
search.hide();
|
||||||
|
search.parent().find('span').show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// Clicking on folders
|
||||||
|
fileList.on('click', 'li.folders', function(e){
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
var nextDir = $(this).find('a.folders').attr('href');
|
||||||
|
|
||||||
|
if(filemanager.hasClass('searching')) {
|
||||||
|
|
||||||
|
// Building the breadcrumbs
|
||||||
|
breadcrumbsUrls = generateBreadcrumbs(nextDir);
|
||||||
|
|
||||||
|
filemanager.removeClass('searching');
|
||||||
|
filemanager.find('input[type=search]').val('').hide();
|
||||||
|
filemanager.find('span').show();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
breadcrumbsUrls.push(nextDir);
|
||||||
|
}
|
||||||
|
|
||||||
|
window.location.hash = encodeURIComponent(nextDir);
|
||||||
|
currentPath = nextDir;
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// Clicking on breadcrumbs
|
||||||
|
breadcrumbs.on('click', 'a', function(e){
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
var index = breadcrumbs.find('a').index($(this)),
|
||||||
|
nextDir = breadcrumbsUrls[index];
|
||||||
|
|
||||||
|
breadcrumbsUrls.length = Number(index);
|
||||||
|
|
||||||
|
window.location.hash = encodeURIComponent(nextDir);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
function getCookie(cname) {
|
||||||
|
var name = cname + "=";
|
||||||
|
var decodedCookie = decodeURIComponent(document.cookie);
|
||||||
|
var ca = decodedCookie.split(';');
|
||||||
|
for(var i = 0; i < ca.length; i++) {
|
||||||
|
var c = ca[i];
|
||||||
|
while (c.charAt(0) == ' ') {
|
||||||
|
c = c.substring(1);
|
||||||
|
}
|
||||||
|
if (c.indexOf(name) == 0) {
|
||||||
|
return c.substring(name.length, c.length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
// Navigates to the given hash (path)
|
||||||
|
function goto(hash) {
|
||||||
|
|
||||||
|
hash = decodeURIComponent(hash).slice(1).split('=');
|
||||||
|
|
||||||
|
if (hash.length) {
|
||||||
|
var rendered = '';
|
||||||
|
|
||||||
|
// if hash has search in it
|
||||||
|
if (hash[0] === 'search') {
|
||||||
|
|
||||||
|
filemanager.addClass('searching');
|
||||||
|
rendered = searchData(response, hash[1].toLowerCase());
|
||||||
|
|
||||||
|
if (rendered.length) {
|
||||||
|
currentPath = hash[0];
|
||||||
|
render(rendered);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
render(rendered);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if hash is some path
|
||||||
|
else if (hash[0].trim().length) {
|
||||||
|
|
||||||
|
rendered = searchByPath(hash[0]);
|
||||||
|
|
||||||
|
if (rendered.length) {
|
||||||
|
|
||||||
|
currentPath = hash[0];
|
||||||
|
breadcrumbsUrls = generateBreadcrumbs(hash[0]);
|
||||||
|
render(rendered);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
currentPath = hash[0];
|
||||||
|
breadcrumbsUrls = generateBreadcrumbs(hash[0]);
|
||||||
|
render(rendered);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if there is no hash
|
||||||
|
else {
|
||||||
|
currentPath = data.path;
|
||||||
|
breadcrumbsUrls.push(data.path);
|
||||||
|
render(searchByPath(data.path));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Splits a file path and turns it into clickable breadcrumbs
|
||||||
|
function generateBreadcrumbs(nextDir){
|
||||||
|
var path = nextDir.split('/').slice(0);
|
||||||
|
for(var i=1;i<path.length;i++){
|
||||||
|
path[i] = path[i-1]+ '/' +path[i];
|
||||||
|
}
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Locates a file by path
|
||||||
|
function searchByPath(dir) {
|
||||||
|
var path = dir.split('/'),
|
||||||
|
demo = response,
|
||||||
|
flag = 0;
|
||||||
|
|
||||||
|
for(var i=0;i<path.length;i++){
|
||||||
|
for(var j=0;j<demo.length;j++){
|
||||||
|
if(demo[j].name === path[i]){
|
||||||
|
flag = 1;
|
||||||
|
demo = demo[j].items;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
demo = flag ? demo : [];
|
||||||
|
return demo;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Recursively search through the file tree
|
||||||
|
function searchData(data, searchTerms) {
|
||||||
|
|
||||||
|
data.forEach(function(d){
|
||||||
|
if(d.type === 'folder') {
|
||||||
|
|
||||||
|
searchData(d.items,searchTerms);
|
||||||
|
|
||||||
|
if(d.name.toLowerCase().match(searchTerms)) {
|
||||||
|
folders.push(d);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(d.type === 'file') {
|
||||||
|
if(d.name.toLowerCase().match(searchTerms)) {
|
||||||
|
files.push(d);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return {folders: folders, files: files};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Render the HTML for the file manager
|
||||||
|
function render(data) {
|
||||||
|
|
||||||
|
var scannedFolders = [],
|
||||||
|
scannedFiles = [];
|
||||||
|
|
||||||
|
if(Array.isArray(data)) {
|
||||||
|
|
||||||
|
data.forEach(function (d) {
|
||||||
|
|
||||||
|
if (d.type === 'folder') {
|
||||||
|
scannedFolders.push(d);
|
||||||
|
}
|
||||||
|
else if (d.type === 'file') {
|
||||||
|
scannedFiles.push(d);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else if(typeof data === 'object') {
|
||||||
|
|
||||||
|
scannedFolders = data.folders;
|
||||||
|
scannedFiles = data.files;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Empty the old result and make the new one
|
||||||
|
fileList.empty().hide();
|
||||||
|
|
||||||
|
if(!scannedFolders.length && !scannedFiles.length) {
|
||||||
|
filemanager.find('.nothingfound').show();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
filemanager.find('.nothingfound').hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(scannedFolders.length) {
|
||||||
|
|
||||||
|
scannedFolders.forEach(function(f) {
|
||||||
|
|
||||||
|
var itemsLength = f.items.length,
|
||||||
|
name = escapeHTML(f.name),
|
||||||
|
|
||||||
|
icon = '<span class="icon folder"></span>';
|
||||||
|
|
||||||
|
// Function need to checked by MR! -> Otherwise delete!!!
|
||||||
|
// icon = '<span class="icon folder"></span>',
|
||||||
|
// iconpath = 'images/icons/' + f.path + '.png';
|
||||||
|
|
||||||
|
|
||||||
|
// function imageExists(image_url){
|
||||||
|
|
||||||
|
// var http = new XMLHttpRequest();
|
||||||
|
|
||||||
|
// http.open('HEAD', image_url, false);
|
||||||
|
// http.send();
|
||||||
|
//
|
||||||
|
// return http.status != 404;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// if (imageExists(iconpath)) {
|
||||||
|
// icon = '<div style="display:inline-block;margin:5px 5px 5px 5px;border-radius:8px;width:100px;height:100px;background-position: center center;background-size: cover; background-repeat:no-repeat;background-image: url(\'' +iconpath + '\');"></div>';
|
||||||
|
// } else if(itemsLength) {
|
||||||
|
// icon = '<span class="icon folder full"></span>';
|
||||||
|
// }
|
||||||
|
|
||||||
|
if(itemsLength) {
|
||||||
|
icon = '<span class="icon folder full"></span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if(itemsLength == 1) {
|
||||||
|
itemsLength += ' item';
|
||||||
|
}
|
||||||
|
else if(itemsLength > 1) {
|
||||||
|
itemsLength += ' items';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
itemsLength = 'Empty';
|
||||||
|
}
|
||||||
|
|
||||||
|
var folder = $('<li class="folders"><a href="'+ f.path +'" title="'+ f.path +'" class="folders">'+icon+'<span class="name">' + name + '</span> <span class="details">' + itemsLength + '</span><span class="watchStatus"></span></a></li>');
|
||||||
|
fileList.append(folder)
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(scannedFiles.length) {
|
||||||
|
|
||||||
|
scannedFiles.forEach(function(f) {
|
||||||
|
|
||||||
|
var fileSize = bytesToSize(f.size),
|
||||||
|
name = escapeHTML(f.name),
|
||||||
|
fileType = name.split('.'),
|
||||||
|
icon = '<span class="icon file"></span>';
|
||||||
|
|
||||||
|
fileType = fileType[fileType.length-1];
|
||||||
|
|
||||||
|
if (fileType == "db") {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fileType == "jpg") {
|
||||||
|
icon = '<div style="display:inline-block;margin:20px 30px 0px 25px;border-radius:8px;width:60px;height:70px;background-position: center center;background-size: cover; background-repeat:no-repeat;background-image: url(\'' + f.path + '\');"></div>';
|
||||||
|
var file = $('<li class="files"><a data-fancybox="images" href="'+ f.path+'" title="'+ f.path +'" target="_blank" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span></a></li>');
|
||||||
|
} else if (fileType == "jpeg") {
|
||||||
|
icon = '<div style="display:inline-block;margin:20px 30px 0px 25px;border-radius:8px;width:60px;height:70px;background-position: center center;background-size: cover; background-repeat:no-repeat;background-image: url(\'' + f.path + '\');"></div>';
|
||||||
|
var file = $('<li class="files"><a data-fancybox="images" href="'+ f.path+'" title="'+ f.path +'" target="_blank" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span></a></li>');file.appendTo(fileList);
|
||||||
|
} else if (fileType == "png") {
|
||||||
|
icon = '<div style="display:inline-block;margin:20px 30px 0px 25px;border-radius:8px;width:60px;height:70px;background-position: center center;background-size: cover; background-repeat:no-repeat;background-image: url(\'' + f.path + '\');"></div>';
|
||||||
|
var file = $('<li class="files"><a data-fancybox="images" href="'+ f.path+'" title="'+ f.path +'" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span></a></li>');file.appendTo(fileList);
|
||||||
|
} else if (fileType == "gif") {
|
||||||
|
icon = '<div style="display:inline-block;margin:20px 30px 0px 25px;border-radius:8px;width:60px;height:70px;background-position: center center;background-size: cover; background-repeat:no-repeat;background-image: url(\'' + f.path + '\');"></div>';
|
||||||
|
var file = $('<li class="files"><a data-fancybox="images" href="'+ f.path+'" title="'+ f.path +'" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span></a></li>');file.appendTo(fileList);
|
||||||
|
} else {
|
||||||
|
icon = '<span class="icon file f-'+fileType+'">.'+fileType+'</span>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fileType == "mp4") {
|
||||||
|
|
||||||
|
// adding watched courses to cookie information - dev
|
||||||
|
//var arr = ['001 - Course Introduction.mp4', 'bar', 'Home/IT Basics and Sysadmin Topics/DNS and BIND Deep Dive/004 - DNS Concepts - Terms and Definitions.mp4'];
|
||||||
|
//var json_str = JSON.stringify(arr);
|
||||||
|
//setCookie('watchedVideoArray', json_str);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var style="";
|
||||||
|
// https://stackoverflow.com/questions/2980143/i-want-to-store-javascript-array-as-a-cookie/2980163
|
||||||
|
// get saved cookie information
|
||||||
|
var json_str=getCookie("watchedVideoArray");
|
||||||
|
if (json_str != "") {
|
||||||
|
var arr_watchstatus = JSON.parse(json_str);
|
||||||
|
if (arr_watchstatus.includes(f.path)) {
|
||||||
|
style='style="display: inline;"';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var file = $('<li class="files"><a data-fancybox data-src="'+ f.path+'" title="'+ f.path +'" href="#" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span><span class="watchStatus" id="notWatchedJet">❌</span><span class="watchStatus" id="nowWatched"' + style + '>✅</span></a></li>');
|
||||||
|
|
||||||
|
} else {
|
||||||
|
var file = $('<li class="files"><a href="'+ f.path+'" title="'+ f.path +'" target="_blank" class="files">'+icon+'<span class="name">'+ name +'</span> <span class="details">'+fileSize+'</span></a></li>');
|
||||||
|
}
|
||||||
|
|
||||||
|
file.appendTo(fileList);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Generate the breadcrumbs
|
||||||
|
var url = '';
|
||||||
|
|
||||||
|
if(filemanager.hasClass('searching')){
|
||||||
|
|
||||||
|
url = '<span>Search results: </span>';
|
||||||
|
fileList.removeClass('animated');
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
fileList.addClass('animated');
|
||||||
|
|
||||||
|
breadcrumbsUrls.forEach(function (u, i) {
|
||||||
|
|
||||||
|
var name = u.split('/');
|
||||||
|
|
||||||
|
if (i !== breadcrumbsUrls.length - 1) {
|
||||||
|
url += '<a href="'+u+'"><span class="folderName">' + name[name.length-1] + '</span></a> <span class="arrow">→</span> ';
|
||||||
|
document.getElementById("backButton").href = "#"+u;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
url += '<span class="folderName">' + name[name.length-1] + '</span>';
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
breadcrumbs.text('').append(url);
|
||||||
|
|
||||||
|
// Show the generated elements
|
||||||
|
fileList.fadeIn();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// This function escapes special html characters in names
|
||||||
|
function escapeHTML(text) {
|
||||||
|
return text.replace(/\&/g,'&').replace(/\</g,'<').replace(/\>/g,'>');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Convert file sizes from bytes to human readable units
|
||||||
|
function bytesToSize(bytes) {
|
||||||
|
var sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB'];
|
||||||
|
if (bytes == 0) return '0 Bytes';
|
||||||
|
var i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)));
|
||||||
|
return Math.round(bytes / Math.pow(1024, i), 2) + ' ' + sizes[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
BIN
favicon.ico
Normal file
BIN
favicon.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 106 KiB |
BIN
images/background.jpg
Normal file
BIN
images/background.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 827 KiB |
109
index.php
Normal file
109
index.php
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
<?php
|
||||||
|
require(__DIR__.'/login.php');
|
||||||
|
define('PROJECT_ROOT', getcwd());
|
||||||
|
?>
|
||||||
|
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head lang="en">
|
||||||
|
<title>MIT Learning Manager 2.5</title>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
|
||||||
|
|
||||||
|
<link rel="shortcut icon" href="favicon.ico" type="image/x-icon" />
|
||||||
|
<!-- Include our stylesheets -->
|
||||||
|
<link href="assets/css/styles.css?random=<?php echo uniqid(); ?>" rel="stylesheet"/>
|
||||||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/fancybox/3.5.7/jquery.fancybox.min.css" />
|
||||||
|
|
||||||
|
<!-- Font Awesome -->
|
||||||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css" />
|
||||||
|
|
||||||
|
<!-- Matomo -->
|
||||||
|
<script type="text/javascript">
|
||||||
|
var _paq = window._paq = window._paq || [];
|
||||||
|
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
|
||||||
|
_paq.push(['trackPageView']);
|
||||||
|
_paq.push(['enableLinkTracking']);
|
||||||
|
(function() {
|
||||||
|
var u="https://analytics.michu-it.com/";
|
||||||
|
_paq.push(['setTrackerUrl', u+'matomo.php']);
|
||||||
|
_paq.push(['setSiteId', '3']);
|
||||||
|
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
||||||
|
g.type='text/javascript'; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
|
||||||
|
})();
|
||||||
|
</script>
|
||||||
|
<noscript><p><img src="https://analytics.michu-it.com/matomo.php?idsite=3&rec=1" style="border:0;" alt="" /></p></noscript>
|
||||||
|
<!-- End Matomo Code -->
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="filemanager">
|
||||||
|
<div class="header">
|
||||||
|
MIT Learning Manager
|
||||||
|
</div>
|
||||||
|
<div class="search">
|
||||||
|
<input type="search" placeholder="Find a file.." />
|
||||||
|
</div>
|
||||||
|
<div class="breadcrumbs"></div>
|
||||||
|
<a class="button folderName" id="backButton" href=""><i class="fa fa-arrow-left" aria-hidden="true"></i> Go Back</a>
|
||||||
|
<a class="button" href="./"><i class="fa fa-home" aria-hidden="true"></i> Home</a>
|
||||||
|
|
||||||
|
<ul class="data"></ul>
|
||||||
|
<div class="nothingfound">
|
||||||
|
<div class="nofiles"></div>
|
||||||
|
<span>Error! - No files here.</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Include our script files -->
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.js"></script>
|
||||||
|
<script src="assets/js/script.js?random=<?php echo uniqid(); ?>"></script>
|
||||||
|
<!-- FancyBox -->
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/fancybox/3.5.7/jquery.fancybox.min.js"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
function getCookie(cname) {
|
||||||
|
var name = cname + "=";
|
||||||
|
var decodedCookie = decodeURIComponent(document.cookie);
|
||||||
|
var ca = decodedCookie.split(';');
|
||||||
|
for(var i = 0; i < ca.length; i++) {
|
||||||
|
var c = ca[i];
|
||||||
|
while (c.charAt(0) == ' ') {
|
||||||
|
c = c.substring(1);
|
||||||
|
}
|
||||||
|
if (c.indexOf(name) == 0) {
|
||||||
|
return c.substring(name.length, c.length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
function setCookie(cname,cvalue) {
|
||||||
|
document.cookie = cname + "=" + cvalue + "; expires=Fri, 31 Dec 9999 23:59:59 GMT; path=/";
|
||||||
|
}
|
||||||
|
|
||||||
|
// initialize array only if emty
|
||||||
|
var json_str=getCookie("watchedVideoArray");
|
||||||
|
if (json_str == "") {
|
||||||
|
// If never used this page create an initial array
|
||||||
|
var arr_watchstatus = [
|
||||||
|
"netcloud-init"
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
// Decode allready watched elements from cookie
|
||||||
|
var arr_watchstatus = JSON.parse(json_str);
|
||||||
|
}
|
||||||
|
|
||||||
|
$(document).on('afterClose.fb', function( e, instance, slide ) {
|
||||||
|
console.info( slide.opts.$orig );
|
||||||
|
//console.info( slide.opts.$orig[0].dataset.src ); //Gets Video Path from clicked link
|
||||||
|
|
||||||
|
// append new value to the array
|
||||||
|
arr_watchstatus.push(slide.opts.$orig[0].dataset.src); // adds new video path to array!
|
||||||
|
var json_str = JSON.stringify(arr_watchstatus); // JSON encodes the array
|
||||||
|
setCookie('watchedVideoArray', json_str); // Set new JSON Value to cookie
|
||||||
|
//parent.location.reload(true);
|
||||||
|
|
||||||
|
slide.opts.$orig[0].childNodes[5].style.display = "inline"; // After closing set green thick!
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
448
login.php
Normal file
448
login.php
Normal file
@ -0,0 +1,448 @@
|
|||||||
|
<?php
|
||||||
|
###############################################################
|
||||||
|
# Page Password Protect 1.3
|
||||||
|
###############################################################
|
||||||
|
# By Michael R. - swiss
|
||||||
|
###############################################################
|
||||||
|
# LOGIN OVERRIDE FUNCTION FOR LOCAL ACCESS!
|
||||||
|
|
||||||
|
function getUserIP() {
|
||||||
|
$client = @$_SERVER['HTTP_CLIENT_IP'];
|
||||||
|
$forward = @$_SERVER['HTTP_X_FORWARDED_FOR'];
|
||||||
|
$remote = $_SERVER['REMOTE_ADDR'];
|
||||||
|
|
||||||
|
if(filter_var($client, FILTER_VALIDATE_IP)) {
|
||||||
|
$ip = $client;
|
||||||
|
}
|
||||||
|
elseif(filter_var($forward, FILTER_VALIDATE_IP)) {
|
||||||
|
$ip = $forward;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$ip = $remote;
|
||||||
|
}
|
||||||
|
return $ip;
|
||||||
|
}
|
||||||
|
$user_ip = getUserIP();
|
||||||
|
//print("Your IP is: ".$user_ip); #FOR DEBUGGING!
|
||||||
|
|
||||||
|
if ($user_ip != "83.150.6.68") {
|
||||||
|
# IF IP-ADRESS IS NOT MY IP, CONSTRUCT LOGIN-PAGE:
|
||||||
|
|
||||||
|
$adminPassword = "learn@m-it";
|
||||||
|
|
||||||
|
$LOGIN_INFORMATION = array( $adminPassword );
|
||||||
|
defined('USE_USERNAME') or define('USE_USERNAME', false);
|
||||||
|
// time out after NN minutes of inactivity. Set to 0 to not timeout
|
||||||
|
defined('TIMEOUT_MINUTES') or define('TIMEOUT_MINUTES', 0);
|
||||||
|
// This parameter is only useful when TIMEOUT_MINUTES is not zero
|
||||||
|
// true - timeout time from last activity, false - timeout time from login
|
||||||
|
defined('TIMEOUT_CHECK_ACTIVITY') or define('TIMEOUT_CHECK_ACTIVITY', true);
|
||||||
|
|
||||||
|
// timeout in seconds
|
||||||
|
$timeout = (TIMEOUT_MINUTES == 0 ? 0 : time() + TIMEOUT_MINUTES * 60);
|
||||||
|
// logout?
|
||||||
|
if(isset($_GET['logout'])) {
|
||||||
|
setcookie("verify", '', $timeout, '/'); // clear password;
|
||||||
|
header('Location: ' . "/study/");
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
if(!function_exists('showLoginPasswordProtect')) {
|
||||||
|
// show login form
|
||||||
|
function showLoginPasswordProtect($error_msg) {
|
||||||
|
?>
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html >
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>Please provide password!</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=yes">
|
||||||
|
<meta name="theme-color" content="#191a1b" />
|
||||||
|
<link rel='stylesheet prefetch' href='//fonts.googleapis.com/css?family=Open+Sans'>
|
||||||
|
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
|
||||||
|
<!--<link rel="stylesheet" href="css/login.css?random=<?php //echo uniqid(); ?>"> -->
|
||||||
|
<style>
|
||||||
|
*, *:before, *:after {
|
||||||
|
box-sizing: border-box;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
html, body {
|
||||||
|
font-size: 62.5%;
|
||||||
|
height: 100%;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
html, body {
|
||||||
|
font-size: 50%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
svg {
|
||||||
|
display: inline-block;
|
||||||
|
width: 2rem;
|
||||||
|
height: 2rem;
|
||||||
|
overflow: visible;
|
||||||
|
}
|
||||||
|
.svg-icon {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.svg-icon path {
|
||||||
|
stroke: rgba(255, 255, 255, 0.9);
|
||||||
|
fill: none;
|
||||||
|
stroke-width: 1;
|
||||||
|
}
|
||||||
|
input, button {
|
||||||
|
outline: none;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
.container {
|
||||||
|
position: relative;
|
||||||
|
height: 100%;
|
||||||
|
background-image: url("//www.blackgate.org/enjoy/img/wood.jpg");
|
||||||
|
background-size: cover;
|
||||||
|
overflow: auto;
|
||||||
|
font-family: "Open Sans", Helvetica, Arial, sans-serif;
|
||||||
|
}
|
||||||
|
.row {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -15rem;
|
||||||
|
margin-top: -26.5rem;
|
||||||
|
width: 30rem;
|
||||||
|
height: 53rem;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.login {
|
||||||
|
position: relative;
|
||||||
|
height: 100%;
|
||||||
|
background: -webkit-linear-gradient(top, rgba(113, 113, 113, 0.8) 0%, rgba(0, 0, 0, 0.6) 100%);
|
||||||
|
background: linear-gradient(to bottom, rgba(113, 113, 113, 0.8) 0%, rgba(0, 0, 0, 0.6) 100%);
|
||||||
|
-webkit-transition: opacity 0.1s, -webkit-transform 0.3s cubic-bezier(0.17, -0.65, 0.665, 1.25);
|
||||||
|
transition: opacity 0.1s, -webkit-transform 0.3s cubic-bezier(0.17, -0.65, 0.665, 1.25);
|
||||||
|
transition: opacity 0.1s, transform 0.3s cubic-bezier(0.17, -0.65, 0.665, 1.25);
|
||||||
|
transition: opacity 0.1s, transform 0.3s cubic-bezier(0.17, -0.65, 0.665, 1.25), -webkit-transform 0.3s cubic-bezier(0.17, -0.65, 0.665, 1.25);
|
||||||
|
-webkit-transform: scale(1);
|
||||||
|
transform: scale(1);
|
||||||
|
}
|
||||||
|
.login.inactive {
|
||||||
|
opacity: 0;
|
||||||
|
-webkit-transform: scale(1.1);
|
||||||
|
transform: scale(1.1);
|
||||||
|
}
|
||||||
|
.login__lock {
|
||||||
|
position: absolute;
|
||||||
|
top: 8rem;
|
||||||
|
left: 10rem;
|
||||||
|
width: 14rem;
|
||||||
|
height: 2.8rem;
|
||||||
|
font-size: 128px;
|
||||||
|
|
||||||
|
}
|
||||||
|
@media screen and (min-width: 769px) {
|
||||||
|
.login__lock {
|
||||||
|
font-size: 152px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.login__check {
|
||||||
|
position: absolute;
|
||||||
|
top: 16rem;
|
||||||
|
left: 13.5rem;
|
||||||
|
width: 14rem;
|
||||||
|
height: 2.8rem;
|
||||||
|
background: #fff;
|
||||||
|
-webkit-transform-origin: 0 100%;
|
||||||
|
transform-origin: 0 100%;
|
||||||
|
-webkit-transform: rotate(-45deg);
|
||||||
|
transform: rotate(-45deg);
|
||||||
|
}
|
||||||
|
.login__check:before {
|
||||||
|
content: "";
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
bottom: 100%;
|
||||||
|
width: 2.8rem;
|
||||||
|
height: 5.2rem;
|
||||||
|
background: #fff;
|
||||||
|
box-shadow: inset -0.2rem -2rem 2rem rgba(0, 0, 0, 0.2);
|
||||||
|
}
|
||||||
|
.login__form {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 50%;
|
||||||
|
padding: 1.5rem 2.5rem;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.login__row {
|
||||||
|
height: 5rem;
|
||||||
|
padding-top: 1rem;
|
||||||
|
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
|
||||||
|
}
|
||||||
|
.login__icon {
|
||||||
|
margin-bottom: -0.4rem;
|
||||||
|
margin-right: 0.5rem;
|
||||||
|
}
|
||||||
|
.login__icon.name path {
|
||||||
|
stroke-dasharray: 73.50196075439453;
|
||||||
|
stroke-dashoffset: 73.50196075439453;
|
||||||
|
-webkit-animation: animatePath 2s 0.5s forwards;
|
||||||
|
animation: animatePath 2s 0.5s forwards;
|
||||||
|
}
|
||||||
|
.login__icon.pass path {
|
||||||
|
stroke-dasharray: 92.10662841796875;
|
||||||
|
stroke-dashoffset: 92.10662841796875;
|
||||||
|
-webkit-animation: animatePath 2s 0.5s forwards;
|
||||||
|
animation: animatePath 2s 0.5s forwards;
|
||||||
|
}
|
||||||
|
.login__input {
|
||||||
|
display: inline-block;
|
||||||
|
width: 22rem;
|
||||||
|
height: 100%;
|
||||||
|
padding-left: 1.5rem;
|
||||||
|
font-size: 1.5rem;
|
||||||
|
background: transparent;
|
||||||
|
color: #FDFCFD;
|
||||||
|
}
|
||||||
|
.login__submit {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
height: 4rem;
|
||||||
|
margin: 5rem 0 2.2rem;
|
||||||
|
color: rgba(255, 255, 255, 0.8);
|
||||||
|
background: #383838;
|
||||||
|
font-size: 1.5rem;
|
||||||
|
border-radius: 3rem;
|
||||||
|
cursor: pointer;
|
||||||
|
overflow: hidden;
|
||||||
|
-webkit-transition: width 0.3s 0.15s, font-size 0.1s 0.15s;
|
||||||
|
transition: width 0.3s 0.15s, font-size 0.1s 0.15s;
|
||||||
|
}
|
||||||
|
.login__submit:after {
|
||||||
|
content: "";
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -1.5rem;
|
||||||
|
margin-top: -1.5rem;
|
||||||
|
width: 3rem;
|
||||||
|
height: 3rem;
|
||||||
|
border: 2px dotted #fff;
|
||||||
|
border-radius: 50%;
|
||||||
|
border-left: none;
|
||||||
|
border-bottom: none;
|
||||||
|
-webkit-transition: opacity 0.1s 0.4s;
|
||||||
|
transition: opacity 0.1s 0.4s;
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
.login__submit.processing {
|
||||||
|
width: 4rem;
|
||||||
|
font-size: 0;
|
||||||
|
}
|
||||||
|
.login__submit.processing:after {
|
||||||
|
opacity: 1;
|
||||||
|
-webkit-animation: rotate 0.5s 0.4s infinite linear;
|
||||||
|
animation: rotate 0.5s 0.4s infinite linear;
|
||||||
|
}
|
||||||
|
.login__submit.success {
|
||||||
|
-webkit-transition: opacity 0.1s 0.3s, background-color 0.1s 0.3s, -webkit-transform 0.3s 0.1s ease-out;
|
||||||
|
transition: opacity 0.1s 0.3s, background-color 0.1s 0.3s, -webkit-transform 0.3s 0.1s ease-out;
|
||||||
|
transition: transform 0.3s 0.1s ease-out, opacity 0.1s 0.3s, background-color 0.1s 0.3s;
|
||||||
|
transition: transform 0.3s 0.1s ease-out, opacity 0.1s 0.3s, background-color 0.1s 0.3s, -webkit-transform 0.3s 0.1s ease-out;
|
||||||
|
-webkit-transform: scale(30);
|
||||||
|
transform: scale(30);
|
||||||
|
opacity: 0.9;
|
||||||
|
}
|
||||||
|
.login__submit.success:after {
|
||||||
|
-webkit-transition: opacity 0.1s 0s;
|
||||||
|
transition: opacity 0.1s 0s;
|
||||||
|
opacity: 0;
|
||||||
|
-webkit-animation: none;
|
||||||
|
animation: none;
|
||||||
|
}
|
||||||
|
.login__signup {
|
||||||
|
font-size: 1.2rem;
|
||||||
|
color: #ABA8AE;
|
||||||
|
}
|
||||||
|
.login__signup a {
|
||||||
|
color: #fff;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.ripple {
|
||||||
|
position: absolute;
|
||||||
|
width: 15rem;
|
||||||
|
height: 15rem;
|
||||||
|
margin-left: -7.5rem;
|
||||||
|
margin-top: -7.5rem;
|
||||||
|
background: rgba(0, 0, 0, 0.4);
|
||||||
|
-webkit-transform: scale(0);
|
||||||
|
transform: scale(0);
|
||||||
|
-webkit-animation: animRipple 0.4s;
|
||||||
|
animation: animRipple 0.4s;
|
||||||
|
border-radius: 50%;
|
||||||
|
}
|
||||||
|
@-webkit-keyframes animRipple {
|
||||||
|
to {
|
||||||
|
-webkit-transform: scale(3.5);
|
||||||
|
transform: scale(3.5);
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@keyframes animRipple {
|
||||||
|
to {
|
||||||
|
-webkit-transform: scale(3.5);
|
||||||
|
transform: scale(3.5);
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@-webkit-keyframes rotate {
|
||||||
|
to {
|
||||||
|
-webkit-transform: rotate(360deg);
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@keyframes rotate {
|
||||||
|
to {
|
||||||
|
-webkit-transform: rotate(360deg);
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@-webkit-keyframes animatePath {
|
||||||
|
to {
|
||||||
|
stroke-dashoffset: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@keyframes animatePath {
|
||||||
|
to {
|
||||||
|
stroke-dashoffset: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body onLoad="document.getElementsByTagName('input')[0].focus();"
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<div class="login">
|
||||||
|
<!--<div class="login__check"></div>-->
|
||||||
|
<div class="login__lock"><i class="fa fa-lock" aria-hidden="true"></i></div>
|
||||||
|
<div class="login__form">
|
||||||
|
|
||||||
|
<form method="post">
|
||||||
|
<div class="login__row">
|
||||||
|
<svg class="login__icon pass svg-icon" viewBox="0 0 20 20">
|
||||||
|
<path d="M0,20 20,20 20,8 0,8z M10,13 10,16z M4,8 a6,8 0 0,1 12,0" />
|
||||||
|
</svg>
|
||||||
|
<input type="password" name="access_password" class="login__input pass" placeholder="Password"/>
|
||||||
|
</div>
|
||||||
|
<button type="submit" value="Submit" class="login__submit">Login</button>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<p class="login__signup">Please provide the correct password!</p>
|
||||||
|
<font color="red" style="font-size: x-small";><?php echo $error_msg; ?></font>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script src='//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
var animating = false,
|
||||||
|
submitPhase1 = 1100,
|
||||||
|
submitPhase2 = 400,
|
||||||
|
logoutPhase1 = 800,
|
||||||
|
$login = $(".login"),
|
||||||
|
$app = $(".app");
|
||||||
|
|
||||||
|
function ripple(elem, e) {
|
||||||
|
$(".ripple").remove();
|
||||||
|
var elTop = elem.offset().top,
|
||||||
|
elLeft = elem.offset().left,
|
||||||
|
x = e.pageX - elLeft,
|
||||||
|
y = e.pageY - elTop;
|
||||||
|
var $ripple = $("<div class='ripple'></div>");
|
||||||
|
$ripple.css({top: y, left: x});
|
||||||
|
elem.append($ripple);
|
||||||
|
};
|
||||||
|
|
||||||
|
$(document).on("click", ".login__submit", function(e) {
|
||||||
|
if (animating) return;
|
||||||
|
animating = true;
|
||||||
|
var that = this;
|
||||||
|
ripple($(that), e);
|
||||||
|
$(that).addClass("processing");
|
||||||
|
setTimeout(function() {
|
||||||
|
$(that).addClass("success");
|
||||||
|
setTimeout(function() {
|
||||||
|
$app.show();
|
||||||
|
$app.css("top");
|
||||||
|
$app.addClass("active");
|
||||||
|
}, submitPhase2 - 70);
|
||||||
|
setTimeout(function() {
|
||||||
|
$login.hide();
|
||||||
|
$login.addClass("inactive");
|
||||||
|
animating = false;
|
||||||
|
$(that).removeClass("success processing");
|
||||||
|
}, submitPhase2);
|
||||||
|
}, submitPhase1);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
<?php
|
||||||
|
// stop at this point
|
||||||
|
die();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// user provided password
|
||||||
|
if (isset($_POST['access_password'])) {
|
||||||
|
$login = isset($_POST['access_login']) ? $_POST['access_login'] : '';
|
||||||
|
$pass = $_POST['access_password'];
|
||||||
|
if (!USE_USERNAME && !in_array($pass, $LOGIN_INFORMATION)
|
||||||
|
|| (USE_USERNAME && ( !array_key_exists($login, $LOGIN_INFORMATION) || $LOGIN_INFORMATION[$login] != $pass ) )
|
||||||
|
) {
|
||||||
|
showLoginPasswordProtect("wrong password!");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// set cookie if password was validated
|
||||||
|
setcookie("verify", md5($login.'%'.$pass), $timeout, '/');
|
||||||
|
|
||||||
|
// Some programs (like Form1 Bilder) check $_POST array to see if parameters passed
|
||||||
|
// So need to clear password protector variables
|
||||||
|
unset($_POST['access_login']);
|
||||||
|
unset($_POST['access_password']);
|
||||||
|
unset($_POST['Submit']);
|
||||||
|
header('Location: ' . $logoutURL . '/study/');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// check if password cookie is set
|
||||||
|
if (!isset($_COOKIE['verify'])) {
|
||||||
|
showLoginPasswordProtect("");
|
||||||
|
}
|
||||||
|
// check if cookie is good
|
||||||
|
$found = false;
|
||||||
|
foreach($LOGIN_INFORMATION as $key=>$val) {
|
||||||
|
$lp = (USE_USERNAME ? $key : '') .'%'.$val;
|
||||||
|
if ($_COOKIE['verify'] == md5($lp)) {
|
||||||
|
$found = true;
|
||||||
|
// prolong timeout
|
||||||
|
if (TIMEOUT_CHECK_ACTIVITY) {
|
||||||
|
setcookie("verify", md5($lp), $timeout, '/');
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$found) {
|
||||||
|
showLoginPasswordProtect("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
57
scan.php
Normal file
57
scan.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
$dir = "Home";
|
||||||
|
|
||||||
|
// Run the recursive function
|
||||||
|
$response = scan($dir);
|
||||||
|
|
||||||
|
// This function scans the files folder recursively, and builds a large array
|
||||||
|
function scan($dir){
|
||||||
|
|
||||||
|
$files = array();
|
||||||
|
|
||||||
|
// Is there actually such a folder/file?
|
||||||
|
if(file_exists($dir)){
|
||||||
|
|
||||||
|
foreach(scandir($dir) as $f) {
|
||||||
|
|
||||||
|
if(!$f || $f[0] == '.') {
|
||||||
|
continue; // Ignore hidden files
|
||||||
|
}
|
||||||
|
|
||||||
|
if(is_dir($dir . '/' . $f)) {
|
||||||
|
// Remove Synology Temp-Folders, if they exists!
|
||||||
|
if($f != '@eaDir') {
|
||||||
|
// The path is a folder
|
||||||
|
$files[] = array(
|
||||||
|
"name" => $f,
|
||||||
|
"type" => "folder",
|
||||||
|
"path" => $dir . '/' . $f,
|
||||||
|
"items" => scan($dir . '/' . $f) // Recursively get the contents of the folder
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (is_file($dir . '/' . $f)) {
|
||||||
|
// It is a file
|
||||||
|
$files[] = array(
|
||||||
|
"name" => $f,
|
||||||
|
"type" => "file",
|
||||||
|
"path" => $dir . '/' . $f,
|
||||||
|
"size" => filesize($dir . '/' . $f) // Gets the size of this file
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return $files;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output the directory listing as JSON
|
||||||
|
header('Content-type: application/json');
|
||||||
|
|
||||||
|
echo json_encode(array(
|
||||||
|
"name" => basename($dir),
|
||||||
|
"type" => "folder",
|
||||||
|
"path" => $dir,
|
||||||
|
"items" => $response
|
||||||
|
));
|
Loading…
Reference in New Issue
Block a user