1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687 |
- <?php
- //Default Configuration
- $CONFIG = '{"lang":"en","error_reporting":false,"show_hidden":false,"hide_Cols":false,"calc_folder":false}';
- /**
- * H3K | Tiny File Manager V2.4.3
- * CCP Programmers | ccpprogrammers@gmail.com
- * https://tinyfilemanager.github.io
- */
- //TFM version
- define('VERSION', '2.4.3');
- //Application Title
- define('APP_TITLE', '超级蚂蚁');
- // --- EDIT BELOW CONFIGURATION CAREFULLY ---
- define('DOCUMENT_ROOT',$_SERVER['DOCUMENT_ROOT']);
- /*
- #################################################################################################################
- This is an OPTIONAL configuration file.
- The role of this file is to make updating of "tinyfilemanager.php" easier.
- So you can:
- -Feel free to remove completely this file and configure "tinyfilemanager.php" as a single file application.
- or
- -Put inside this file all the static configuration you want and forgot to configure "tinyfilemanager.php".
- #################################################################################################################
- */
- // Auth with login/password
- // set true/false to enable/disable it
- // Is independent from IP white- and blacklisting
- $use_auth = true;
- // Login user name and password
- // Users: array('Username' => 'Password', 'Username2' => 'Password2', ...)
- // Generate secure password hash - https://tinyfilemanager.github.io/docs/pwd.html
- $auth_users = array(
- 'dev' => 'a9d5de7d15a202a7',
- 'admin' => '6nnBG%bnqk',
- 'other' => 'superant',
- 'firebase' => 'firebase',
- 'share' => 'share',
- 'activity' => 'activity',
- 'announcement' => 'announcement',
- 'clientErrorLogFiles' => 'clientErrorLogFiles',
- 'cardImgManage' => 'cardImgManage',
- 'advertise' => 'advertise',
- );
- $max_upload_size = [
- 'dev' => 500,
- 'admin' => 500,
- 'other' => 500,
- 'firebase' => 500,
- 'share' => 500,
- 'activity' => 500,
- 'announcement' => 500,
- ];
- //set application theme
- //options - 'light' and 'dark'
- $theme = 'light';
- define('FM_THEME', $theme);
- // Readonly users
- // e.g. array('users', 'guest', ...)
- $readonly_users = [
- ];
- $delete_users = [
- 'admin',
- 'share'
- ];
- // Enable highlight.js (https://highlightjs.org/) on view's page
- $use_highlightjs = true;
- // highlight.js style
- // for dark theme use 'ir-black'
- $highlightjs_style = 'vs';
- // Enable ace.js (https://ace.c9.io/) on view's page
- $edit_files = true;
- // Default timezone for date() and time()
- // Doc - http://php.net/manual/en/timezones.php
- $default_timezone = 'Etc/UTC'; // UTC
- // Root path for file manager
- // use absolute path of directory i.e: '/var/www/folder' or $_SERVER['DOCUMENT_ROOT'].'/folder'
- $root_path = $_SERVER['DOCUMENT_ROOT'];
- // Root url for links in file manager.Relative to $http_host. Variants: '', 'path/to/subfolder'
- // Will not working if $root_path will be outside of server document root
- $root_url = '';
- // Server hostname. Can set manually if wrong
- $http_host = $_SERVER['HTTP_HOST'];
- // user specific directories
- // array('Username' => 'Directory path', 'Username2' => 'Directory path', ...)
- $directories_users = [
- 'dev' => 'public/game/',
- 'firebase' => 'public/game/image/firebase/',
- 'share' => 'img/feed/',
- 'activity' => 'public/game/image/activity_2/',
- 'announcement' => 'public/game/image/announcement/',
- 'clientErrorLogFiles' => 'deBUG/clientErrorLogFiles/',
- 'cardImgManage' => 'public/game/image/newcard/',
- 'advertise' => 'public/game/advertisementImgs/',
- ];
- // input encoding for iconv
- $iconv_input_encoding = 'UTF-8';
- // date() format for file modification date
- // Doc - https://www.php.net/manual/en/function.date.php
- $datetime_format = 'Y-m-d H:i';
- // Allowed file extensions for create and rename files
- // e.g. 'txt,html,css,js'
- $allowed_file_extensions = '';
- // Allowed file extensions for upload files
- // e.g. 'gif,png,jpg,html,txt'
- $allowed_upload_extensions = '';
- // Favicon path. This can be either a full url to an .PNG image, or a path based on the document root.
- // full path, e.g http://example.com/favicon.png
- // local path, e.g images/icons/favicon.png
- $favicon_path = '?img=favicon';
- // Files and folders to excluded from listing
- // e.g. array('myfile.html', 'personal-folder', '*.php', ...)
- $exclude_items = array();
- // Online office Docs Viewer
- // Availabe rules are 'google', 'microsoft' or false
- // google => View documents using Google Docs Viewer
- // microsoft => View documents using Microsoft Web Apps Viewer
- // false => disable online doc viewer
- $online_viewer = 'google';
- // Sticky Nav bar
- // true => enable sticky header
- // false => disable sticky header
- $sticky_navbar = true;
- // Possible rules are 'OFF', 'AND' or 'OR'
- // OFF => Don't check connection IP, defaults to OFF
- // AND => Connection must be on the whitelist, and not on the blacklist
- // OR => Connection must be on the whitelist, or not on the blacklist
- $ip_ruleset = 'OFF';
- // Should users be notified of their block?
- $ip_silent = true;
- // IP-addresses, both ipv4 and ipv6
- $ip_whitelist = array(
- '127.0.0.1', // local ipv4
- '::1' // local ipv6
- );
- // IP-addresses, both ipv4 and ipv6
- $ip_blacklist = array(
- '0.0.0.0', // non-routable meta ipv4
- '::' // non-routable meta ipv6
- );
- // --- EDIT BELOW CAREFULLY OR DO NOT EDIT AT ALL ---
- // max upload file size
- $max_upload_size_bytes = 0.2;//单位MB
- // private key and session name to store to the session
- if ( !defined( 'FM_SESSION_ID')) {
- define('FM_SESSION_ID', 'filemanager_'.$_GET['fm_usr']);
- }
- // Configuration
- $cfg = new FM_Config();
- // Default language
- $lang = isset($cfg->data['lang']) ? $cfg->data['lang'] : 'en';
- // Show or hide files and folders that starts with a dot
- $show_hidden_files = isset($cfg->data['show_hidden']) ? $cfg->data['show_hidden'] : true;
- // PHP error reporting - false = Turns off Errors, true = Turns on Errors
- $report_errors = isset($cfg->data['error_reporting']) ? $cfg->data['error_reporting'] : true;
- // Hide Permissions and Owner cols in file-listing
- $hide_Cols = isset($cfg->data['hide_Cols']) ? $cfg->data['hide_Cols'] : true;
- // Show directory size: true or speedup output: false
- $calc_folder = isset($cfg->data['calc_folder']) ? $cfg->data['calc_folder'] : true;
- //available languages
- $lang_list = array(
- 'en' => 'English'
- );
- if ($report_errors == true) {
- @ini_set('error_reporting', E_ALL);
- @ini_set('display_errors', 1);
- } else {
- @ini_set('error_reporting', E_ALL);
- @ini_set('display_errors', 0);
- }
- // if fm included
- if (defined('FM_EMBED')) {
- $use_auth = false;
- $sticky_navbar = false;
- } else {
- @set_time_limit(600);
- date_default_timezone_set($default_timezone);
- ini_set('default_charset', 'UTF-8');
- if (version_compare(PHP_VERSION, '5.6.0', '<') && function_exists('mb_internal_encoding')) {
- mb_internal_encoding('UTF-8');
- }
- if (function_exists('mb_regex_encoding')) {
- mb_regex_encoding('UTF-8');
- }
- session_cache_limiter('');
- session_name(FM_SESSION_ID );
- function session_error_handling_function($code, $msg, $file, $line) {
- // Permission denied for default session, try to create a new one
- if ($code == 2) {
- session_abort();
- session_id(session_create_id());
- @session_start();
- }
- }
- set_error_handler('session_error_handling_function');
- session_start();
- restore_error_handler();
- }
- if (empty($auth_users)) {
- $use_auth = false;
- }
- if($_SESSION[FM_SESSION_ID]['logged'] == "share"){
- $directories_users["share"] = $directories_users["share"].$_SESSION[FM_SESSION_ID]['shareCountry']."/";
- }else if($_SESSION[FM_SESSION_ID]['logged'] == "activity"){
- $directories_users["activity"] = $directories_users["activity"].$_SESSION[FM_SESSION_ID]['activityPath']."/";
- }
- if(!empty($max_upload_size[$_SESSION[FM_SESSION_ID]['logged']])){
- $max_upload_size_bytes = $max_upload_size[$_SESSION[FM_SESSION_ID]['logged']];
- }
- // max upload file size
- define('MAX_UPLOAD_SIZE', $max_upload_size_bytes);
- $is_https = isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'] == 'on' || $_SERVER['HTTPS'] == 1) || isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https';
- // update $root_url based on user specific directories
- if (isset($_SESSION[FM_SESSION_ID]['logged']) && !empty($directories_users[$_SESSION[FM_SESSION_ID]['logged']])) {
- $wd = fm_clean_path(dirname($_SERVER['PHP_SELF']));
- $root_url = $root_url.$wd.DIRECTORY_SEPARATOR.$directories_users[$_SESSION[FM_SESSION_ID]['logged']];
- }
- // clean $root_url
- $root_url = fm_clean_path($root_url);
- // abs path for site
- defined('FM_ROOT_URL') || define('FM_ROOT_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . (!empty($root_url) ? '/' . $root_url : ''));
- defined('FM_SELF_URL') || define('FM_SELF_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . $_SERVER['PHP_SELF']);
- // logout
- if (isset($_GET['logout'])) {
- unset($_SESSION[FM_SESSION_ID]['logged']);
- fm_redirect(FM_SELF_URL);
- }
- // Show image here
- if (isset($_GET['img'])) {
- fm_show_image($_GET['img']);
- }
- // Validate connection IP
- if($ip_ruleset != 'OFF'){
- $clientIp = $_SERVER['REMOTE_ADDR'];
- $proceed = false;
- $whitelisted = in_array($clientIp, $ip_whitelist);
- $blacklisted = in_array($clientIp, $ip_blacklist);
- if($ip_ruleset == 'AND'){
- if($whitelisted == true && $blacklisted == false){
- $proceed = true;
- }
- } else
- if($ip_ruleset == 'OR'){
- if($whitelisted == true || $blacklisted == false){
- $proceed = true;
- }
- }
- if($proceed == false){
- trigger_error('User connection denied from: ' . $clientIp, E_USER_WARNING);
- if($ip_silent == false){
- fm_set_msg('Access denied. IP restriction applicable', 'error');
- fm_show_header_login();
- fm_show_message();
- }
- exit();
- }
- }
- function login($auth_users){
- // Logging In
- if (function_exists('password_verify')) {
- if (isset($auth_users[$_GET['fm_usr']]) && isset($_GET['fm_pwd']) && $_GET['fm_pwd'] == $auth_users[$_GET['fm_usr']]) {
- $_SESSION[FM_SESSION_ID]['logged'] = $_GET['fm_usr'];
- $_SESSION[FM_SESSION_ID]['userName'] = $_GET['userName'];
- if(!empty($_GET['shareCountry'])){
- $_SESSION[FM_SESSION_ID]['shareCountry'] = $_GET['shareCountry'];
- }
- if(!empty($_GET['activityPath'])){
- $_SESSION[FM_SESSION_ID]['activityPath'] = $_GET['activityPath'];
- }
- fm_set_msg(lng('You are logged in'));
- fm_redirect(FM_SELF_URL . '?fm_usr=' . $_GET['fm_usr'] . '&p=');
- } else {
- unset($_SESSION[FM_SESSION_ID]['logged']);
- fm_set_msg(lng('Login failed. Invalid username or password'), 'error');
- fm_redirect(FM_SELF_URL);
- }
- } else {
- fm_set_msg(lng('password_hash not supported, Upgrade PHP version'), 'error');;
- }
- }
- // Auth
- if ($use_auth) {
- if (isset($_SESSION[FM_SESSION_ID]['logged'], $auth_users[$_SESSION[FM_SESSION_ID]['logged']])) {
- if (isset($_GET['fm_usr'], $_GET['fm_pwd'])) {
- login($auth_users);
- }
- } elseif (isset($_GET['fm_usr'], $_GET['fm_pwd'])) {
- login($auth_users);
- } else {
- // Form
- unset($_SESSION[FM_SESSION_ID]['logged']);
- die();
- fm_show_header_login();
- ?>
- <section class="h-100">
- <div class="container h-100">
- <div class="row justify-content-md-center h-100">
- <div class="card-wrapper">
- <div class="card fat <?php echo fm_get_theme(); ?>">
- <div class="card-body">
- <form class="form-signin" action="" method="post" autocomplete="off">
- <div class="form-group">
- <div class="brand">
- <svg version="1.0" xmlns="http://www.w3.org/2000/svg" M1008 width="100%" height="80px" viewBox="0 0 238.000000 140.000000" aria-label="H3K Tiny File Manager">
- <g transform="translate(0.000000,140.000000) scale(0.100000,-0.100000)" fill="#000000" stroke="none">
- <path d="M160 700 l0 -600 110 0 110 0 0 260 0 260 70 0 70 0 0 -260 0 -260 110 0 110 0 0 600 0 600 -110 0 -110 0 0 -260 0 -260 -70 0 -70 0 0 260 0 260 -110 0 -110 0 0 -600z"/>
- <path fill="#003500" d="M1008 1227 l-108 -72 0 -117 0 -118 110 0 110 0 0 110 0 110 70 0 70 0 0 -180 0 -180 -125 0 c-69 0 -125 -3 -125 -6 0 -3 23 -39 52 -80 l52 -74 73 0 73 0 0 -185 0 -185 -70 0 -70 0 0 115 0 115 -110 0 -110 0 0 -190 0 -190 181 0 181 0 109 73 108 72 1 181 0 181 -69 48 -68 49 68 50 69 49 0 249 0 248 -182 -1 -183 0 -107 -72z"/>
- <path d="M1640 700 l0 -600 110 0 110 0 0 208 0 208 35 34 35 34 35 -34 35 -34 0 -208 0 -208 110 0 110 0 0 212 0 213 -87 87 -88 88 88 88 87 87 0 213 0 212 -110 0 -110 0 0 -208 0 -208 -70 -69 -70 -69 0 277 0 277 -110 0 -110 0 0 -600z"/></g>
- </svg>
- </div>
- <div class="text-center">
- <h1 class="card-title"><?php echo APP_TITLE; ?></h1>
- </div>
- </div>
- <hr />
- <div class="form-group">
- <label for="fm_usr"><?php echo lng('Username'); ?></label>
- <input type="text" class="form-control" id="fm_usr" name="fm_usr" required autofocus>
- </div>
- <div class="form-group">
- <label for="fm_pwd"><?php echo lng('Password'); ?></label>
- <input type="password" class="form-control" id="fm_pwd" name="fm_pwd" required>
- </div>
- <div class="form-group">
- <?php fm_show_message(); ?>
- </div>
- <div class="form-group">
- <button type="submit" class="btn btn-success btn-block mt-4" role="button">
- <?php echo lng('Login'); ?>
- </button>
- </div>
- </form>
- </div>
- </div>
- <div class="footer text-center">
- —— ©
- <a href="https://tinyfilemanager.github.io/" target="_blank" class="text-muted" data-version="<?php echo VERSION; ?>">CCP Programmers</a> ——
- </div>
- </div>
- </div>
- </div>
- </section>
- <?php
- fm_show_footer_login();
- exit;
- }
- }
- // update root path
- if ($use_auth && isset($_SESSION[FM_SESSION_ID]['logged'])) {
- $root_path = isset($directories_users[$_SESSION[FM_SESSION_ID]['logged']]) ? $directories_users[$_SESSION[FM_SESSION_ID]['logged']] : $root_path;
- }
- // clean and check $root_path
- $root_path = rtrim($root_path, '\\/');
- $root_path = str_replace('\\', '/', $root_path);
- if (!@is_dir($root_path)) {
- echo "<h1>Root path \"{$root_path}\" not found!</h1>";
- exit;
- }
- defined('FM_SHOW_HIDDEN') || define('FM_SHOW_HIDDEN', $show_hidden_files);
- defined('FM_ROOT_PATH') || define('FM_ROOT_PATH', $root_path);
- defined('FM_LANG') || define('FM_LANG', $lang);
- defined('FM_FILE_EXTENSION') || define('FM_FILE_EXTENSION', $allowed_file_extensions);
- defined('FM_UPLOAD_EXTENSION') || define('FM_UPLOAD_EXTENSION', $allowed_upload_extensions);
- defined('FM_EXCLUDE_ITEMS') || define('FM_EXCLUDE_ITEMS', $exclude_items);
- defined('FM_DOC_VIEWER') || define('FM_DOC_VIEWER', $online_viewer);
- define('FM_READONLY', $use_auth && !empty($readonly_users) && isset($_SESSION[FM_SESSION_ID]['logged']) && in_array($_SESSION[FM_SESSION_ID]['logged'], $readonly_users));
- define('FM_DELETE', $use_auth && !empty($delete_users) && isset($_SESSION[FM_SESSION_ID]['logged']) && in_array($_SESSION[FM_SESSION_ID]['logged'], $delete_users));
- define('FM_IS_WIN', DIRECTORY_SEPARATOR == '\\');
- // always use ?p=
- if (!isset($_GET['p']) && empty($_FILES)) {
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=');
- }
- // get path
- $p = isset($_GET['p']) ? $_GET['p'] : (isset($_POST['p']) ? $_POST['p'] : '');
- // clean path
- $p = fm_clean_path($p);
- // for ajax request - save
- $input = file_get_contents('php://input');
- $_POST = (strpos($input, 'ajax') != FALSE && strpos($input, 'save') != FALSE) ? json_decode($input, true) : $_POST;
- // instead globals vars
- define('FM_PATH', $p);
- define('FM_USE_AUTH', $use_auth);
- define('FM_EDIT_FILE', $edit_files);
- defined('FM_ICONV_INPUT_ENC') || define('FM_ICONV_INPUT_ENC', $iconv_input_encoding);
- defined('FM_USE_HIGHLIGHTJS') || define('FM_USE_HIGHLIGHTJS', $use_highlightjs);
- defined('FM_HIGHLIGHTJS_STYLE') || define('FM_HIGHLIGHTJS_STYLE', $highlightjs_style);
- defined('FM_DATETIME_FORMAT') || define('FM_DATETIME_FORMAT', $datetime_format);
- unset($p, $use_auth, $iconv_input_encoding, $use_highlightjs, $highlightjs_style);
- /*************************** ACTIONS ***************************/
- // AJAX Request
- if (isset($_POST['ajax']) && !FM_READONLY) {
- // save
- if (isset($_POST['type']) && $_POST['type'] == "save") {
- // get current path
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- // check path
- if (!is_dir($path)) {
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=');
- }
- $file = $_GET['edit'];
- $file = fm_clean_path($file);
- $file = str_replace('/', '', $file);
- if ($file == '' || !is_file($path . '/' . $file)) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- header('X-XSS-Protection:0');
- $file_path = $path . '/' . $file;
- $writedata = $_POST['content'];
- $fd = fopen($file_path, "w");
- $write_results = @fwrite($fd, $writedata);
- fclose($fd);
- if ($write_results === false){
- header("HTTP/1.1 500 Internal Server Error");
- die("Could Not Write File! - Check Permissions / Ownership");
- }
- die(true);
- }
- //search : get list of files from the current folder
- if(isset($_POST['type']) && $_POST['type']=="search") {
- $dir = FM_ROOT_PATH;
- $response = scan(fm_clean_path($_POST['path']), $_POST['content']);
- echo json_encode($response);
- exit();
- }
- // backup files
- if (isset($_POST['type']) && $_POST['type'] == "backup" && !empty($_POST['file'])) {
- $fileName = $_POST['file'];
- $fullPath = FM_ROOT_PATH . '/';
- if (!empty($_POST['path'])) {
- $relativeDirPath = fm_clean_path($_POST['path']);
- $fullPath .= "{$relativeDirPath}/";
- }
- $date = date("dMy-His");
- $newFileName = "{$fileName}-{$date}.bak";
- $fullyQualifiedFileName = $fullPath . $fileName;
- try {
- if (!file_exists($fullyQualifiedFileName)) {
- throw new Exception("File {$fileName} not found");
- }
- if (copy($fullyQualifiedFileName, $fullPath . $newFileName)) {
- echo "Backup {$newFileName} created";
- } else {
- throw new Exception("Could not copy file {$fileName}");
- }
- } catch (Exception $e) {
- echo $e->getMessage();
- }
- }
- // Save Config
- if (isset($_POST['type']) && $_POST['type'] == "settings") {
- global $cfg, $lang, $report_errors, $show_hidden_files, $lang_list, $hide_Cols, $calc_folder;
- $newLng = $_POST['js-language'];
- fm_get_translations([]);
- if (!array_key_exists($newLng, $lang_list)) {
- $newLng = 'en';
- }
- $erp = isset($_POST['js-error-report']) && $_POST['js-error-report'] == "true" ? true : false;
- $shf = isset($_POST['js-show-hidden']) && $_POST['js-show-hidden'] == "true" ? true : false;
- $hco = isset($_POST['js-hide-cols']) && $_POST['js-hide-cols'] == "true" ? true : false;
- $caf = isset($_POST['js-calc-folder']) && $_POST['js-calc-folder'] == "true" ? true : false;
- if ($cfg->data['lang'] != $newLng) {
- $cfg->data['lang'] = $newLng;
- $lang = $newLng;
- }
- if ($cfg->data['error_reporting'] != $erp) {
- $cfg->data['error_reporting'] = $erp;
- $report_errors = $erp;
- }
- if ($cfg->data['show_hidden'] != $shf) {
- $cfg->data['show_hidden'] = $shf;
- $show_hidden_files = $shf;
- }
- if ($cfg->data['show_hidden'] != $shf) {
- $cfg->data['show_hidden'] = $shf;
- $show_hidden_files = $shf;
- }
- if ($cfg->data['hide_Cols'] != $hco) {
- $cfg->data['hide_Cols'] = $hco;
- $hide_Cols = $hco;
- }
- if ($cfg->data['calc_folder'] != $caf) {
- $cfg->data['calc_folder'] = $caf;
- $calc_folder = $caf;
- }
- $cfg->save();
- echo true;
- }
- // new password hash
- if (isset($_POST['type']) && $_POST['type'] == "pwdhash") {
- $res = isset($_POST['inputPassword2']) && !empty($_POST['inputPassword2']) ? password_hash($_POST['inputPassword2'], PASSWORD_DEFAULT) : '';
- echo $res;
- }
- //upload using url
- if(isset($_POST['type']) && $_POST['type'] == "upload" && !empty($_REQUEST["uploadurl"])) {
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- $url = !empty($_REQUEST["uploadurl"]) && preg_match("|^http(s)?://.+$|", stripslashes($_REQUEST["uploadurl"])) ? stripslashes($_REQUEST["uploadurl"]) : null;
- $use_curl = false;
- $temp_file = tempnam(sys_get_temp_dir(), "upload-");
- $fileinfo = new stdClass();
- $fileinfo->name = trim(basename($url), ".\x00..\x20");
- $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false;
- $ext = strtolower(pathinfo($fileinfo->name, PATHINFO_EXTENSION));
- $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
- function event_callback ($message) {
- global $callback;
- echo json_encode($message);
- }
- function get_file_path () {
- global $path, $fileinfo, $temp_file;
- return $path."/".basename($fileinfo->name);
- }
- $err = false;
- if(!$isFileAllowed) {
- $err = array("message" => "File extension is not allowed");
- event_callback(array("fail" => $err));
- exit();
- }
- if (!$url) {
- $success = false;
- } else if ($use_curl) {
- @$fp = fopen($temp_file, "w");
- @$ch = curl_init($url);
- curl_setopt($ch, CURLOPT_NOPROGRESS, false );
- curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
- curl_setopt($ch, CURLOPT_FILE, $fp);
- @$success = curl_exec($ch);
- $curl_info = curl_getinfo($ch);
- if (!$success) {
- $err = array("message" => curl_error($ch));
- }
- @curl_close($ch);
- fclose($fp);
- $fileinfo->size = $curl_info["size_download"];
- $fileinfo->type = $curl_info["content_type"];
- } else {
- $ctx = stream_context_create();
- @$success = copy($url, $temp_file, $ctx);
- if (!$success) {
- $err = error_get_last();
- }
- }
- if ($success) {
- $success = rename($temp_file, get_file_path());
- }
- if ($success) {
- event_callback(array("done" => $fileinfo));
- } else {
- unlink($temp_file);
- if (!$err) {
- $err = array("message" => "Invalid url parameter");
- }
- event_callback(array("fail" => $err));
- }
- }
- exit();
- }
- // Delete file / folder
- if (isset($_GET['del']) && !FM_READONLY) {
- $del = str_replace( '/', '', fm_clean_path( $_GET['del'] ) );
- if ($del != '' && $del != '..' && $del != '.') {
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- $is_dir = is_dir($path . '/' . $del);
- if (fm_rdelete($path . '/' . $del)) {
- $msg = $is_dir ? 'Folder <b>%s</b> deleted' : 'File <b>%s</b> deleted';
- fm_set_msg(sprintf($msg, fm_enc($del)));
- } else {
- $msg = $is_dir ? 'Folder <b>%s</b> not deleted' : 'File <b>%s</b> not deleted';
- fm_set_msg(sprintf($msg, fm_enc($del)), 'error');
- }
- } else {
- fm_set_msg('Invalid file or folder name', 'error');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Create folder
- if (isset($_GET['new']) && isset($_GET['type']) && !FM_READONLY) {
- $type = $_GET['type'];
- $new = str_replace( '/', '', fm_clean_path( strip_tags( $_GET['new'] ) ) );
- if (fm_isvalid_filename($new) && $new != '' && $new != '..' && $new != '.') {
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- if ($_GET['type'] == "file") {
- if (!file_exists($path . '/' . $new)) {
- if(fm_is_valid_ext($new)) {
- @fopen($path . '/' . $new, 'w') or die('Cannot open file: ' . $new);
- fm_set_msg(sprintf(lng('File').' <b>%s</b> '.lng('Created'), fm_enc($new)));
- } else {
- fm_set_msg('File extension is not allowed', 'error');
- }
- } else {
- fm_set_msg(sprintf('File <b>%s</b> already exists', fm_enc($new)), 'alert');
- }
- } else {
- if (fm_mkdir($path . '/' . $new, false) === true) {
- fm_set_msg(sprintf(lng('Folder').' <b>%s</b> '.lng('Created'), $new));
- } elseif (fm_mkdir($path . '/' . $new, false) === $path . '/' . $new) {
- fm_set_msg(sprintf('Folder <b>%s</b> already exists', fm_enc($new)), 'alert');
- } else {
- fm_set_msg(sprintf('Folder <b>%s</b> not created', fm_enc($new)), 'error');
- }
- }
- } else {
- fm_set_msg('Invalid characters in file or folder name', 'error');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Copy folder / file
- if (isset($_GET['copy'], $_GET['finish']) && !FM_READONLY) {
- // from
- $copy = $_GET['copy'];
- $copy = fm_clean_path($copy);
- // empty path
- if ($copy == '') {
- fm_set_msg('Source path not defined', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // abs path from
- $from = FM_ROOT_PATH . '/' . $copy;
- // abs path to
- $dest = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $dest .= '/' . FM_PATH;
- }
- $dest .= '/' . basename($from);
- // move?
- $move = isset($_GET['move']);
- // copy/move/duplicate
- if ($from != $dest) {
- $msg_from = trim(FM_PATH . '/' . basename($from), '/');
- if ($move) { // Move and to != from so just perform move
- $rename = fm_rename($from, $dest);
- if ($rename) {
- fm_set_msg(sprintf('Moved from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)));
- } elseif ($rename === null) {
- fm_set_msg('File or folder with this path already exists', 'alert');
- } else {
- fm_set_msg(sprintf('Error while moving from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)), 'error');
- }
- } else { // Not move and to != from so copy with original name
- if (fm_rcopy($from, $dest)) {
- fm_set_msg(sprintf('Copied from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)));
- } else {
- fm_set_msg(sprintf('Error while copying from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)), 'error');
- }
- }
- } else {
- if (!$move){ //Not move and to = from so duplicate
- $msg_from = trim(FM_PATH . '/' . basename($from), '/');
- $fn_parts = pathinfo($from);
- $extension_suffix = '';
- if(!is_dir($from)){
- $extension_suffix = '.'.$fn_parts['extension'];
- }
- //Create new name for duplicate
- $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-'.date('YmdHis').$extension_suffix;
- $loop_count = 0;
- $max_loop = 1000;
- // Check if a file with the duplicate name already exists, if so, make new name (edge case...)
- while(file_exists($fn_duplicate) & $loop_count < $max_loop){
- $fn_parts = pathinfo($fn_duplicate);
- $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-copy'.$extension_suffix;
- $loop_count++;
- }
- if (fm_rcopy($from, $fn_duplicate, False)) {
- fm_set_msg(sprintf('Copyied from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($fn_duplicate)));
- } else {
- fm_set_msg(sprintf('Error while copying from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($fn_duplicate)), 'error');
- }
- }
- else{
- fm_set_msg('Paths must be not equal', 'alert');
- }
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Mass copy files/ folders
- if (isset($_POST['file'], $_POST['copy_to'], $_POST['finish']) && !FM_READONLY) {
- // from
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- // to
- $copy_to_path = FM_ROOT_PATH;
- $copy_to = fm_clean_path($_POST['copy_to']);
- if ($copy_to != '') {
- $copy_to_path .= '/' . $copy_to;
- }
- if ($path == $copy_to_path) {
- fm_set_msg('Paths must be not equal', 'alert');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- if (!is_dir($copy_to_path)) {
- if (!fm_mkdir($copy_to_path, true)) {
- fm_set_msg('Unable to create destination folder', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- }
- // move?
- $move = isset($_POST['move']);
- // copy/move
- $errors = 0;
- $files = $_POST['file'];
- if (is_array($files) && count($files)) {
- foreach ($files as $f) {
- if ($f != '') {
- // abs path from
- $from = $path . '/' . $f;
- // abs path to
- $dest = $copy_to_path . '/' . $f;
- // do
- if ($move) {
- $rename = fm_rename($from, $dest);
- if ($rename === false) {
- $errors++;
- }
- } else {
- if (!fm_rcopy($from, $dest)) {
- $errors++;
- }
- }
- }
- }
- if ($errors == 0) {
- $msg = $move ? 'Selected files and folders moved' : 'Selected files and folders copied';
- fm_set_msg($msg);
- } else {
- $msg = $move ? 'Error while moving items' : 'Error while copying items';
- fm_set_msg($msg, 'error');
- }
- } else {
- fm_set_msg('Nothing selected', 'alert');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Rename
- if (isset($_GET['ren'], $_GET['to']) && !FM_READONLY) {
- // old name
- $old = $_GET['ren'];
- $old = fm_clean_path($old);
- $old = str_replace('/', '', $old);
- // new name
- $new = $_GET['to'];
- $new = fm_clean_path(strip_tags($new));
- $new = str_replace('/', '', $new);
- // path
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- // rename
- if (fm_isvalid_filename($new) && $old != '' && $new != '') {
- if (fm_rename($path . '/' . $old, $path . '/' . $new)) {
- fm_set_msg(sprintf('Renamed from <b>%s</b> to <b>%s</b>', fm_enc($old), fm_enc($new)));
- } else {
- fm_set_msg(sprintf('Error while renaming from <b>%s</b> to <b>%s</b>', fm_enc($old), fm_enc($new)), 'error');
- }
- } else {
- fm_set_msg('Invalid characters in file name', 'error');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Download
- if (isset($_GET['dl'])) {
- $dl = $_GET['dl'];
- $dl = fm_clean_path($dl);
- $dl = str_replace('/', '', $dl);
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- if ($dl != '' && is_file($path . '/' . $dl)) {
- fm_download_file($path . '/' . $dl, $dl, 1024);
- exit;
- } else {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- }
- // Upload
- try{
- if (!empty($_FILES) && !FM_READONLY) {
- $override_file_name = false;
- $f = $_FILES;
- $path = FM_ROOT_PATH;
- $ds = DIRECTORY_SEPARATOR;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- $errors = 0;
- $uploads = 0;
- $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false;
- $response = array (
- 'status' => 'error',
- 'info' => 'Oops! Try again'
- );
- $filename = $f['file']['name'];
- $tmp_name = $f['file']['tmp_name'];
- $ext = strtolower(pathinfo($filename, PATHINFO_EXTENSION));
- $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
- $targetPath = $path . $ds;
- if ( is_writable($targetPath) ) {
- $fullPath = $path . '/' . $_REQUEST['fullpath'];
- $folder = substr($fullPath, 0, strrpos($fullPath, "/"));
- if(file_exists ($fullPath)){
- if(!$override_file_name) {
- /**
- * 修改名称
- */
- // $ext_1 = $ext ? '.'.$ext : '';
- // $fullPath = str_replace($ext_1, '', $fullPath) .'_'. date('ymdHis'). $ext_1;
- /**
- * 移动到回收站
- */
- $removePath = str_replace(DOCUMENT_ROOT,"",$fullPath);
- fm_rdelete(DOCUMENT_ROOT."/".$removePath);
- }
- }
- if (!is_dir($folder)) {
- $old = umask(0);
- mkdir($folder, 0777, true);
- umask($old);
- }
- if (empty($f['file']['error']) && !empty($tmp_name) && $tmp_name != 'none' && $isFileAllowed) {
- if (move_uploaded_file($tmp_name, $fullPath)) {
- // Be sure that the file has been uploaded
- if ( file_exists($fullPath) ) {
- $response = array (
- 'status' => 'success',
- 'info' => "file upload successful"
- );
- } else {
- $response = array (
- 'status' => 'error',
- 'info' => 'Couldn\'t upload the requested file.'
- );
- }
- } else {
- $response = array (
- 'status' => 'error',
- 'info' => "Error while uploading files. Uploaded files $uploads",
- );
- }
- }
- $response = [$f, $tmp_name, $isFileAllowed];
- } else {
- $response = array (
- 'status' => 'error',
- 'info' => 'The specified folder for upload isn\'t writeable.'
- );
- }
- // Return the response
- echo json_encode($response);
- exit();
- }
- }catch (\throwable $e){
- $response = array (
- 'status' => $e->getCode(),
- 'info' => $e->getMessage()
- );
- echo json_encode($response);
- exit;
- }
- // Mass deleting
- if (isset($_POST['group'], $_POST['delete']) && !FM_READONLY) {
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- $errors = 0;
- $files = $_POST['file'];
- if (is_array($files) && count($files)) {
- foreach ($files as $f) {
- if ($f != '') {
- $new_path = $path . '/' . $f;
- if (!fm_rdelete($new_path)) {
- $errors++;
- }
- }
- }
- if ($errors == 0) {
- fm_set_msg('Selected files and folder deleted');
- } else {
- fm_set_msg('Error while deleting items', 'error');
- }
- } else {
- fm_set_msg('Nothing selected', 'alert');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Pack files
- if (isset($_POST['group']) && (isset($_POST['zip']) || isset($_POST['tar'])) && !FM_READONLY) {
- $path = FM_ROOT_PATH;
- $ext = 'zip';
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- //set pack type
- $ext = isset($_POST['tar']) ? 'tar' : 'zip';
- if (($ext == "zip" && !class_exists('ZipArchive')) || ($ext == "tar" && !class_exists('PharData'))) {
- fm_set_msg('Operations with archives are not available', 'error');
- fm_redirect(FM_SELF_URL . 'fm_usr='.$_GET['fm_usr'].'&=' . urlencode(FM_PATH));
- }
- $files = $_POST['file'];
- if (!empty($files)) {
- chdir($path);
- if (count($files) == 1) {
- $one_file = reset($files);
- $one_file = basename($one_file);
- $zipname = $one_file . '_' . date('ymd_His') . '.'.$ext;
- } else {
- $zipname = 'archive_' . date('ymd_His') . '.'.$ext;
- }
- if($ext == 'zip') {
- $zipper = new FM_Zipper();
- $res = $zipper->create($zipname, $files);
- } elseif ($ext == 'tar') {
- $tar = new FM_Zipper_Tar();
- $res = $tar->create($zipname, $files);
- }
- if ($res) {
- fm_set_msg(sprintf('Archive <b>%s</b> created', fm_enc($zipname)));
- } else {
- fm_set_msg('Archive not created', 'error');
- }
- } else {
- fm_set_msg('Nothing selected', 'alert');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Unpack
- if (isset($_GET['unzip']) && !FM_READONLY) {
- $unzip = $_GET['unzip'];
- $unzip = fm_clean_path($unzip);
- $unzip = str_replace('/', '', $unzip);
- $isValid = false;
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- if ($unzip != '' && is_file($path . '/' . $unzip)) {
- $zip_path = $path . '/' . $unzip;
- $ext = pathinfo($zip_path, PATHINFO_EXTENSION);
- $isValid = true;
- } else {
- fm_set_msg('File not found', 'error');
- }
- if (($ext == "zip" && !class_exists('ZipArchive')) || ($ext == "tar" && !class_exists('PharData'))) {
- fm_set_msg('Operations with archives are not available', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- if ($isValid) {
- //to folder
- $tofolder = '';
- if (isset($_GET['tofolder'])) {
- $tofolder = pathinfo($zip_path, PATHINFO_FILENAME);
- if (fm_mkdir($path . '/' . $tofolder, true)) {
- $path .= '/' . $tofolder;
- }
- }
- if($ext == "zip") {
- $zipper = new FM_Zipper();
- $res = $zipper->unzip($zip_path, $path);
- } elseif ($ext == "tar") {
- try {
- $gzipper = new PharData($zip_path);
- if (@$gzipper->extractTo($path,null, true)) {
- $res = true;
- } else {
- $res = false;
- }
- } catch (Exception $e) {
- //TODO:: need to handle the error
- $res = true;
- }
- }
- if ($res) {
- fm_set_msg('Archive unpacked');
- } else {
- fm_set_msg('Archive not unpacked', 'error');
- }
- } else {
- fm_set_msg('File not found', 'error');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- // Change Perms (not for Windows)
- if (isset($_POST['chmod']) && !FM_READONLY && !FM_IS_WIN) {
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- $file = $_POST['chmod'];
- $file = fm_clean_path($file);
- $file = str_replace('/', '', $file);
- if ($file == '' || (!is_file($path . '/' . $file) && !is_dir($path . '/' . $file))) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- $mode = 0;
- if (!empty($_POST['ur'])) {
- $mode |= 0400;
- }
- if (!empty($_POST['uw'])) {
- $mode |= 0200;
- }
- if (!empty($_POST['ux'])) {
- $mode |= 0100;
- }
- if (!empty($_POST['gr'])) {
- $mode |= 0040;
- }
- if (!empty($_POST['gw'])) {
- $mode |= 0020;
- }
- if (!empty($_POST['gx'])) {
- $mode |= 0010;
- }
- if (!empty($_POST['or'])) {
- $mode |= 0004;
- }
- if (!empty($_POST['ow'])) {
- $mode |= 0002;
- }
- if (!empty($_POST['ox'])) {
- $mode |= 0001;
- }
- if (@chmod($path . '/' . $file, $mode)) {
- fm_set_msg('Permissions changed');
- } else {
- fm_set_msg('Permissions not changed', 'error');
- }
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- /*************************** /ACTIONS ***************************/
- // get current path
- $path = FM_ROOT_PATH;
- if (FM_PATH != '') {
- $path .= '/' . FM_PATH;
- }
- // check path
- if (!is_dir($path)) {
- fm_redirect(FM_SELF_URL . '?fm_usr='.$_GET['fm_usr'].'&p=');
- }
- // get parent folder
- $parent = fm_get_parent_path(FM_PATH);
- $objects = is_readable($path) ? scandir($path) : array();
- $folders = array();
- $files = array();
- $current_path = array_slice(explode("/",$path), -1)[0];
- if (is_array($objects) && fm_is_exclude_items($current_path)) {
- foreach ($objects as $file) {
- if ($file == '.' || $file == '..') {
- continue;
- }
- if (!FM_SHOW_HIDDEN && substr($file, 0, 1) === '.') {
- continue;
- }
- $new_path = $path . '/' . $file;
- if (@is_file($new_path) && fm_is_exclude_items($file)) {
- $files[] = $file;
- } elseif (@is_dir($new_path) && $file != '.' && $file != '..' && fm_is_exclude_items($file)) {
- $folders[] = $file;
- }
- }
- }
- if (!empty($files)) {
- natcasesort($files);
- }
- if (!empty($folders)) {
- natcasesort($folders);
- }
- // upload form
- if (isset($_GET['upload']) && !FM_READONLY) {
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- //get the allowed file extensions
- function getUploadExt() {
- $extArr = explode(',', FM_UPLOAD_EXTENSION);
- if(FM_UPLOAD_EXTENSION && $extArr) {
- array_walk($extArr, function(&$x) {$x = ".$x";});
- return implode(',', $extArr);
- }
- return '';
- }
- ?>
- <link href="/public/filemanager/js/dropzone.min.css" rel="stylesheet">
- <div class="path">
- <div class="card mb-2 fm-upload-wrapper <?php echo fm_get_theme(); ?>">
- <div class="card-header">
- <ul class="nav nav-tabs card-header-tabs">
- <li class="nav-item">
- <a class="nav-link active" href="#fileUploader" data-target="#fileUploader"><i class="fa fa-arrow-circle-o-up"></i> <?php echo lng('UploadingFiles') ?></a>
- </li>
- <li class="nav-item">
- <a class="nav-link" href="#urlUploader" class="js-url-upload" data-target="#urlUploader"><i class="fa fa-link"></i> Upload from URL</a>
- </li>
- </ul>
- </div>
- <div class="card-body">
- <p class="card-text">
- <a href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-chevron-circle-left go-back"></i> <?php echo lng('Back')?></a>
- <?php echo lng('DestinationFolder') ?>: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?>
- </p>
- <form action="<?php echo htmlspecialchars(FM_SELF_URL) . '?fm_usr='. $_GET['fm_usr'].'&p=' . fm_enc(FM_PATH) ?>" class="dropzone card-tabs-container" id="fileUploader" enctype="multipart/form-data">
- <input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
- <input type="hidden" name="fullpath" id="fullpath" value="<?php echo fm_enc(FM_PATH) ?>">
- <div class="fallback">
- <input name="file" type="file" multiple/>
- </div>
- </form>
- <div class="upload-url-wrapper card-tabs-container hidden" id="urlUploader">
- <form id="js-form-url-upload" class="form-inline" onsubmit="return upload_from_url(this);" method="POST" action="">
- <input type="hidden" name="type" value="upload" aria-label="hidden" aria-hidden="true">
- <input type="url" placeholder="URL" name="uploadurl" required class="form-control" style="width: 80%">
- <button type="submit" class="btn btn-primary ml-3"><?php echo lng('Upload') ?></button>
- <div class="lds-facebook"><div></div><div></div><div></div></div>
- </form>
- <div id="js-url-upload__list" class="col-9 mt-3"></div>
- </div>
- </div>
- </div>
- </div>
- <script src="/public/filemanager/js/dropzone.min.js"></script>
- <script>
- Dropzone.options.fileUploader = {
- timeout: 120000,
- maxFilesize: <?php echo MAX_UPLOAD_SIZE; ?>,
- acceptedFiles : "<?php echo getUploadExt() ?>",
- init: function () {
- this.on("addedfile", function(file) {
- if(file.name.indexOf(".png") != -1 || file.name.indexOf(".jpg") != -1 || file.name.indexOf(".PNG") != -1 || file.name.indexOf(".JPG") != -1){
- var mbS = (file.size/1024).toFixed(2);
- // alert('上传图片注意大小=》该文件大小 ('+mbS+')KB');
- }
- }).on("sending", function (file, xhr, formData) {
- let _path = (file.fullPath) ? file.fullPath : file.name;
- document.getElementById("fullpath").value = _path;
- xhr.ontimeout = (function() {
- alert('Error: Server Timeout');
- });
- }).on("success", function (res) {
- let _response = JSON.parse(res.xhr.response);
- if(_response.status == "error") {
- alert(_response.info);
- }
- }).on("error", function(file, response) {
- alert(response);
- });
- }
- }
- </script>
- <?php
- fm_show_footer();
- exit;
- }
- // copy form POST
- if (isset($_POST['copy']) && !FM_READONLY) {
- $copy_files = isset($_POST['file']) ? $_POST['file'] : null;
- if (!is_array($copy_files) || empty($copy_files)) {
- fm_set_msg('Nothing selected', 'alert');
- fm_redirect(FM_SELF_URL . '?fm_usr='. $_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- ?>
- <div class="path">
- <div class="card <?php echo fm_get_theme(); ?>">
- <div class="card-header">
- <h6><?php echo lng('Copying') ?></h6>
- </div>
- <div class="card-body">
- <form action="" method="post">
- <input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
- <input type="hidden" name="finish" value="1">
- <?php
- foreach ($copy_files as $cf) {
- echo '<input type="hidden" name="file[]" value="' . fm_enc($cf) . '">' . PHP_EOL;
- }
- ?>
- <p class="break-word"><?php echo lng('Files') ?>: <b><?php echo implode('</b>, <b>', $copy_files) ?></b></p>
- <p class="break-word"><?php echo lng('SourceFolder') ?>: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?><br>
- <label for="inp_copy_to"><?php echo lng('DestinationFolder') ?>:</label>
- <?php echo FM_ROOT_PATH ?>/<input type="text" name="copy_to" id="inp_copy_to" value="<?php echo fm_enc(FM_PATH) ?>">
- </p>
- <p class="custom-checkbox custom-control"><input type="checkbox" name="move" value="1" id="js-move-files" class="custom-control-input"><label for="js-move-files" class="custom-control-label" style="vertical-align: sub"> <?php echo lng('Move') ?></label></p>
- <p>
- <button type="submit" class="btn btn-success"><i class="fa fa-check-circle"></i> <?php echo lng('Copy') ?></button>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>" class="btn btn-outline-primary"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></a></b>
- </p>
- </form>
- </div>
- </div>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- // copy form
- if (isset($_GET['copy']) && !isset($_GET['finish']) && !FM_READONLY) {
- $copy = $_GET['copy'];
- $copy = fm_clean_path($copy);
- if ($copy == '' || !file_exists(FM_ROOT_PATH . '/' . $copy)) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='. $_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- ?>
- <div class="path">
- <p><b>Copying</b></p>
- <p class="break-word">
- Source path: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . $copy)) ?><br>
- Destination folder: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?>
- </p>
- <p>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode($copy) ?>&finish=1"><i class="fa fa-check-circle"></i> Copy</a></b>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode($copy) ?>&finish=1&move=1"><i class="fa fa-check-circle"></i> Move</a></b>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>"><i class="fa fa-times-circle"></i> Cancel</a></b>
- </p>
- <p><i>Select folder</i></p>
- <ul class="folders break-word">
- <?php
- if ($parent !== false) {
- ?>
- <li><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode($parent) ?>&copy=<?php echo urlencode($copy) ?>"><i class="fa fa-chevron-circle-left"></i> ..</a></li>
- <?php
- }
- foreach ($folders as $f) {
- ?>
- <li>
- <a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>&copy=<?php echo urlencode($copy) ?>"><i class="fa fa-folder-o"></i> <?php echo fm_convert_win($f) ?></a></li>
- <?php
- }
- ?>
- </ul>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- if (isset($_GET['settings']) && !FM_READONLY) {
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- global $cfg, $lang, $lang_list;
- ?>
- <div class="col-md-8 offset-md-2 pt-3">
- <div class="card mb-2 <?php echo fm_get_theme(); ?>">
- <h6 class="card-header">
- <i class="fa fa-cog"></i> <?php echo lng('Settings') ?>
- <a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-window-close"></i> <?php echo lng('Cancel')?></a>
- </h6>
- <div class="card-body">
- <form id="js-settings-form" action="" method="post" data-type="ajax" onsubmit="return save_settings(this)">
- <input type="hidden" name="type" value="settings" aria-label="hidden" aria-hidden="true">
- <div class="form-group row">
- <label for="js-language" class="col-sm-3 col-form-label"><?php echo lng('Language') ?></label>
- <div class="col-sm-5">
- <select class="form-control" id="js-language" name="js-language">
- <?php
- function getSelected($l) {
- global $lang;
- return ($lang == $l) ? 'selected' : '';
- }
- foreach ($lang_list as $k => $v) {
- echo "<option value='$k' ".getSelected($k).">$v</option>";
- }
- ?>
- </select>
- </div>
- </div>
- <?php
- //get ON/OFF and active class
- function getChecked($conf, $val, $txt) {
- if($conf== 1 && $val ==1) {
- return $txt;
- } else if($conf == '' && $val == '') {
- return $txt;
- } else {
- return '';
- }
- }
- ?>
- <div class="form-group row">
- <label for="js-err-rpt-1" class="col-sm-3 col-form-label"><?php echo lng('ErrorReporting') ?></label>
- <div class="col-sm-9">
- <div class="btn-group btn-group-toggle" data-toggle="buttons">
- <label class="btn btn-secondary <?php echo getChecked($report_errors, 1, 'active') ?>">
- <input type="radio" name="js-error-report" id="js-err-rpt-1" autocomplete="off" value="true" <?php echo getChecked($report_errors, 1, 'checked') ?> > ON
- </label>
- <label class="btn btn-secondary <?php echo getChecked($report_errors, '', 'active') ?>">
- <input type="radio" name="js-error-report" id="js-err-rpt-0" autocomplete="off" value="false" <?php echo getChecked($report_errors, '', 'checked') ?> > OFF
- </label>
- </div>
- </div>
- </div>
- <div class="form-group row">
- <label for="js-hdn-1" class="col-sm-3 col-form-label"><?php echo lng('ShowHiddenFiles') ?></label>
- <div class="col-sm-9">
- <div class="btn-group btn-group-toggle" data-toggle="buttons">
- <label class="btn btn-secondary <?php echo getChecked($show_hidden_files, 1, 'active') ?>">
- <input type="radio" name="js-show-hidden" id="js-hdn-1" autocomplete="off" value="true" <?php echo getChecked($show_hidden_files, 1, 'checked') ?> > ON
- </label>
- <label class="btn btn-secondary <?php echo getChecked($show_hidden_files, '', 'active') ?>">
- <input type="radio" name="js-show-hidden" id="js-hdn-0" autocomplete="off" value="false" <?php echo getChecked($show_hidden_files, '', 'checked') ?> > OFF
- </label>
- </div>
- </div>
- </div>
- <div class="form-group row">
- <label for="js-hid-1" class="col-sm-3 col-form-label"><?php echo lng('HideColumns') ?></label>
- <div class="col-sm-9">
- <div class="btn-group btn-group-toggle" data-toggle="buttons">
- <label class="btn btn-secondary <?php echo getChecked($hide_Cols, 1, 'active') ?>">
- <input type="radio" name="js-hide-cols" id="js-hid-1" autocomplete="off" value="true" <?php echo getChecked($hide_Cols, 1, 'checked') ?> > ON
- </label>
- <label class="btn btn-secondary <?php echo getChecked($hide_Cols, '', 'active') ?>">
- <input type="radio" name="js-hide-cols" id="js-hid-0" autocomplete="off" value="false" <?php echo getChecked($hide_Cols, '', 'checked') ?> > OFF
- </label>
- </div>
- </div>
- </div>
- <div class="form-group row">
- <label for="js-dir-1" class="col-sm-3 col-form-label"><?php echo lng('CalculateFolderSize') ?></label>
- <div class="col-sm-9">
- <div class="btn-group btn-group-toggle" data-toggle="buttons">
- <label class="btn btn-secondary <?php echo getChecked($calc_folder, 1, 'active') ?>">
- <input type="radio" name="js-calc-folder" id="js-dir-1" autocomplete="off" value="true" <?php echo getChecked($calc_folder, 1, 'checked') ?> > ON
- </label>
- <label class="btn btn-secondary <?php echo getChecked($calc_folder, '', 'active') ?>">
- <input type="radio" name="js-calc-folder" id="js-dir-0" autocomplete="off" value="false" <?php echo getChecked($calc_folder, '', 'checked') ?> > OFF
- </label>
- </div>
- </div>
- </div>
- <div class="form-group row">
- <div class="col-sm-10">
- <button type="submit" class="btn btn-success"> <i class="fa fa-check-circle"></i> <?php echo lng('Save'); ?></button>
- </div>
- </div>
- </form>
- </div>
- </div>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- if (isset($_GET['help'])) {
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- global $cfg, $lang;
- ?>
- <div class="col-md-8 offset-md-2 pt-3">
- <div class="card mb-2 <?php echo fm_get_theme(); ?>">
- <h6 class="card-header">
- <i class="fa fa-exclamation-circle"></i> <?php echo lng('Help') ?>
- <a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-window-close"></i> <?php echo lng('Cancel')?></a>
- </h6>
- <div class="card-body">
- <div class="row">
- <div class="col-xs-12 col-sm-6">
- <p><h3><a href="https://github.com/prasathmani/tinyfilemanager" target="_blank" class="app-v-title"> Tiny File Manager <?php echo VERSION; ?></a></h3></p>
- <p>Author: Prasath Mani</p>
- <p>Mail Us: <a href="mailto:ccpprogrammers@gmail.com">ccpprogrammers[at]gmail.com</a> </p>
- </div>
- <div class="col-xs-12 col-sm-6">
- <div class="card">
- <ul class="list-group list-group-flush">
- <li class="list-group-item"><a href="https://github.com/prasathmani/tinyfilemanager/wiki" target="_blank"><i class="fa fa-question-circle"></i> <?php echo lng('Help Documents') ?> </a> </li>
- <li class="list-group-item"><a href="https://github.com/prasathmani/tinyfilemanager/issues" target="_blank"><i class="fa fa-bug"></i> <?php echo lng('Report Issue') ?></a></li>
- <li class="list-group-item"><a href="javascript:latest_release_info('<?php echo VERSION; ?>');"><i class="fa fa-link"> </i> <?php echo lng('Check Latest Version') ?></a></li>
- <?php if(!FM_READONLY) { ?>
- <li class="list-group-item"><a href="javascript:show_new_pwd();"><i class="fa fa-lock"></i> <?php echo lng('Generate new password hash') ?></a></li>
- <?php } ?>
- </ul>
- </div>
- </div>
- </div>
- <div class="row js-new-pwd hidden mt-2">
- <div class="col-12">
- <form class="form-inline" onsubmit="return new_password_hash(this)" method="POST" action="">
- <input type="hidden" name="type" value="pwdhash" aria-label="hidden" aria-hidden="true">
- <div class="form-group mb-2">
- <label for="staticEmail2"><?php echo lng('Generate new password hash') ?></label>
- </div>
- <div class="form-group mx-sm-3 mb-2">
- <label for="inputPassword2" class="sr-only"><?php echo lng('Password') ?></label>
- <input type="text" class="form-control btn-sm" id="inputPassword2" name="inputPassword2" placeholder="Password" required>
- </div>
- <button type="submit" class="btn btn-success btn-sm mb-2"><?php echo lng('Generate') ?></button>
- </form>
- <textarea class="form-control" rows="2" readonly id="js-pwd-result"></textarea>
- </div>
- </div>
- </div>
- </div>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- // file viewer
- if (isset($_GET['view'])) {
- $file = $_GET['view'];
- $quickView = (isset($_GET['quickView']) && $_GET['quickView'] == 1) ? true : false;
- $file = fm_clean_path($file, false);
- $file = str_replace('/', '', $file);
- if ($file == '' || !is_file($path . '/' . $file) || in_array($file, $GLOBALS['exclude_items'])) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='. $_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- if(!$quickView) {
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- }
- $file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file);
- $file_path = $path . '/' . $file;
- $ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION));
- $mime_type = fm_get_mime_type($file_path);
- $filesize_raw = fm_get_size($file_path);
- $filesize = fm_get_filesize($filesize_raw);
- $is_zip = false;
- $is_gzip = false;
- $is_image = false;
- $is_audio = false;
- $is_video = false;
- $is_text = false;
- $is_onlineViewer = false;
- $view_title = 'File';
- $filenames = false; // for zip
- $content = ''; // for text
- $online_viewer = strtolower(FM_DOC_VIEWER);
- if($online_viewer && $online_viewer !== 'false' && in_array($ext, fm_get_onlineViewer_exts())){
- $is_onlineViewer = true;
- }
- elseif ($ext == 'zip' || $ext == 'tar') {
- $is_zip = true;
- $view_title = 'Archive';
- $filenames = fm_get_zif_info($file_path, $ext);
- } elseif (in_array($ext, fm_get_image_exts())) {
- $is_image = true;
- $view_title = 'Image';
- } elseif (in_array($ext, fm_get_audio_exts())) {
- $is_audio = true;
- $view_title = 'Audio';
- } elseif (in_array($ext, fm_get_video_exts())) {
- $is_video = true;
- $view_title = 'Video';
- } elseif (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) {
- $is_text = true;
- $content = file_get_contents($file_path);
- }
- ?>
- <div class="row">
- <div class="col-12">
- <?php if(!$quickView) { ?>
- <p class="break-word"><b><?php echo $view_title ?> "<?php echo fm_enc(fm_convert_win($file)) ?>"</b></p>
- <p class="break-word">
- Full path: <?php echo fm_enc(fm_convert_win($file_path)) ?><br>
- File size: <?php echo ($filesize_raw <= 1000) ? "$filesize_raw bytes" : $filesize; ?><br>
- MIME-type: <?php echo $mime_type ?><br>
- <?php
- // ZIP info
- if (($is_zip || $is_gzip) && $filenames !== false) {
- $total_files = 0;
- $total_comp = 0;
- $total_uncomp = 0;
- foreach ($filenames as $fn) {
- if (!$fn['folder']) {
- $total_files++;
- }
- $total_comp += $fn['compressed_size'];
- $total_uncomp += $fn['filesize'];
- }
- ?>
- Files in archive: <?php echo $total_files ?><br>
- Total size: <?php echo fm_get_filesize($total_uncomp) ?><br>
- Size in archive: <?php echo fm_get_filesize($total_comp) ?><br>
- Compression: <?php echo round(($total_comp / $total_uncomp) * 100) ?>%<br>
- <?php
- }
- // Image info
- if ($is_image) {
- $image_size = getimagesize($file_path);
- echo 'Image sizes: ' . (isset($image_size[0]) ? $image_size[0] : '0') . ' x ' . (isset($image_size[1]) ? $image_size[1] : '0') . '<br>';
- }
- // Text info
- if ($is_text) {
- $is_utf8 = fm_is_utf8($content);
- if (function_exists('iconv')) {
- if (!$is_utf8) {
- $content = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $content);
- }
- }
- echo 'Charset: ' . ($is_utf8 ? 'utf-8' : '8 bit') . '<br>';
- }
- ?>
- </p>
- <p>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>&dl=<?php echo urlencode($file) ?>"><i class="fa fa-cloud-download"></i> <?php echo lng('Download') ?></a></b>
- <b><a href="<?php echo fm_enc($file_url) ?>" target="_blank"><i class="fa fa-external-link-square"></i> <?php echo lng('Open') ?></a></b>
-
- <?php
- // ZIP actions
- if (!FM_READONLY && ($is_zip || $is_gzip) && $filenames !== false) {
- $zip_name = pathinfo($file_path, PATHINFO_FILENAME);
- ?>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>&unzip=<?php echo urlencode($file) ?>"><i class="fa fa-check-circle"></i> <?php echo lng('UnZip') ?></a></b>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>&unzip=<?php echo urlencode($file) ?>&tofolder=1" title="UnZip to <?php echo fm_enc($zip_name) ?>"><i class="fa fa-check-circle"></i>
- <?php echo lng('UnZipToFolder') ?></a></b>
- <?php
- }
- if ($is_text && !FM_READONLY) {
- ?>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>" class="edit-file"><i class="fa fa-pencil-square"></i> <?php echo lng('Edit') ?>
- </a></b>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>&env=ace"
- class="edit-file"><i class="fa fa-pencil-square-o"></i> <?php echo lng('AdvancedEditor') ?>
- </a></b>
- <?php } ?>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>"><i class="fa fa-chevron-circle-left go-back"></i> <?php echo lng('Back') ?></a></b>
- </p>
- <?php
- }
- if($is_onlineViewer) {
- if($online_viewer == 'google') {
- echo '<iframe src="https://docs.google.com/viewer?embedded=true&hl=en&url=' . fm_enc($file_url) . '" frameborder="no" style="width:100%;min-height:460px"></iframe>';
- } else if($online_viewer == 'microsoft') {
- echo '<iframe src="https://view.officeapps.live.com/op/embed.aspx?src=' . fm_enc($file_url) . '" frameborder="no" style="width:100%;min-height:460px"></iframe>';
- }
- } elseif ($is_zip) {
- // ZIP content
- if ($filenames !== false) {
- echo '<code class="maxheight">';
- foreach ($filenames as $fn) {
- if ($fn['folder']) {
- echo '<b>' . fm_enc($fn['name']) . '</b><br>';
- } else {
- echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')<br>';
- }
- }
- echo '</code>';
- } else {
- echo '<p>Error while fetching archive info</p>';
- }
- } elseif ($is_image) {
- // Image content
- if (in_array($ext, array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg'))) {
- echo '<p><img src="' . fm_enc($file_url) . '" alt="" class="preview-img"></p>';
- }
- } elseif ($is_audio) {
- // Audio content
- echo '<p><audio src="' . fm_enc($file_url) . '" controls preload="metadata"></audio></p>';
- } elseif ($is_video) {
- // Video content
- echo '<div class="preview-video"><video src="' . fm_enc($file_url) . '" width="640" height="360" controls preload="metadata"></video></div>';
- } elseif ($is_text) {
- if (FM_USE_HIGHLIGHTJS) {
- // highlight
- $hljs_classes = array(
- 'shtml' => 'xml',
- 'htaccess' => 'apache',
- 'phtml' => 'php',
- 'lock' => 'json',
- 'svg' => 'xml',
- );
- $hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext;
- if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) {
- $hljs_class = 'nohighlight';
- }
- $content = '<pre class="with-hljs" style="height: 100%"><code style="height: 100%" class="' . $hljs_class . '">' . fm_enc($content) . '</code></pre>';
- } elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) {
- // php highlight
- $content = highlight_string($content, true);
- } else {
- $content = '<pre>' . fm_enc($content) . '</pre>';
- }
- echo $content;
- }
- ?>
- </div>
- </div>
- <?php
- if(!$quickView) {
- fm_show_footer();
- }
- exit;
- }
- // file editor
- if (isset($_GET['edit'])) {
- $file = $_GET['edit'];
- $file = fm_clean_path($file, false);
- $file = str_replace('/', '', $file);
- if ($file == '' || !is_file($path . '/' . $file)) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='. $_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- header('X-XSS-Protection:0');
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- $file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file);
- $file_path = $path . '/' . $file;
- // normal editer
- $isNormalEditor = true;
- if (isset($_GET['env'])) {
- if ($_GET['env'] == "ace") {
- $isNormalEditor = false;
- }
- }
- // Save File
- if (isset($_POST['savedata'])) {
- $writedata = $_POST['savedata'];
- $fd = fopen($file_path, "w");
- @fwrite($fd, $writedata);
- fclose($fd);
- fm_set_msg('File Saved Successfully');
- }
- $ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION));
- $mime_type = fm_get_mime_type($file_path);
- $filesize = filesize($file_path);
- $is_text = false;
- $content = ''; // for text
- if (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) {
- $is_text = true;
- $content = file_get_contents($file_path);
- }
- ?>
- <div class="path">
- <div class="row">
- <div class="col-xs-12 col-sm-5 col-lg-6 pt-1">
- <div class="btn-toolbar" role="toolbar">
- <?php if (!$isNormalEditor) { ?>
- <div class="btn-group js-ace-toolbar">
- <button data-cmd="none" data-option="fullscreen" class="btn btn-sm btn-outline-secondary" id="js-ace-fullscreen" title="Fullscreen"><i class="fa fa-expand" title="Fullscreen"></i></button>
- <button data-cmd="find" class="btn btn-sm btn-outline-secondary" id="js-ace-search" title="Search"><i class="fa fa-search" title="Search"></i></button>
- <button data-cmd="undo" class="btn btn-sm btn-outline-secondary" id="js-ace-undo" title="Undo"><i class="fa fa-undo" title="Undo"></i></button>
- <button data-cmd="redo" class="btn btn-sm btn-outline-secondary" id="js-ace-redo" title="Redo"><i class="fa fa-repeat" title="Redo"></i></button>
- <button data-cmd="none" data-option="wrap" class="btn btn-sm btn-outline-secondary" id="js-ace-wordWrap" title="Word Wrap"><i class="fa fa-text-width" title="Word Wrap"></i></button>
- <button data-cmd="none" data-option="help" class="btn btn-sm btn-outline-secondary" id="js-ace-goLine" title="Help"><i class="fa fa-question" title="Help"></i></button>
- <select id="js-ace-mode" data-type="mode" title="Select Document Type" class="btn-outline-secondary border-left-0 d-none d-md-block"><option>-- Select Mode --</option></select>
- <select id="js-ace-theme" data-type="theme" title="Select Theme" class="btn-outline-secondary border-left-0 d-none d-lg-block"><option>-- Select Theme --</option></select>
- <select id="js-ace-fontSize" data-type="fontSize" title="Selct Font Size" class="btn-outline-secondary border-left-0 d-none d-lg-block"><option>-- Select Font Size --</option></select>
- </div>
- <?php } ?>
- </div>
- </div>
- <div class="edit-file-actions col-xs-12 col-sm-7 col-lg-6 text-right pt-1">
- <a title="Back" class="btn btn-sm btn-outline-primary" href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH)) ?>&view=<?php echo urlencode($file) ?>"><i class="fa fa-reply-all"></i> <?php echo lng('Back') ?></a>
- <a title="Backup" class="btn btn-sm btn-outline-primary" href="javascript:void(0);" onclick="backup('<?php echo urlencode(trim(FM_PATH)) ?>','<?php echo urlencode($file) ?>')"><i class="fa fa-database"></i> <?php echo lng('BackUp') ?></a>
- <?php if ($is_text) { ?>
- <?php if ($isNormalEditor) { ?>
- <a title="Advanced" class="btn btn-sm btn-outline-primary" href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>&env=ace"><i class="fa fa-pencil-square-o"></i> <?php echo lng('AdvancedEditor') ?></a>
- <button type="button" class="btn btn-sm btn-outline-primary name="Save" data-url="<?php echo fm_enc($file_url) ?>" onclick="edit_save(this,'nrl')"><i class="fa fa-floppy-o"></i> Save
- </button>
- <?php } else { ?>
- <a title="Plain Editor" class="btn btn-sm btn-outline-primary" href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>"><i class="fa fa-text-height"></i> <?php echo lng('NormalEditor') ?></a>
- <button type="button" class="btn btn-sm btn-outline-primary" name="Save" data-url="<?php echo fm_enc($file_url) ?>" onclick="edit_save(this,'ace')"><i class="fa fa-floppy-o"></i> <?php echo lng('Save') ?>
- </button>
- <?php } ?>
- <?php } ?>
- </div>
- </div>
- <?php
- if ($is_text && $isNormalEditor) {
- echo '<textarea class="mt-2" id="normal-editor" rows="33" cols="120" style="width: 99.5%;">' . htmlspecialchars($content) . '</textarea>';
- } elseif ($is_text) {
- echo '<div id="editor" contenteditable="true">' . htmlspecialchars($content) . '</div>';
- } else {
- fm_set_msg('FILE EXTENSION HAS NOT SUPPORTED', 'error');
- }
- ?>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- // chmod (not for Windows)
- if (isset($_GET['chmod']) && !FM_READONLY && !FM_IS_WIN) {
- $file = $_GET['chmod'];
- $file = fm_clean_path($file);
- $file = str_replace('/', '', $file);
- if ($file == '' || (!is_file($path . '/' . $file) && !is_dir($path . '/' . $file))) {
- fm_set_msg('File not found', 'error');
- fm_redirect(FM_SELF_URL . '?fm_usr='. $_GET['fm_usr'].'&p=' . urlencode(FM_PATH));
- }
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- $file_url = FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file;
- $file_path = $path . '/' . $file;
- $mode = fileperms($path . '/' . $file);
- ?>
- <div class="path">
- <div class="card mb-2 <?php echo fm_get_theme(); ?>">
- <h6 class="card-header">
- <?php echo lng('ChangePermissions') ?>
- </h6>
- <div class="card-body">
- <p class="card-text">
- Full path: <?php echo $file_path ?><br>
- </p>
- <form action="" method="post">
- <input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
- <input type="hidden" name="chmod" value="<?php echo fm_enc($file) ?>">
- <table class="table compact-table <?php echo fm_get_theme(); ?>">
- <tr>
- <td></td>
- <td><b><?php echo lng('Owner') ?></b></td>
- <td><b><?php echo lng('Group') ?></b></td>
- <td><b><?php echo lng('Other') ?></b></td>
- </tr>
- <tr>
- <td style="text-align: right"><b><?php echo lng('Read') ?></b></td>
- <td><label><input type="checkbox" name="ur" value="1"<?php echo ($mode & 00400) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="gr" value="1"<?php echo ($mode & 00040) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="or" value="1"<?php echo ($mode & 00004) ? ' checked' : '' ?>></label></td>
- </tr>
- <tr>
- <td style="text-align: right"><b><?php echo lng('Write') ?></b></td>
- <td><label><input type="checkbox" name="uw" value="1"<?php echo ($mode & 00200) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="gw" value="1"<?php echo ($mode & 00020) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="ow" value="1"<?php echo ($mode & 00002) ? ' checked' : '' ?>></label></td>
- </tr>
- <tr>
- <td style="text-align: right"><b><?php echo lng('Execute') ?></b></td>
- <td><label><input type="checkbox" name="ux" value="1"<?php echo ($mode & 00100) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="gx" value="1"<?php echo ($mode & 00010) ? ' checked' : '' ?>></label></td>
- <td><label><input type="checkbox" name="ox" value="1"<?php echo ($mode & 00001) ? ' checked' : '' ?>></label></td>
- </tr>
- </table>
- <p>
- <button type="submit" class="btn btn-success"><i class="fa fa-check-circle"></i> <?php echo lng('Change') ?></button>
- <b><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode(FM_PATH) ?>" class="btn btn-outline-primary"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></a></b>
- </p>
- </form>
- </div>
- </div>
- </div>
- <?php
- fm_show_footer();
- exit;
- }
- //--- FILEMANAGER MAIN
- fm_show_header(); // HEADER
- fm_show_nav_path(FM_PATH); // current path
- // messages
- fm_show_message();
- $num_files = count($files);
- $num_folders = count($folders);
- $all_files_size = 0;
- $tableTheme = (FM_THEME == "dark") ? "text-white bg-dark table-dark" : "bg-white";
- ?>
- <form action="" method="post" class="pt-3">
- <input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
- <input type="hidden" name="group" value="1">
- <div class="table-responsive">
- <table class="table table-bordered table-hover table-sm <?php echo $tableTheme; ?>" id="main-table">
- <thead class="thead-white">
- <tr>
- <?php if (!FM_READONLY): ?>
- <th style="width:3%" class="custom-checkbox-header">
- <div class="custom-control custom-checkbox">
- <input type="checkbox" class="custom-control-input" id="js-select-all-items" onclick="checkbox_toggle()">
- <label class="custom-control-label" for="js-select-all-items"></label>
- </div>
- </th><?php endif; ?>
- <th><?php echo lng('Name') ?></th>
- <th><?php echo lng('Size') ?></th>
- <th><?php echo lng('Modified') ?></th>
- <?php if (!FM_IS_WIN && !$hide_Cols): ?>
- <th><?php echo lng('Perms') ?></th>
- <th><?php echo lng('Owner') ?></th><?php endif; ?>
- <th><?php echo lng('Actions') ?></th>
- </tr>
- </thead>
- <?php
- // link to parent folder
- if ($parent !== false) {
- ?>
- <tr><?php if (!FM_READONLY): ?>
- <td class="nosort"></td><?php endif; ?>
- <td class="border-0"><a href="?fm_usr=<?php echo $_GET['fm_usr'] ?>&p=<?php echo urlencode($parent) ?>"><i class="fa fa-chevron-circle-left go-back"></i> ..</a></td>
- <td class="border-0"></td>
- <td class="border-0"></td>
- <td class="border-0"></td>
- <?php if (!FM_IS_WIN && !$hide_Cols) { ?>
- <td class="border-0"></td>
- <td class="border-0"></td>
- <?php } ?>
- </tr>
- <?php
- }
- $ii = 3399;
- foreach ($folders as $f) {
- $is_link = is_link($path . '/' . $f);
- $img = $is_link ? 'icon-link_folder' : 'fa fa-folder-o';
- $modif_raw = filemtime($path . '/' . $f);
- $modif = date(FM_DATETIME_FORMAT, $modif_raw);
- if ($calc_folder) {
- $filesize_raw = fm_get_directorysize($path . '/' . $f);
- $filesize = fm_get_filesize($filesize_raw);
- }
- else {
- $filesize_raw = "";
- $filesize = lng('Folder');
- }
- $perms = substr(decoct(fileperms($path . '/' . $f)), -4);
- if (function_exists('posix_getpwuid') && function_exists('posix_getgrgid')) {
- $owner = posix_getpwuid(fileowner($path . '/' . $f));
- $group = posix_getgrgid(filegroup($path . '/' . $f));
- } else {
- $owner = array('name' => '?');
- $group = array('name' => '?');
- }
- ?>
- <tr>
- <?php if (!FM_READONLY): ?>
- <td class="custom-checkbox-td">
- <div class="custom-control custom-checkbox">
- <input type="checkbox" class="custom-control-input" id="<?php echo $ii ?>" name="file[]" value="<?php echo fm_enc($f) ?>">
- <label class="custom-control-label" for="<?php echo $ii ?>"></label>
- </div>
- </td><?php endif; ?>
- <td>
- <div class="filename"><a href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="<?php echo $img ?>"></i> <?php echo fm_convert_win(fm_enc($f)) ?>
- </a><?php echo($is_link ? ' → <i>' . readlink($path . '/' . $f) . '</i>' : '') ?></div>
- </td>
- <td data-sort="a-<?php echo str_pad($filesize_raw, 18, "0", STR_PAD_LEFT);?>">
- <?php echo $filesize; ?>
- </td>
- <td data-sort="a-<?php echo $modif_raw;?>"><?php echo $modif ?></td>
- <?php if (!FM_IS_WIN && !$hide_Cols): ?>
- <td><?php if (!FM_READONLY): ?><a title="Change Permissions" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&chmod=<?php echo urlencode($f) ?>"><?php echo $perms ?></a><?php else: ?><?php echo $perms ?><?php endif; ?>
- </td>
- <td><?php echo $owner['name'] . ':' . $group['name'] ?></td>
- <?php endif; ?>
- <td class="inline-actions"><?php if (!FM_READONLY): ?>
- <?php if (FM_DELETE): ?>
- <a title="<?php echo lng('Delete')?>" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&del=<?php echo urlencode($f) ?>" onclick="return confirm('<?php echo lng('Delete').' '.lng('Folder').'?'; ?>\n \n ( <?php echo urlencode($f) ?> )');"> <i class="fa fa-trash-o" aria-hidden="true"></i></a>
- <?php endif; ?>
- <a title="<?php echo lng('Rename')?>" href="#" onclick="rename('<?php echo fm_enc(FM_PATH) ?>', '<?php echo fm_enc(addslashes($f)) ?>');return false;"><i class="fa fa-pencil-square-o" aria-hidden="true"></i></a>
- <a title="<?php echo lng('CopyTo')?>..." href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=&copy=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="fa fa-files-o" aria-hidden="true"></i></a>
- <?php endif; ?>
- <a title="<?php echo lng('DirectLink')?>" href="<?php echo fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f . '/') ?>" target="_blank"><i class="fa fa-link" aria-hidden="true"></i></a>
- <a title="刷新CDN" class="refreshCdn" href="#" data-href="<?php echo fm_enc((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f . '/') ?>" ><i class="fa fa-refresh " aria-hidden="true"></i></a>
- <!--只有bundle包目录可以同步到正式-->
- <?php if( checkSyncPermission($_GET['p'], $f) ): ?>
- <a title="同步到正式" class="asyncProd" href="#" data-href="<?php echo fm_enc((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f . '/') ?>" ><i class="fa fa-retweet " aria-hidden="true"></i></a>
- <?php endif; ?>
- <!--只有bundle包目录可以同步到正式-->
- <?php if(in_array(urldecode($_GET['p']), [
- 'crazyfox/activity'
- , 'crazyfox/activity'
- ])): ?>
- <a title="更新资源JSON配置" class="refreshJsonConfig" href="#" data-type="<?=$f?>" data-href="<?php echo fm_enc((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f . '/') ?>" ><i class="fa fa-check-square-o " aria-hidden="true"></i></a>
- <?php endif; ?>
- </td>
- </tr>
- <?php
- flush();
- $ii++;
- }
- $ik = 6070;
- foreach ($files as $f) {
- $is_link = is_link($path . '/' . $f);
- $img = $is_link ? 'fa fa-file-text-o' : fm_get_file_icon_class($path . '/' . $f);
- $modif_raw = filemtime($path . '/' . $f);
- $modif = date(FM_DATETIME_FORMAT, $modif_raw);
- $filesize_raw = fm_get_size($path . '/' . $f);
- $filesize = fm_get_filesize($filesize_raw);
- $filelink = '?fm_usr=<?php echo $_GET[\'fm_usr\']?>&p=' . urlencode(FM_PATH) . '&view=' . urlencode($f);
- $all_files_size += $filesize_raw;
- $perms = substr(decoct(fileperms($path . '/' . $f)), -4);
- if (function_exists('posix_getpwuid') && function_exists('posix_getgrgid')) {
- $owner = posix_getpwuid(fileowner($path . '/' . $f));
- $group = posix_getgrgid(filegroup($path . '/' . $f));
- } else {
- $owner = array('name' => '?');
- $group = array('name' => '?');
- }
- ?>
- <tr>
- <?php if (!FM_READONLY): ?>
- <td class="custom-checkbox-td">
- <div class="custom-control custom-checkbox">
- <input type="checkbox" class="custom-control-input" id="<?php echo $ik ?>" name="file[]" value="<?php echo fm_enc($f) ?>">
- <label class="custom-control-label" for="<?php echo $ik ?>"></label>
- </div>
- </td><?php endif; ?>
- <td>
- <div class="filename">
- <?php
- if (in_array(strtolower(pathinfo($f, PATHINFO_EXTENSION)), array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg'))): ?>
- <?php $imagePreview = fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f); ?>
- <a href="<?php echo $filelink ?>" data-preview-image="<?php echo $imagePreview."?time=".time() ?>" title="<?php echo $f ?>">
- <?php else: ?>
- <a href="<?php echo $filelink ?>" title="<?php echo $f ?>">
- <?php endif; ?>
- <i class="<?php echo $img ?>"></i> <?php echo fm_convert_win($f) ?>
- </a>
- <?php echo($is_link ? ' → <i>' . readlink($path . '/' . $f) . '</i>' : '') ?>
- </div>
- </td>
- <td data-sort=b-"<?php echo str_pad($filesize_raw, 18, "0", STR_PAD_LEFT); ?>"><span title="<?php printf('%s bytes', $filesize_raw) ?>">
- <?php echo $filesize; ?>
- </span></td>
- <td data-sort="b-<?php echo $modif_raw;?>"><?php echo $modif ?></td>
- <?php if (!FM_IS_WIN && !$hide_Cols): ?>
- <td><?php if (!FM_READONLY): ?><a title="<?php echo 'Change Permissions' ?>" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&chmod=<?php echo urlencode($f) ?>"><?php echo $perms ?></a><?php else: ?><?php echo $perms ?><?php endif; ?>
- </td>
- <td><?php echo fm_enc($owner['name'] . ':' . $group['name']) ?></td>
- <?php endif; ?>
- <td class="inline-actions">
- <a title="<?php echo lng('Preview') ?>" href="<?php echo $filelink.'&quickView=1'; ?>" data-toggle="lightbox" data-gallery="tiny-gallery" data-title="<?php echo fm_convert_win($f) ?>" data-max-width="100%" data-width="100%"><i class="fa fa-eye"></i></a>
- <?php if (!FM_READONLY): ?>
- <?php if (FM_DELETE): ?>
- <a title="<?php echo lng('Delete') ?>" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&del=<?php echo urlencode($f) ?>" onclick="return confirm('<?php echo lng('Delete').' '.lng('File').'?'; ?>\n \n ( <?php echo urlencode($f) ?> )');"> <i class="fa fa-trash-o"></i></a>
- <?php endif; ?>
- <a title="<?php echo lng('Rename') ?>" href="#" onclick="rename('<?php echo fm_enc(FM_PATH) ?>', '<?php echo fm_enc(addslashes($f)) ?>');return false;"><i class="fa fa-pencil-square-o"></i></a>
- <a title="<?php echo lng('CopyTo') ?>..."
- href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="fa fa-files-o"></i></a>
- <?php endif; ?>
- <a title="<?php echo lng('DirectLink') ?>" href="<?php echo fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f) ?>" target="_blank">
- <i class="fa fa-link"></i>
- </a>
- <a title="<?php echo lng('DirectLink') ?>" href="###" >
- <i class="fa fa-paperclip" onclick="copyText('<?php echo fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f) ?>')"></i>
- </a>
- <a title="<?php echo lng('Download') ?>" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&dl=<?php echo urlencode($f) ?>"><i class="fa fa-download"></i></a>
- <!--只有bundle包目录可以同步到正式-->
- <?php if( checkSyncPermission($_GET['p'], $f) ): ?>
- <a title="同步到正式" class="asyncProd" href="#" data-href="<?php echo fm_enc((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f) ?>" ><i class="fa fa-retweet " aria-hidden="true"></i></a>
- <?php endif; ?>
- </td>
- </tr>
- <?php
- flush();
- $ik++;
- }
- if (empty($folders) && empty($files)) {
- ?>
- <tfoot>
- <tr><?php if (!FM_READONLY): ?>
- <td></td><?php endif; ?>
- <td colspan="<?php echo (!FM_IS_WIN && !$hide_Cols) ? '6' : '4' ?>"><em><?php echo 'Folder is empty' ?></em></td>
- </tr>
- </tfoot>
- <?php
- } else {
- ?>
- <tfoot>
- <tr><?php if (!FM_READONLY): ?>
- <td class="gray"></td><?php endif; ?>
- <td class="gray" colspan="<?php echo (!FM_IS_WIN && !$hide_Cols) ? '6' : '4' ?>">
- <?php echo lng('FullSize').': <span class="badge badge-light">'.fm_get_filesize($all_files_size).'</span>' ?>
- <?php echo lng('File').': <span class="badge badge-light">'.$num_files.'</span>' ?>
- <?php echo lng('Folder').': <span class="badge badge-light">'.$num_folders.'</span>' ?>
- <?php echo lng('MemoryUsed').': <span class="badge badge-light">'.fm_get_filesize(@memory_get_usage(true)).'</span>' ?>
- <?php echo lng('PartitionSize').': <span class="badge badge-light">'.fm_get_filesize(@disk_free_space($path)) .'</span> '.lng('FreeOf').' <span class="badge badge-light">'.fm_get_filesize(@disk_total_space($path)).'</span>'; ?>
- </td>
- </tr>
- </tfoot>
- <?php
- }
- ?>
- </table>
- </div>
- <div class="row">
- <?php if (!FM_READONLY): ?>
- <div class="col-xs-12 col-sm-9">
- <ul class="list-inline footer-action">
- <li class="list-inline-item"> <a href="#/select-all" class="btn btn-small btn-outline-primary btn-2" onclick="select_all();return false;"><i class="fa fa-check-square"></i> <?php echo lng('SelectAll') ?> </a></li>
- <li class="list-inline-item"><a href="#/unselect-all" class="btn btn-small btn-outline-primary btn-2" onclick="unselect_all();return false;"><i class="fa fa-window-close"></i> <?php echo lng('UnSelectAll') ?> </a></li>
- <li class="list-inline-item"><a href="#/invert-all" class="btn btn-small btn-outline-primary btn-2" onclick="invert_all();return false;"><i class="fa fa-th-list"></i> <?php echo lng('InvertSelection') ?> </a></li>
- <?php if (FM_DELETE): ?>
- <li class="list-inline-item"><input type="submit" class="hidden" name="delete" id="a-delete" value="Delete" onclick="return confirm('Delete selected files and folders?')"><a href="javascript:document.getElementById('a-delete').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-trash"></i> <?php echo lng('Delete') ?> </a></li>
- <?php endif; ?>
- <li class="list-inline-item"><input type="submit" class="hidden" name="zip" id="a-zip" value="zip" onclick="return confirm('Create archive?')"><a href="javascript:document.getElementById('a-zip').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-file-archive-o"></i> <?php echo lng('Zip') ?> </a></li>
- <li class="list-inline-item"><input type="submit" class="hidden" name="tar" id="a-tar" value="tar" onclick="return confirm('Create archive?')"><a href="javascript:document.getElementById('a-tar').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-file-archive-o"></i> <?php echo lng('Tar') ?> </a></li>
- <li class="list-inline-item"><input type="submit" class="hidden" name="copy" id="a-copy" value="Copy"><a href="javascript:document.getElementById('a-copy').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-files-o"></i> <?php echo lng('Copy') ?> </a></li>
- </ul>
- </div>
- <div class="col-3 d-none d-sm-block"><a href="https://tinyfilemanager.github.io" target="_blank" class="float-right text-muted">Tiny File Manager <?php echo VERSION; ?></a></div>
- <?php else: ?>
- <div class="col-12"><a href="https://tinyfilemanager.github.io" target="_blank" class="float-right text-muted">Tiny File Manager <?php echo VERSION; ?></a></div>
- <?php endif; ?>
- </div>
- </form>
- <?php
- fm_show_footer();
- //--- END
- // Functions
- function checkSyncPermission($path, $file){
- if(empty($file))return false;
- if(in_array($file, ['Android', 'iOS']))return false;
- if(empty($path))return false;
- if(strpos($path, 'crazyfox/') !== 0)return false;
- if(strpos($path,'crazyfox/cfg') === false)return true;
- return false;
- }
- /**
- * Check if the filename is allowed.
- * @param string $filename
- * @return bool
- */
- function fm_is_file_allowed($filename)
- {
- // By default, no file is allowed
- $allowed = false;
- if (FM_EXTENSION) {
- $ext = strtolower(pathinfo($filename, PATHINFO_EXTENSION));
- if (in_array($ext, explode(',', strtolower(FM_EXTENSION)))) {
- $allowed = true;
- }
- }
- return $allowed;
- }
- /**
- * Delete file or folder (recursively)
- * @param string $path
- * @return bool
- */
- function fm_rdelete_backup($path)
- {
- if (is_link($path)) {
- return unlink($path);
- } elseif (is_dir($path)) {
- $objects = scandir($path);
- $ok = true;
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (!fm_rdelete($path . '/' . $file)) {
- $ok = false;
- }
- }
- }
- }
- return ($ok) ? rmdir($path) : false;
- } elseif (is_file($path)) {
- return unlink($path);
- }
- return false;
- }
- /**
- * Delete file or folder (recursively)
- * @param string $path
- * @return bool
- */
- function fm_rdelete($path){
- $name = $_SESSION[FM_SESSION_ID]['userName'];
- if (is_link($path)) {
- $fileName = explode('/',$path);
- if(count($fileName) > 0){
- return rename($path,DOCUMENT_ROOT."/public/RecycleBin/".time()."_".$name."_".str_replace("/","-",$path));
- }
- return false;
- } elseif (is_dir($path)) {
- $objects = scandir($path);
- $ok = true;
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (!fm_rdelete($path . '/' . $file)) {
- $ok = false;
- }
- }
- }
- }
- return ($ok) ? rmdir($path) : false;
- } elseif (is_file($path)) {
- $fileName = explode('/',$path);
- if(count($fileName) > 0){
- return rename($path,DOCUMENT_ROOT."/public/RecycleBin/".time()."_".$name."_".str_replace("/","-",$path));
- }
- return false;
- }
- return false;
- }
- /**
- * Recursive chmod
- * @param string $path
- * @param int $filemode
- * @param int $dirmode
- * @return bool
- * @todo Will use in mass chmod
- */
- function fm_rchmod($path, $filemode, $dirmode)
- {
- if (is_dir($path)) {
- if (!chmod($path, $dirmode)) {
- return false;
- }
- $objects = scandir($path);
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (!fm_rchmod($path . '/' . $file, $filemode, $dirmode)) {
- return false;
- }
- }
- }
- }
- return true;
- } elseif (is_link($path)) {
- return true;
- } elseif (is_file($path)) {
- return chmod($path, $filemode);
- }
- return false;
- }
- /**
- * Check the file extension which is allowed or not
- * @param string $filename
- * @return bool
- */
- function fm_is_valid_ext($filename)
- {
- $allowed = (FM_FILE_EXTENSION) ? explode(',', FM_FILE_EXTENSION) : false;
- $ext = pathinfo($filename, PATHINFO_EXTENSION);
- $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
- return ($isFileAllowed) ? true : false;
- }
- /**
- * Safely rename
- * @param string $old
- * @param string $new
- * @return bool|null
- */
- function fm_rename($old, $new)
- {
- $isFileAllowed = fm_is_valid_ext($new);
- if(!$isFileAllowed) return false;
- return (!file_exists($new) && file_exists($old)) ? rename($old, $new) : null;
- }
- /**
- * Copy file or folder (recursively).
- * @param string $path
- * @param string $dest
- * @param bool $upd Update files
- * @param bool $force Create folder with same names instead file
- * @return bool
- */
- function fm_rcopy($path, $dest, $upd = true, $force = true)
- {
- if (is_dir($path)) {
- if (!fm_mkdir($dest, $force)) {
- return false;
- }
- $objects = scandir($path);
- $ok = true;
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (!fm_rcopy($path . '/' . $file, $dest . '/' . $file)) {
- $ok = false;
- }
- }
- }
- }
- return $ok;
- } elseif (is_file($path)) {
- return fm_copy($path, $dest, $upd);
- }
- return false;
- }
- /**
- * Safely create folder
- * @param string $dir
- * @param bool $force
- * @return bool
- */
- function fm_mkdir($dir, $force)
- {
- if (file_exists($dir)) {
- if (is_dir($dir)) {
- return $dir;
- } elseif (!$force) {
- return false;
- }
- unlink($dir);
- }
- return mkdir($dir, 0777, true);
- }
- /**
- * Safely copy file
- * @param string $f1
- * @param string $f2
- * @param bool $upd Indicates if file should be updated with new content
- * @return bool
- */
- function fm_copy($f1, $f2, $upd)
- {
- $time1 = filemtime($f1);
- if (file_exists($f2)) {
- $time2 = filemtime($f2);
- if ($time2 >= $time1 && $upd) {
- return false;
- }
- }
- $ok = copy($f1, $f2);
- if ($ok) {
- touch($f2, $time1);
- }
- return $ok;
- }
- /**
- * Get mime type
- * @param string $file_path
- * @return mixed|string
- */
- function fm_get_mime_type($file_path)
- {
- if (function_exists('finfo_open')) {
- $finfo = finfo_open(FILEINFO_MIME_TYPE);
- $mime = finfo_file($finfo, $file_path);
- finfo_close($finfo);
- return $mime;
- } elseif (function_exists('mime_content_type')) {
- return mime_content_type($file_path);
- } elseif (!stristr(ini_get('disable_functions'), 'shell_exec')) {
- $file = escapeshellarg($file_path);
- $mime = shell_exec('file -bi ' . $file);
- return $mime;
- } else {
- return '--';
- }
- }
- /**
- * HTTP Redirect
- * @param string $url
- * @param int $code
- */
- function fm_redirect($url, $code = 302)
- {
- header('Location: ' . $url, true, $code);
- exit;
- }
- /**
- * Path traversal prevention and clean the url
- * It replaces (consecutive) occurrences of / and \\ with whatever is in DIRECTORY_SEPARATOR, and processes /. and /.. fine.
- * @param $path
- * @return string
- */
- function get_absolute_path($path) {
- $path = str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $path);
- $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen');
- $absolutes = array();
- foreach ($parts as $part) {
- if ('.' == $part) continue;
- if ('..' == $part) {
- array_pop($absolutes);
- } else {
- $absolutes[] = $part;
- }
- }
- return implode(DIRECTORY_SEPARATOR, $absolutes);
- }
- /**
- * Clean path
- * @param string $path
- * @return string
- */
- function fm_clean_path($path, $trim = true)
- {
- $path = $trim ? trim($path) : $path;
- $path = trim($path, '\\/');
- $path = str_replace(array('../', '..\\'), '', $path);
- $path = get_absolute_path($path);
- if ($path == '..') {
- $path = '';
- }
- return str_replace('\\', '/', $path);
- }
- /**
- * Get parent path
- * @param string $path
- * @return bool|string
- */
- function fm_get_parent_path($path)
- {
- $path = fm_clean_path($path);
- if ($path != '') {
- $array = explode('/', $path);
- if (count($array) > 1) {
- $array = array_slice($array, 0, -1);
- return implode('/', $array);
- }
- return '';
- }
- return false;
- }
- /**
- * Check file is in exclude list
- * @param string $file
- * @return bool
- */
- function fm_is_exclude_items($file) {
- $ext = strtolower(pathinfo($file, PATHINFO_EXTENSION));
- if(!in_array($file, FM_EXCLUDE_ITEMS) && !in_array("*.$ext", FM_EXCLUDE_ITEMS)) {
- return true;
- }
- return false;
- }
- /**
- * get language translations from json file
- * @param int $tr
- * @return array
- */
- function fm_get_translations($tr) {
- try {
- $content = @file_get_contents('translation.json');
- if($content !== FALSE) {
- $lng = json_decode($content, TRUE);
- global $lang_list;
- foreach ($lng["language"] as $key => $value)
- {
- $code = $value["code"];
- $lang_list[$code] = $value["name"];
- if ($tr)
- $tr[$code] = $value["translation"];
- }
- return $tr;
- }
- }
- catch (Exception $e) {
- echo $e;
- }
- }
- /**
- * @param $file
- * Recover all file sizes larger than > 2GB.
- * Works on php 32bits and 64bits and supports linux
- * @return int|string
- */
- function fm_get_size($file)
- {
- static $iswin;
- static $isdarwin;
- if (!isset($iswin)) {
- $iswin = (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN');
- }
- if (!isset($isdarwin)) {
- $isdarwin = (strtoupper(substr(PHP_OS, 0)) == "DARWIN");
- }
- static $exec_works;
- if (!isset($exec_works)) {
- $exec_works = (function_exists('exec') && !ini_get('safe_mode') && @exec('echo EXEC') == 'EXEC');
- }
- // try a shell command
- if ($exec_works) {
- $arg = escapeshellarg($file);
- $cmd = ($iswin) ? "for %F in (\"$file\") do @echo %~zF" : ($isdarwin ? "stat -f%z $arg" : "stat -c%s $arg");
- @exec($cmd, $output);
- if (is_array($output) && ctype_digit($size = trim(implode("\n", $output)))) {
- return $size;
- }
- }
- // try the Windows COM interface
- if ($iswin && class_exists("COM")) {
- try {
- $fsobj = new COM('Scripting.FileSystemObject');
- $f = $fsobj->GetFile( realpath($file) );
- $size = $f->Size;
- } catch (Exception $e) {
- $size = null;
- }
- if (ctype_digit($size)) {
- return $size;
- }
- }
- // if all else fails
- return filesize($file);
- }
- /**
- * Get nice filesize
- * @param int $size
- * @return string
- */
- function fm_get_filesize($size)
- {
- $size = (float) $size;
- $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
- $power = $size > 0 ? floor(log($size, 1024)) : 0;
- return sprintf('%s %s', round($size / pow(1024, $power), 2), $units[$power]);
- }
- /**
- * Get director total size
- * @param string $directory
- * @return int
- */
- function fm_get_directorysize($directory) {
- global $calc_folder;
- if ($calc_folder==true) { // Slower output
- $size = 0; $count= 0; $dirCount= 0;
- foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory)) as $file)
- if ($file->isFile())
- { $size+=$file->getSize();
- $count++;
- }
- else if ($file->isDir()) { $dirCount++; }
- // return [$size, $count, $dirCount];
- return $size;
- }
- else return 'Folder'; // Quick output
- }
- /**
- * Get info about zip archive
- * @param string $path
- * @return array|bool
- */
- function fm_get_zif_info($path, $ext) {
- if ($ext == 'zip' && function_exists('zip_open')) {
- $arch = zip_open($path);
- if ($arch) {
- $filenames = array();
- while ($zip_entry = zip_read($arch)) {
- $zip_name = zip_entry_name($zip_entry);
- $zip_folder = substr($zip_name, -1) == '/';
- $filenames[] = array(
- 'name' => $zip_name,
- 'filesize' => zip_entry_filesize($zip_entry),
- 'compressed_size' => zip_entry_compressedsize($zip_entry),
- 'folder' => $zip_folder
- //'compression_method' => zip_entry_compressionmethod($zip_entry),
- );
- }
- zip_close($arch);
- return $filenames;
- }
- } elseif($ext == 'tar' && class_exists('PharData')) {
- $archive = new PharData($path);
- $filenames = array();
- foreach(new RecursiveIteratorIterator($archive) as $file) {
- $parent_info = $file->getPathInfo();
- $zip_name = str_replace("phar://".$path, '', $file->getPathName());
- $zip_name = substr($zip_name, ($pos = strpos($zip_name, '/')) !== false ? $pos + 1 : 0);
- $zip_folder = $parent_info->getFileName();
- $zip_info = new SplFileInfo($file);
- $filenames[] = array(
- 'name' => $zip_name,
- 'filesize' => $zip_info->getSize(),
- 'compressed_size' => $file->getCompressedSize(),
- 'folder' => $zip_folder
- );
- }
- return $filenames;
- }
- return false;
- }
- /**
- * Encode html entities
- * @param string $text
- * @return string
- */
- function fm_enc($text)
- {
- return htmlspecialchars($text, ENT_QUOTES, 'UTF-8');
- }
- /**
- * Prevent XSS attacks
- * @param string $text
- * @return string
- */
- function fm_isvalid_filename($text) {
- return (strpbrk($text, '/?%*:|"<>') === FALSE) ? true : false;
- }
- /**
- * Save message in session
- * @param string $msg
- * @param string $status
- */
- function fm_set_msg($msg, $status = 'ok')
- {
- $_SESSION[FM_SESSION_ID]['message'] = $msg;
- $_SESSION[FM_SESSION_ID]['status'] = $status;
- }
- /**
- * Check if string is in UTF-8
- * @param string $string
- * @return int
- */
- function fm_is_utf8($string)
- {
- return preg_match('//u', $string);
- }
- /**
- * Convert file name to UTF-8 in Windows
- * @param string $filename
- * @return string
- */
- function fm_convert_win($filename)
- {
- if (FM_IS_WIN && function_exists('iconv')) {
- $filename = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $filename);
- }
- return $filename;
- }
- /**
- * @param $obj
- * @return array
- */
- function fm_object_to_array($obj)
- {
- if (!is_object($obj) && !is_array($obj)) {
- return $obj;
- }
- if (is_object($obj)) {
- $obj = get_object_vars($obj);
- }
- return array_map('fm_object_to_array', $obj);
- }
- /**
- * Get CSS classname for file
- * @param string $path
- * @return string
- */
- function fm_get_file_icon_class($path)
- {
- // get extension
- $ext = strtolower(pathinfo($path, PATHINFO_EXTENSION));
- switch ($ext) {
- case 'ico':
- case 'gif':
- case 'jpg':
- case 'jpeg':
- case 'jpc':
- case 'jp2':
- case 'jpx':
- case 'xbm':
- case 'wbmp':
- case 'png':
- case 'bmp':
- case 'tif':
- case 'tiff':
- case 'svg':
- $img = 'fa fa-picture-o';
- break;
- case 'passwd':
- case 'ftpquota':
- case 'sql':
- case 'js':
- case 'json':
- case 'sh':
- case 'config':
- case 'twig':
- case 'tpl':
- case 'md':
- case 'gitignore':
- case 'c':
- case 'cpp':
- case 'cs':
- case 'py':
- case 'map':
- case 'lock':
- case 'dtd':
- $img = 'fa fa-file-code-o';
- break;
- case 'txt':
- case 'ini':
- case 'conf':
- case 'log':
- case 'htaccess':
- $img = 'fa fa-file-text-o';
- break;
- case 'css':
- case 'less':
- case 'sass':
- case 'scss':
- $img = 'fa fa-css3';
- break;
- case 'zip':
- case 'rar':
- case 'gz':
- case 'tar':
- case '7z':
- $img = 'fa fa-file-archive-o';
- break;
- case 'php':
- case 'php4':
- case 'php5':
- case 'phps':
- case 'phtml':
- $img = 'fa fa-code';
- break;
- case 'htm':
- case 'html':
- case 'shtml':
- case 'xhtml':
- $img = 'fa fa-html5';
- break;
- case 'xml':
- case 'xsl':
- $img = 'fa fa-file-excel-o';
- break;
- case 'wav':
- case 'mp3':
- case 'mp2':
- case 'm4a':
- case 'aac':
- case 'ogg':
- case 'oga':
- case 'wma':
- case 'mka':
- case 'flac':
- case 'ac3':
- case 'tds':
- $img = 'fa fa-music';
- break;
- case 'm3u':
- case 'm3u8':
- case 'pls':
- case 'cue':
- $img = 'fa fa-headphones';
- break;
- case 'avi':
- case 'mpg':
- case 'mpeg':
- case 'mp4':
- case 'm4v':
- case 'flv':
- case 'f4v':
- case 'ogm':
- case 'ogv':
- case 'mov':
- case 'mkv':
- case '3gp':
- case 'asf':
- case 'wmv':
- $img = 'fa fa-file-video-o';
- break;
- case 'eml':
- case 'msg':
- $img = 'fa fa-envelope-o';
- break;
- case 'xls':
- case 'xlsx':
- case 'ods':
- $img = 'fa fa-file-excel-o';
- break;
- case 'csv':
- $img = 'fa fa-file-text-o';
- break;
- case 'bak':
- $img = 'fa fa-clipboard';
- break;
- case 'doc':
- case 'docx':
- case 'odt':
- $img = 'fa fa-file-word-o';
- break;
- case 'ppt':
- case 'pptx':
- $img = 'fa fa-file-powerpoint-o';
- break;
- case 'ttf':
- case 'ttc':
- case 'otf':
- case 'woff':
- case 'woff2':
- case 'eot':
- case 'fon':
- $img = 'fa fa-font';
- break;
- case 'pdf':
- $img = 'fa fa-file-pdf-o';
- break;
- case 'psd':
- case 'ai':
- case 'eps':
- case 'fla':
- case 'swf':
- $img = 'fa fa-file-image-o';
- break;
- case 'exe':
- case 'msi':
- $img = 'fa fa-file-o';
- break;
- case 'bat':
- $img = 'fa fa-terminal';
- break;
- default:
- $img = 'fa fa-info-circle';
- }
- return $img;
- }
- /**
- * Get image files extensions
- * @return array
- */
- function fm_get_image_exts()
- {
- return array('ico', 'gif', 'jpg', 'jpeg', 'jpc', 'jp2', 'jpx', 'xbm', 'wbmp', 'png', 'bmp', 'tif', 'tiff', 'psd', 'svg');
- }
- /**
- * Get video files extensions
- * @return array
- */
- function fm_get_video_exts()
- {
- return array('avi', 'webm', 'wmv', 'mp4', 'm4v', 'ogm', 'ogv', 'mov', 'mkv');
- }
- /**
- * Get audio files extensions
- * @return array
- */
- function fm_get_audio_exts()
- {
- return array('wav', 'mp3', 'ogg', 'm4a');
- }
- /**
- * Get text file extensions
- * @return array
- */
- function fm_get_text_exts()
- {
- return array(
- 'txt', 'css', 'ini', 'conf', 'log', 'htaccess', 'passwd', 'ftpquota', 'sql', 'js', 'json', 'sh', 'config',
- 'php', 'php4', 'php5', 'phps', 'phtml', 'htm', 'html', 'shtml', 'xhtml', 'xml', 'xsl', 'm3u', 'm3u8', 'pls', 'cue',
- 'eml', 'msg', 'csv', 'bat', 'twig', 'tpl', 'md', 'gitignore', 'less', 'sass', 'scss', 'c', 'cpp', 'cs', 'py',
- 'map', 'lock', 'dtd', 'svg', 'scss', 'asp', 'aspx', 'asx', 'asmx', 'ashx', 'jsx', 'jsp', 'jspx', 'cfm', 'cgi'
- );
- }
- /**
- * Get mime types of text files
- * @return array
- */
- function fm_get_text_mimes()
- {
- return array(
- 'application/xml',
- 'application/javascript',
- 'application/x-javascript',
- 'image/svg+xml',
- 'message/rfc822',
- );
- }
- /**
- * Get file names of text files w/o extensions
- * @return array
- */
- function fm_get_text_names()
- {
- return array(
- 'license',
- 'readme',
- 'authors',
- 'contributors',
- 'changelog',
- );
- }
- /**
- * Get online docs viewer supported files extensions
- * @return array
- */
- function fm_get_onlineViewer_exts()
- {
- return array('doc', 'docx', 'xls', 'xlsx', 'pdf', 'ppt', 'pptx', 'ai', 'psd', 'dxf', 'xps', 'rar', 'odt', 'ods');
- }
- function fm_get_file_mimes($extension)
- {
- $fileTypes['swf'] = 'application/x-shockwave-flash';
- $fileTypes['pdf'] = 'application/pdf';
- $fileTypes['exe'] = 'application/octet-stream';
- $fileTypes['zip'] = 'application/zip';
- $fileTypes['doc'] = 'application/msword';
- $fileTypes['xls'] = 'application/vnd.ms-excel';
- $fileTypes['ppt'] = 'application/vnd.ms-powerpoint';
- $fileTypes['gif'] = 'image/gif';
- $fileTypes['png'] = 'image/png';
- $fileTypes['jpeg'] = 'image/jpg';
- $fileTypes['jpg'] = 'image/jpg';
- $fileTypes['rar'] = 'application/rar';
- $fileTypes['ra'] = 'audio/x-pn-realaudio';
- $fileTypes['ram'] = 'audio/x-pn-realaudio';
- $fileTypes['ogg'] = 'audio/x-pn-realaudio';
- $fileTypes['wav'] = 'video/x-msvideo';
- $fileTypes['wmv'] = 'video/x-msvideo';
- $fileTypes['avi'] = 'video/x-msvideo';
- $fileTypes['asf'] = 'video/x-msvideo';
- $fileTypes['divx'] = 'video/x-msvideo';
- $fileTypes['mp3'] = 'audio/mpeg';
- $fileTypes['mp4'] = 'audio/mpeg';
- $fileTypes['mpeg'] = 'video/mpeg';
- $fileTypes['mpg'] = 'video/mpeg';
- $fileTypes['mpe'] = 'video/mpeg';
- $fileTypes['mov'] = 'video/quicktime';
- $fileTypes['swf'] = 'video/quicktime';
- $fileTypes['3gp'] = 'video/quicktime';
- $fileTypes['m4a'] = 'video/quicktime';
- $fileTypes['aac'] = 'video/quicktime';
- $fileTypes['m3u'] = 'video/quicktime';
- $fileTypes['php'] = ['application/x-php'];
- $fileTypes['html'] = ['text/html'];
- $fileTypes['txt'] = ['text/plain'];
- return $fileTypes[$extension];
- }
- /**
- * This function scans the files and folder recursively, and return matching files
- * @param string $dir
- * @param string $filter
- * @return json
- */
- function scan($dir, $filter = '') {
- $path = FM_ROOT_PATH.'/'.$dir;
- if($dir) {
- $ite = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path));
- $rii = new RegexIterator($ite, "/(" . $filter . ")/i");
- $files = array();
- foreach ($rii as $file) {
- if (!$file->isDir()) {
- $fileName = $file->getFilename();
- $location = str_replace(FM_ROOT_PATH, '', $file->getPath());
- $files[] = array(
- "name" => $fileName,
- "type" => "file",
- "path" => $location,
- );
- }
- }
- return $files;
- }
- }
- /*
- Parameters: downloadFile(File Location, File Name,
- max speed, is streaming
- If streaming - videos will show as videos, images as images
- instead of download prompt
- https://stackoverflow.com/a/13821992/1164642
- */
- function fm_download_file($fileLocation, $fileName, $chunkSize = 1024)
- {
- if (connection_status() != 0)
- return (false);
- $extension = pathinfo($fileName, PATHINFO_EXTENSION);
- $contentType = fm_get_file_mimes($extension);
- header("Cache-Control: public");
- header("Content-Transfer-Encoding: binary\n");
- header('Content-Type: $contentType');
- $contentDisposition = 'attachment';
- if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) {
- $fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1);
- header("Content-Disposition: $contentDisposition;filename=\"$fileName\"");
- } else {
- header("Content-Disposition: $contentDisposition;filename=\"$fileName\"");
- }
- header("Accept-Ranges: bytes");
- $range = 0;
- $size = filesize($fileLocation);
- if (isset($_SERVER['HTTP_RANGE'])) {
- list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']);
- str_replace($range, "-", $range);
- $size2 = $size - 1;
- $new_length = $size - $range;
- header("HTTP/1.1 206 Partial Content");
- header("Content-Length: $new_length");
- header("Content-Range: bytes $range$size2/$size");
- } else {
- $size2 = $size - 1;
- header("Content-Range: bytes 0-$size2/$size");
- header("Content-Length: " . $size);
- }
- if ($size == 0) {
- die('Zero byte file! Aborting download');
- }
- @ini_set('magic_quotes_runtime', 0);
- $fp = fopen("$fileLocation", "rb");
- fseek($fp, $range);
- while (!feof($fp) and (connection_status() == 0)) {
- set_time_limit(0);
- print(@fread($fp, 1024*$chunkSize));
- flush();
- ob_flush();
- sleep(1);
- }
- fclose($fp);
- return ((connection_status() == 0) and !connection_aborted());
- }
- function fm_get_theme() {
- $result = '';
- if(FM_THEME == "dark") {
- $result = "text-white bg-dark";
- }
- return $result;
- }
- /**
- * Class to work with zip files (using ZipArchive)
- */
- class FM_Zipper
- {
- private $zip;
- public function __construct()
- {
- $this->zip = new ZipArchive();
- }
- /**
- * Create archive with name $filename and files $files (RELATIVE PATHS!)
- * @param string $filename
- * @param array|string $files
- * @return bool
- */
- public function create($filename, $files)
- {
- $res = $this->zip->open($filename, ZipArchive::CREATE);
- if ($res !== true) {
- return false;
- }
- if (is_array($files)) {
- foreach ($files as $f) {
- if (!$this->addFileOrDir($f)) {
- $this->zip->close();
- return false;
- }
- }
- $this->zip->close();
- return true;
- } else {
- if ($this->addFileOrDir($files)) {
- $this->zip->close();
- return true;
- }
- return false;
- }
- }
- /**
- * Extract archive $filename to folder $path (RELATIVE OR ABSOLUTE PATHS)
- * @param string $filename
- * @param string $path
- * @return bool
- */
- public function unzip($filename, $path)
- {
- $res = $this->zip->open($filename);
- if ($res !== true) {
- return false;
- }
- if ($this->zip->extractTo($path)) {
- $this->zip->close();
- return true;
- }
- return false;
- }
- /**
- * Add file/folder to archive
- * @param string $filename
- * @return bool
- */
- private function addFileOrDir($filename)
- {
- if (is_file($filename)) {
- return $this->zip->addFile($filename);
- } elseif (is_dir($filename)) {
- return $this->addDir($filename);
- }
- return false;
- }
- /**
- * Add folder recursively
- * @param string $path
- * @return bool
- */
- private function addDir($path)
- {
- if (!$this->zip->addEmptyDir($path)) {
- return false;
- }
- $objects = scandir($path);
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (is_dir($path . '/' . $file)) {
- if (!$this->addDir($path . '/' . $file)) {
- return false;
- }
- } elseif (is_file($path . '/' . $file)) {
- if (!$this->zip->addFile($path . '/' . $file)) {
- return false;
- }
- }
- }
- }
- return true;
- }
- return false;
- }
- }
- /**
- * Class to work with Tar files (using PharData)
- */
- class FM_Zipper_Tar
- {
- private $tar;
- public function __construct()
- {
- $this->tar = null;
- }
- /**
- * Create archive with name $filename and files $files (RELATIVE PATHS!)
- * @param string $filename
- * @param array|string $files
- * @return bool
- */
- public function create($filename, $files)
- {
- $this->tar = new PharData($filename);
- if (is_array($files)) {
- foreach ($files as $f) {
- if (!$this->addFileOrDir($f)) {
- return false;
- }
- }
- return true;
- } else {
- if ($this->addFileOrDir($files)) {
- return true;
- }
- return false;
- }
- }
- /**
- * Extract archive $filename to folder $path (RELATIVE OR ABSOLUTE PATHS)
- * @param string $filename
- * @param string $path
- * @return bool
- */
- public function unzip($filename, $path)
- {
- $res = $this->tar->open($filename);
- if ($res !== true) {
- return false;
- }
- if ($this->tar->extractTo($path)) {
- return true;
- }
- return false;
- }
- /**
- * Add file/folder to archive
- * @param string $filename
- * @return bool
- */
- private function addFileOrDir($filename)
- {
- if (is_file($filename)) {
- try {
- $this->tar->addFile($filename);
- return true;
- } catch (Exception $e) {
- return false;
- }
- } elseif (is_dir($filename)) {
- return $this->addDir($filename);
- }
- return false;
- }
- /**
- * Add folder recursively
- * @param string $path
- * @return bool
- */
- private function addDir($path)
- {
- $objects = scandir($path);
- if (is_array($objects)) {
- foreach ($objects as $file) {
- if ($file != '.' && $file != '..') {
- if (is_dir($path . '/' . $file)) {
- if (!$this->addDir($path . '/' . $file)) {
- return false;
- }
- } elseif (is_file($path . '/' . $file)) {
- try {
- $this->tar->addFile($path . '/' . $file);
- } catch (Exception $e) {
- return false;
- }
- }
- }
- }
- return true;
- }
- return false;
- }
- }
- /**
- * Save Configuration
- */
- class FM_Config
- {
- var $data;
- function __construct()
- {
- global $root_path, $root_url, $CONFIG;
- $fm_url = $root_url.$_SERVER["PHP_SELF"];
- $this->data = array(
- 'lang' => 'en',
- 'error_reporting' => true,
- 'show_hidden' => true
- );
- $data = false;
- if (strlen($CONFIG)) {
- $data = fm_object_to_array(json_decode($CONFIG));
- } else {
- $msg = 'Tiny File Manager<br>Error: Cannot load configuration';
- if (substr($fm_url, -1) == '/') {
- $fm_url = rtrim($fm_url, '/');
- $msg .= '<br>';
- $msg .= '<br>Seems like you have a trailing slash on the URL.';
- $msg .= '<br>Try this link: <a href="' . $fm_url . '">' . $fm_url . '</a>';
- }
- die($msg);
- }
- if (is_array($data) && count($data)) $this->data = $data;
- else $this->save();
- }
- function save()
- {
- $fm_file = __FILE__;
- $var_name = '$CONFIG';
- $var_value = var_export(json_encode($this->data), true);
- $config_string = "<?php" . chr(13) . chr(10) . "//Default Configuration".chr(13) . chr(10)."$var_name = $var_value;" . chr(13) . chr(10);
- if (is_writable($fm_file)) {
- $lines = file($fm_file);
- if ($fh = @fopen($fm_file, "w")) {
- @fputs($fh, $config_string, strlen($config_string));
- for ($x = 3; $x < count($lines); $x++) {
- @fputs($fh, $lines[$x], strlen($lines[$x]));
- }
- @fclose($fh);
- }
- }
- }
- }
- //--- templates functions
- /**
- * Show nav block
- * @param string $path
- */
- function fm_show_nav_path($path)
- {
- global $lang, $sticky_navbar;
- $isStickyNavBar = $sticky_navbar ? 'fixed-top' : '';
- $getTheme = fm_get_theme();
- $getTheme .= " navbar-light";
- if(FM_THEME == "dark") {
- $getTheme .= " navbar-dark";
- } else {
- $getTheme .= " bg-white";
- }
- ?>
- <nav class="navbar navbar-expand-lg <?php echo $getTheme; ?> mb-4 main-nav <?php echo $isStickyNavBar ?>">
- <a class="navbar-brand" href=""> <?php echo lng('AppTitle') ?> </a>
- <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
- <span class="navbar-toggler-icon"></span>
- </button>
- <div class="collapse navbar-collapse" id="navbarSupportedContent">
- <?php
- $path = fm_clean_path($path);
- $root_url = "<a href='?fm_usr={$_GET['fm_usr']}&p='><i class='fa fa-home' aria-hidden='true' title='" . FM_ROOT_PATH . "'></i></a>";
- $sep = '<i class="bread-crumb"> / </i>';
- if ($path != '') {
- $exploded = explode('/', $path);
- $count = count($exploded);
- $array = array();
- $parent = '';
- for ($i = 0; $i < $count; $i++) {
- $parent = trim($parent . '/' . $exploded[$i], '/');
- $parent_enc = urlencode($parent);
- $array[] = "<a href='?fm_usr={$_GET['fm_usr']}&p={$parent_enc}'>" . fm_enc(fm_convert_win($exploded[$i])) . "</a>";
- }
- $root_url .= $sep . implode($sep, $array);
- }
- echo '<div class="col-xs-6 col-sm-5">' . $root_url . '</div>';
- ?>
- <div class="col-xs-6 col-sm-7 text-right">
- <ul class="navbar-nav mr-auto float-right <?php echo fm_get_theme(); ?>">
- <li class="nav-item mr-2">
- <div class="input-group input-group-sm mr-1" style="margin-top:4px;">
- <input type="text" class="form-control" placeholder="<?php echo lng('Search') ?>" aria-label="<?php echo lng('Search') ?>" aria-describedby="search-addon2" id="search-addon">
- <div class="input-group-append">
- <span class="input-group-text" id="search-addon2"><i class="fa fa-search"></i></span>
- </div>
- <div class="input-group-append btn-group">
- <span class="input-group-text dropdown-toggle" id="search-addon2" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"></span>
- <div class="dropdown-menu dropdown-menu-right">
- <a class="dropdown-item" href="<?php echo $path2 = $path ? $path : '.'; ?>" id="js-search-modal" data-toggle="modal" data-target="#searchModal">Advanced Search</a>
- </div>
- </div>
- </div>
- </li>
- <?php if (!FM_READONLY): ?>
- <li class="nav-item">
- <a title="<?php echo lng('Upload') ?>" class="nav-link" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&upload"><i class="fa fa-cloud-upload" aria-hidden="true"></i> <?php echo lng('Upload') ?></a>
- </li>
- <li class="nav-item">
- <a title="<?php echo lng('NewItem') ?>" class="nav-link" href="#createNewItem" data-toggle="modal" data-target="#createNewItem"><i class="fa fa-plus-square"></i> <?php echo lng('NewItem') ?></a>
- </li>
- <?php endif; ?>
- <?php if (FM_USE_AUTH): ?>
- <li class="nav-item avatar dropdown">
- <a class="nav-link dropdown-toggle" id="navbarDropdownMenuLink-5" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> <i class="fa fa-user-circle"></i> <?php if(isset($_SESSION[FM_SESSION_ID]['logged'])) { echo $_SESSION[FM_SESSION_ID]['logged']; } ?></a>
- <div class="dropdown-menu dropdown-menu-right <?php echo fm_get_theme(); ?>" aria-labelledby="navbarDropdownMenuLink-5">
- <?php if (!FM_READONLY): ?>
- <a title="<?php echo lng('Settings') ?>" class="dropdown-item nav-link" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&settings=1"><i class="fa fa-cog" aria-hidden="true"></i> <?php echo lng('Settings') ?></a>
- <?php endif ?>
- <!-- <a title="--><?php //echo lng('Help') ?><!--" class="dropdown-item nav-link" href="?p=--><?php //echo urlencode(FM_PATH) ?><!--&help=2"><i class="fa fa-exclamation-circle" aria-hidden="true"></i> --><?php //echo lng('Help') ?><!--</a>-->
- <a title="<?php echo lng('Logout') ?>" class="dropdown-item nav-link" href="?logout=1"><i class="fa fa-sign-out" aria-hidden="true"></i> <?php echo lng('Logout') ?></a>
- </div>
- </li>
- <?php else: ?>
- <?php if (!FM_READONLY): ?>
- <li class="nav-item">
- <a title="<?php echo lng('Settings') ?>" class="dropdown-item nav-link" href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=<?php echo urlencode(FM_PATH) ?>&settings=1"><i class="fa fa-cog" aria-hidden="true"></i> <?php echo lng('Settings') ?></a>
- </li>
- <?php endif; ?>
- <?php endif; ?>
- </ul>
- </div>
- </div>
- </nav>
- <?php
- }
- /**
- * Show message from session
- */
- function fm_show_message()
- {
- if (isset($_SESSION[FM_SESSION_ID]['message'])) {
- $class = isset($_SESSION[FM_SESSION_ID]['status']) ? $_SESSION[FM_SESSION_ID]['status'] : 'ok';
- echo '<p class="message ' . $class . '">' . $_SESSION[FM_SESSION_ID]['message'] . '</p>';
- unset($_SESSION[FM_SESSION_ID]['message']);
- unset($_SESSION[FM_SESSION_ID]['status']);
- }
- }
- /**
- * Show page header in Login Form
- */
- function fm_show_header_login()
- {
- $sprites_ver = '20160315';
- header("Content-Type: text/html; charset=utf-8");
- header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
- header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0");
- header("Pragma: no-cache");
- global $lang, $root_url, $favicon_path;
- ?>
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
- <meta name="description" content="Web based File Manager in PHP, Manage your files efficiently and easily with Tiny File Manager">
- <meta name="author" content="CCP Programmers">
- <meta name="robots" content="noindex, nofollow">
- <meta name="googlebot" content="noindex">
- <link rel="icon" href="<?php echo fm_enc($favicon_path) ?>" type="image/png">
- <title><?php echo fm_enc(APP_TITLE) ?></title>
- <link rel="stylesheet" href="/public/filemanager/js/bootstrap.min.css">
- <style>
- body.fm-login-page{ background-color:#f7f9fb;font-size:14px;background-color:#f7f9fb;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 304 304' width='304' height='304'%3E%3Cpath fill='%23e2e9f1' fill-opacity='0.4' d='M44.1 224a5 5 0 1 1 0 2H0v-2h44.1zm160 48a5 5 0 1 1 0 2H82v-2h122.1zm57.8-46a5 5 0 1 1 0-2H304v2h-42.1zm0 16a5 5 0 1 1 0-2H304v2h-42.1zm6.2-114a5 5 0 1 1 0 2h-86.2a5 5 0 1 1 0-2h86.2zm-256-48a5 5 0 1 1 0 2H0v-2h12.1zm185.8 34a5 5 0 1 1 0-2h86.2a5 5 0 1 1 0 2h-86.2zM258 12.1a5 5 0 1 1-2 0V0h2v12.1zm-64 208a5 5 0 1 1-2 0v-54.2a5 5 0 1 1 2 0v54.2zm48-198.2V80h62v2h-64V21.9a5 5 0 1 1 2 0zm16 16V64h46v2h-48V37.9a5 5 0 1 1 2 0zm-128 96V208h16v12.1a5 5 0 1 1-2 0V210h-16v-76.1a5 5 0 1 1 2 0zm-5.9-21.9a5 5 0 1 1 0 2H114v48H85.9a5 5 0 1 1 0-2H112v-48h12.1zm-6.2 130a5 5 0 1 1 0-2H176v-74.1a5 5 0 1 1 2 0V242h-60.1zm-16-64a5 5 0 1 1 0-2H114v48h10.1a5 5 0 1 1 0 2H112v-48h-10.1zM66 284.1a5 5 0 1 1-2 0V274H50v30h-2v-32h18v12.1zM236.1 176a5 5 0 1 1 0 2H226v94h48v32h-2v-30h-48v-98h12.1zm25.8-30a5 5 0 1 1 0-2H274v44.1a5 5 0 1 1-2 0V146h-10.1zm-64 96a5 5 0 1 1 0-2H208v-80h16v-14h-42.1a5 5 0 1 1 0-2H226v18h-16v80h-12.1zm86.2-210a5 5 0 1 1 0 2H272V0h2v32h10.1zM98 101.9V146H53.9a5 5 0 1 1 0-2H96v-42.1a5 5 0 1 1 2 0zM53.9 34a5 5 0 1 1 0-2H80V0h2v34H53.9zm60.1 3.9V66H82v64H69.9a5 5 0 1 1 0-2H80V64h32V37.9a5 5 0 1 1 2 0zM101.9 82a5 5 0 1 1 0-2H128V37.9a5 5 0 1 1 2 0V82h-28.1zm16-64a5 5 0 1 1 0-2H146v44.1a5 5 0 1 1-2 0V18h-26.1zm102.2 270a5 5 0 1 1 0 2H98v14h-2v-16h124.1zM242 149.9V160h16v34h-16v62h48v48h-2v-46h-48v-66h16v-30h-16v-12.1a5 5 0 1 1 2 0zM53.9 18a5 5 0 1 1 0-2H64V2H48V0h18v18H53.9zm112 32a5 5 0 1 1 0-2H192V0h50v2h-48v48h-28.1zm-48-48a5 5 0 0 1-9.8-2h2.07a3 3 0 1 0 5.66 0H178v34h-18V21.9a5 5 0 1 1 2 0V32h14V2h-58.1zm0 96a5 5 0 1 1 0-2H137l32-32h39V21.9a5 5 0 1 1 2 0V66h-40.17l-32 32H117.9zm28.1 90.1a5 5 0 1 1-2 0v-76.51L175.59 80H224V21.9a5 5 0 1 1 2 0V82h-49.59L146 112.41v75.69zm16 32a5 5 0 1 1-2 0v-99.51L184.59 96H300.1a5 5 0 0 1 3.9-3.9v2.07a3 3 0 0 0 0 5.66v2.07a5 5 0 0 1-3.9-3.9H185.41L162 121.41v98.69zm-144-64a5 5 0 1 1-2 0v-3.51l48-48V48h32V0h2v50H66v55.41l-48 48v2.69zM50 53.9v43.51l-48 48V208h26.1a5 5 0 1 1 0 2H0v-65.41l48-48V53.9a5 5 0 1 1 2 0zm-16 16V89.41l-34 34v-2.82l32-32V69.9a5 5 0 1 1 2 0zM12.1 32a5 5 0 1 1 0 2H9.41L0 43.41V40.6L8.59 32h3.51zm265.8 18a5 5 0 1 1 0-2h18.69l7.41-7.41v2.82L297.41 50H277.9zm-16 160a5 5 0 1 1 0-2H288v-71.41l16-16v2.82l-14 14V210h-28.1zm-208 32a5 5 0 1 1 0-2H64v-22.59L40.59 194H21.9a5 5 0 1 1 0-2H41.41L66 216.59V242H53.9zm150.2 14a5 5 0 1 1 0 2H96v-56.6L56.6 162H37.9a5 5 0 1 1 0-2h19.5L98 200.6V256h106.1zm-150.2 2a5 5 0 1 1 0-2H80v-46.59L48.59 178H21.9a5 5 0 1 1 0-2H49.41L82 208.59V258H53.9zM34 39.8v1.61L9.41 66H0v-2h8.59L32 40.59V0h2v39.8zM2 300.1a5 5 0 0 1 3.9 3.9H3.83A3 3 0 0 0 0 302.17V256h18v48h-2v-46H2v42.1zM34 241v63h-2v-62H0v-2h34v1zM17 18H0v-2h16V0h2v18h-1zm273-2h14v2h-16V0h2v16zm-32 273v15h-2v-14h-14v14h-2v-16h18v1zM0 92.1A5.02 5.02 0 0 1 6 97a5 5 0 0 1-6 4.9v-2.07a3 3 0 1 0 0-5.66V92.1zM80 272h2v32h-2v-32zm37.9 32h-2.07a3 3 0 0 0-5.66 0h-2.07a5 5 0 0 1 9.8 0zM5.9 0A5.02 5.02 0 0 1 0 5.9V3.83A3 3 0 0 0 3.83 0H5.9zm294.2 0h2.07A3 3 0 0 0 304 3.83V5.9a5 5 0 0 1-3.9-5.9zm3.9 300.1v2.07a3 3 0 0 0-1.83 1.83h-2.07a5 5 0 0 1 3.9-3.9zM97 100a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-48 32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32 48a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16-64a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 96a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-144a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-96 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm96 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16-64a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-32 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zM49 36a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-32 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zM33 68a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-48a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 240a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16-64a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm80-176a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32 48a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm112 176a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm-16 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zM17 180a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0 16a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm0-32a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16 0a3 3 0 1 0 0-6 3 3 0 0 0 0 6zM17 84a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm32 64a3 3 0 1 0 0-6 3 3 0 0 0 0 6zm16-16a3 3 0 1 0 0-6 3 3 0 0 0 0 6z'%3E%3C/path%3E%3C/svg%3E");}
- .fm-login-page .brand{ width:121px;overflow:hidden;margin:0 auto;position:relative;z-index:1}
- .fm-login-page .brand img{ width:100%}
- .fm-login-page .card-wrapper{ width:360px;margin-top:10%;margin-left:auto;margin-right:auto;}
- .fm-login-page .card{ border-color:transparent;box-shadow:0 4px 8px rgba(0,0,0,.05)}
- .fm-login-page .card-title{ margin-bottom:1.5rem;font-size:24px;font-weight:400;}
- .fm-login-page .form-control{ border-width:2.3px}
- .fm-login-page .form-group label{ width:100%}
- .fm-login-page .btn.btn-block{ padding:12px 10px}
- .fm-login-page .footer{ margin:40px 0;color:#888;text-align:center}
- @media screen and (max-width:425px){
- .fm-login-page .card-wrapper{ width:90%;margin:0 auto;margin-top:10%;}
- }
- @media screen and (max-width:320px){
- .fm-login-page .card.fat{ padding:0}
- .fm-login-page .card.fat .card-body{ padding:15px}
- }
- .message{ padding:4px 7px;border:1px solid #ddd;background-color:#fff}
- .message.ok{ border-color:green;color:green}
- .message.error{ border-color:red;color:red}
- .message.alert{ border-color:orange;color:orange}
- body.fm-login-page.theme-dark {background-color: #2f2a2a;}
- .theme-dark svg g, .theme-dark svg path {fill: #ffffff; }
- </style>
- </head>
- <body class="fm-login-page <?php echo (FM_THEME == "dark") ? 'theme-dark' : ''; ?>">
- <!-- loading start -->
- <style>
- #loadingMask{
- position: fixed;
- top: 0;
- bottom: 0;
- left: 0;
- right: 0;
- z-index: 1000000;
- background: white;
- opacity: 0.5;
- display: none;
- }
- /* Spinner Circle Rotation */
- .sp {
- width: 32px;
- height: 32px;
- clear: both;
- margin: 20px auto;
- }
- .sp-circle {
- border: 4px rgba(0, 0, 0, 0.25) solid;
- border-top: 4px black solid;
- border-radius: 50%;
- -webkit-animation: spCircRot .6s infinite linear;
- animation: spCircRot .6s infinite linear;
- }
- @-webkit-keyframes spCircRot {
- from {
- -webkit-transform: rotate(0deg);
- }
- to {
- -webkit-transform: rotate(359deg);
- }
- }
- @keyframes spCircRot {
- from {
- transform: rotate(0deg);
- }
- to {
- transform: rotate(359deg);
- }
- }
- /* Spinner 3Balls Scale */
- .sp-3balls, .sp-3balls:before, .sp-3balls:after {
- border-radius: 50%;
- background-color: #000;
- width: 18px;
- height: 18px;
- transform-origin: center center;
- display: inline-block;
- }
- .sp-3balls {
- position: relative;
- background-color: black;
- opacity: 1;
- -webkit-animation: spScaleAlpha 1s infinite linear;
- animation: spScaleAlpha 1s infinite linear;
- }
- .sp-3balls:before, .sp-3balls:after {
- content: '';
- position: relative;
- opacity: 0.25;
- }
- .sp-3balls:before {
- left: 30px;
- top: 0px;
- -webkit-animation: spScaleAlphaBefore 1s infinite linear;
- animation: spScaleAlphaBefore 1s infinite linear;
- }
- .sp-3balls:after {
- left: -30px;
- top: -23px;
- -webkit-animation: spScaleAlphaAfter 1s infinite linear;
- animation: spScaleAlphaAfter 1s infinite linear;
- }
- @-webkit-keyframes spScaleAlpha {
- 0% {
- opacity: 1;
- }
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 0.25;
- }
- 100% {
- opacity: 1;
- }
- }
- @keyframes spScaleAlpha {
- 0% {
- opacity: 1;
- }
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 0.25;
- }
- 100% {
- opacity: 1;
- }
- }
- @-webkit-keyframes spScaleAlphaBefore {
- 0% {
- opacity: 0.25;
- }
- 33% {
- opacity: 1;
- }
- 66% {
- opacity: 0.25;
- }
- }
- @keyframes spScaleAlphaBefore {
- 0% {
- opacity: 0.25;
- }
- 33% {
- opacity: 1;
- }
- 66% {
- opacity: 0.25;
- }
- }
- @-webkit-keyframes spScaleAlphaAfter {
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 1;
- }
- 100% {
- opacity: 0.25;
- }
- }
- @keyframes spScaleAlphaAfter {
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 1;
- }
- 100% {
- opacity: 0.25;
- }
- }
- </style>
- <div id="loadingMask" style="z-index: 999999999">
- <div class="row" style="height: 100%;display: flex;align-items: center;">
- <div class="" style="width: 50%;margin-left: 25%;text-align: center;">
- <div class="sp sp-3balls"></div>
- </div>
- </div>
- </div>
- <!-- loading end -->
- <div id="wrapper" class="container-fluid">
- <?php
- }
- /**
- * Show page footer in Login Form
- */
- function fm_show_footer_login()
- {
- ?>
- </div>
- <script src="/public/filemanager/js/jquery.slim.min.js"></script>
- <script src="/public/filemanager/js/bootstrap.min.js"></script>
- </body>
- </html>
- <?php
- }
- /**
- * Show Header after login
- */
- function fm_show_header()
- {
- $sprites_ver = '20160315';
- header("Content-Type: text/html; charset=utf-8");
- header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
- header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0");
- header("Pragma: no-cache");
- global $lang, $root_url, $sticky_navbar, $favicon_path;
- $isStickyNavBar = $sticky_navbar ? 'navbar-fixed' : 'navbar-normal';
- ?>
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
- <meta name="description" content="Web based File Manager in PHP, Manage your files efficiently and easily with Tiny File Manager">
- <meta name="author" content="CCP Programmers">
- <meta name="robots" content="noindex, nofollow">
- <meta name="googlebot" content="noindex">
- <link rel="icon" href="<?php echo fm_enc($favicon_path) ?>" type="image/png">
- <title><?php echo fm_enc(APP_TITLE) ?></title>
- <link rel="stylesheet" href="/public/filemanager/js/bootstrap.min.css">
- <link rel="stylesheet" href="/public/filemanager/js/font-awesome.min.css">
- <link rel="stylesheet" href="/public/filemanager/js/ekko-lightbox.css" />
- <?php if (FM_USE_HIGHLIGHTJS): ?>
- <link rel="stylesheet" href="/public/filemanager/js/<?php echo FM_HIGHLIGHTJS_STYLE ?>.min.css">
- <?php endif; ?>
- <style>
- body { font-size:14px;color:#222;background:#F7F7F7; }
- body.navbar-fixed { margin-top:55px; }
- a:hover, a:visited, a:focus { text-decoration:none !important; }
- * { -webkit-border-radius:0 !important;-moz-border-radius:0 !important;border-radius:0 !important; }
- .filename, td, th { white-space:nowrap }
- .navbar-brand { font-weight:bold; }
- .nav-item.avatar a { cursor:pointer;text-transform:capitalize; }
- .nav-item.avatar a > i { font-size:15px; }
- .nav-item.avatar .dropdown-menu a { font-size:13px; }
- #search-addon { font-size:12px;border-right-width:0; }
- #search-addon2 { background:transparent;border-left:0; }
- .bread-crumb { color:#cccccc;font-style:normal; }
- #main-table .filename a { color:#222222; }
- .table td, .table th { vertical-align:middle !important; }
- .table .custom-checkbox-td .custom-control.custom-checkbox, .table .custom-checkbox-header .custom-control.custom-checkbox { min-width:18px; }
- .table-sm td, .table-sm th { padding:.4rem; }
- .table-bordered td, .table-bordered th { border:1px solid #f1f1f1; }
- .hidden { display:none }
- pre.with-hljs { padding:0 }
- pre.with-hljs code { margin:0;border:0;overflow:visible }
- code.maxheight, pre.maxheight { max-height:512px }
- .fa.fa-caret-right { font-size:1.2em;margin:0 4px;vertical-align:middle;color:#ececec }
- .fa.fa-home { font-size:1.3em;vertical-align:bottom }
- .path { margin-bottom:10px }
- form.dropzone { min-height:200px;border:2px dashed #007bff;line-height:6rem; }
- .right { text-align:right }
- .center, .close, .login-form { text-align:center }
- .message { padding:4px 7px;border:1px solid #ddd;background-color:#fff }
- .message.ok { border-color:green;color:green }
- .message.error { border-color:red;color:red }
- .message.alert { border-color:orange;color:orange }
- .preview-img { max-width:100%;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAIAAACQkWg2AAAAKklEQVR42mL5//8/Azbw+PFjrOJMDCSCUQ3EABZc4S0rKzsaSvTTABBgAMyfCMsY4B9iAAAAAElFTkSuQmCC) }
- .inline-actions > a > i { font-size:1em;margin-left:5px;background:#3785c1;color:#fff;padding:3px;border-radius:3px }
- .preview-video { position:relative;max-width:100%;height:0;padding-bottom:62.5%;margin-bottom:10px }
- .preview-video video { position:absolute;width:100%;height:100%;left:0;top:0;background:#000 }
- .compact-table { border:0;width:auto }
- .compact-table td, .compact-table th { width:100px;border:0;text-align:center }
- .compact-table tr:hover td { background-color:#fff }
- .filename { max-width:420px;overflow:hidden;text-overflow:ellipsis }
- .break-word { word-wrap:break-word;margin-left:30px }
- .break-word.float-left a { color:#7d7d7d }
- .break-word + .float-right { padding-right:30px;position:relative }
- .break-word + .float-right > a { color:#7d7d7d;font-size:1.2em;margin-right:4px }
- #editor { position:absolute;right:15px;top:100px;bottom:15px;left:15px }
- @media (max-width:481px) {
- #editor { top:150px; }
- }
- #normal-editor { border-radius:3px;border-width:2px;padding:10px;outline:none; }
- .btn-2 { border-radius:0;padding:3px 6px;font-size:small; }
- li.file:before,li.folder:before { font:normal normal normal 14px/1 FontAwesome;content:"\f016";margin-right:5px }
- li.folder:before { content:"\f114" }
- i.fa.fa-folder-o { color:#0157b3 }
- i.fa.fa-picture-o { color:#26b99a }
- i.fa.fa-file-archive-o { color:#da7d7d }
- .btn-2 i.fa.fa-file-archive-o { color:inherit }
- i.fa.fa-css3 { color:#f36fa0 }
- i.fa.fa-file-code-o { color:#007bff }
- i.fa.fa-code { color:#cc4b4c }
- i.fa.fa-file-text-o { color:#0096e6 }
- i.fa.fa-html5 { color:#d75e72 }
- i.fa.fa-file-excel-o { color:#09c55d }
- i.fa.fa-file-powerpoint-o { color:#f6712e }
- i.go-back { font-size:1.2em;color:#007bff; }
- .main-nav { padding:0.2rem 1rem;box-shadow:0 4px 5px 0 rgba(0, 0, 0, .14), 0 1px 10px 0 rgba(0, 0, 0, .12), 0 2px 4px -1px rgba(0, 0, 0, .2) }
- .dataTables_filter { display:none; }
- table.dataTable thead .sorting { cursor:pointer;background-repeat:no-repeat;background-position:center right;background-image:url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAQAAADYWf5HAAAAkElEQVQoz7XQMQ5AQBCF4dWQSJxC5wwax1Cq1e7BAdxD5SL+Tq/QCM1oNiJidwox0355mXnG/DrEtIQ6azioNZQxI0ykPhTQIwhCR+BmBYtlK7kLJYwWCcJA9M4qdrZrd8pPjZWPtOqdRQy320YSV17OatFC4euts6z39GYMKRPCTKY9UnPQ6P+GtMRfGtPnBCiqhAeJPmkqAAAAAElFTkSuQmCC'); }
- table.dataTable thead .sorting_asc { cursor:pointer;background-repeat:no-repeat;background-position:center right;background-image:url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAZ0lEQVQ4y2NgGLKgquEuFxBPAGI2ahhWCsS/gDibUoO0gPgxEP8H4ttArEyuQYxAPBdqEAxPBImTY5gjEL9DM+wTENuQahAvEO9DMwiGdwAxOymGJQLxTyD+jgWDxCMZRsEoGAVoAADeemwtPcZI2wAAAABJRU5ErkJggg=='); }
- table.dataTable thead .sorting_desc { cursor:pointer;background-repeat:no-repeat;background-position:center right;background-image:url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAZUlEQVQ4y2NgGAWjYBSggaqGu5FA/BOIv2PBIPFEUgxjB+IdQPwfC94HxLykus4GiD+hGfQOiB3J8SojEE9EM2wuSJzcsFMG4ttQgx4DsRalkZENxL+AuJQaMcsGxBOAmGvopk8AVz1sLZgg0bsAAAAASUVORK5CYII='); }
- table.dataTable thead tr:first-child th.custom-checkbox-header:first-child { background-image:none; }
- .footer-action li { margin-bottom:10px; }
- .app-v-title { font-size:24px;font-weight:300;letter-spacing:-.5px;text-transform:uppercase; }
- hr.custom-hr { border-top:1px dashed #8c8b8b;border-bottom:1px dashed #fff; }
- .ekko-lightbox .modal-dialog { max-width:98%; }
- .ekko-lightbox-item.fade.in.show .row { background:#fff; }
- .ekko-lightbox-nav-overlay { display:flex !important;opacity:1 !important;height:auto !important;top:50%; }
- .ekko-lightbox-nav-overlay a { opacity:1 !important;width:auto !important;text-shadow:none !important;color:#3B3B3B; }
- .ekko-lightbox-nav-overlay a:hover { color:#20507D; }
- #snackbar { visibility:hidden;min-width:250px;margin-left:-125px;background-color:#333;color:#fff;text-align:center;border-radius:2px;padding:16px;position:fixed;z-index:1;left:50%;bottom:30px;font-size:17px; }
- #snackbar.show { visibility:visible;-webkit-animation:fadein 0.5s, fadeout 0.5s 2.5s;animation:fadein 0.5s, fadeout 0.5s 2.5s; }
- @-webkit-keyframes fadein { from { bottom:0;opacity:0; }
- to { bottom:30px;opacity:1; }
- }
- @keyframes fadein { from { bottom:0;opacity:0; }
- to { bottom:30px;opacity:1; }
- }
- @-webkit-keyframes fadeout { from { bottom:30px;opacity:1; }
- to { bottom:0;opacity:0; }
- }
- @keyframes fadeout { from { bottom:30px;opacity:1; }
- to { bottom:0;opacity:0; }
- }
- #main-table span.badge { border-bottom:2px solid #f8f9fa }
- #main-table span.badge:nth-child(1) { border-color:#df4227 }
- #main-table span.badge:nth-child(2) { border-color:#f8b600 }
- #main-table span.badge:nth-child(3) { border-color:#00bd60 }
- #main-table span.badge:nth-child(4) { border-color:#4581ff }
- #main-table span.badge:nth-child(5) { border-color:#ac68fc }
- #main-table span.badge:nth-child(6) { border-color:#45c3d2 }
- @media only screen and (min-device-width:768px) and (max-device-width:1024px) and (orientation:landscape) and (-webkit-min-device-pixel-ratio:2) { .navbar-collapse .col-xs-6.text-right { padding:0; }
- }
- .btn.active.focus,.btn.active:focus,.btn.focus,.btn.focus:active,.btn:active:focus,.btn:focus { outline:0!important;outline-offset:0!important;background-image:none!important;-webkit-box-shadow:none!important;box-shadow:none!important }
- .lds-facebook { display:none;position:relative;width:64px;height:64px }
- .lds-facebook div,.lds-facebook.show-me { display:inline-block }
- .lds-facebook div { position:absolute;left:6px;width:13px;background:#007bff;animation:lds-facebook 1.2s cubic-bezier(0,.5,.5,1) infinite }
- .lds-facebook div:nth-child(1) { left:6px;animation-delay:-.24s }
- .lds-facebook div:nth-child(2) { left:26px;animation-delay:-.12s }
- .lds-facebook div:nth-child(3) { left:45px;animation-delay:0 }
- @keyframes lds-facebook { 0% { top:6px;height:51px }
- 100%,50% { top:19px;height:26px }
- }
- ul#search-wrapper { padding-left: 0;border: 1px solid #ecececcc; } ul#search-wrapper li { list-style: none; padding: 5px;border-bottom: 1px solid #ecececcc; }
- ul#search-wrapper li:nth-child(odd){ background: #f9f9f9cc;}
- .c-preview-img {
- max-width: 300px;
- }
- .navbar-light .navbar-nav .nav-link {
- color: #007bff;
- }
- </style>
- <?php
- if (FM_THEME == "dark"): ?>
- <style>
- body.theme-dark { background-color: #2f2a2a; }
- .list-group .list-group-item { background: #343a40; }
- .theme-dark .navbar-nav i, .navbar-nav .dropdown-toggle, .break-word { color: #ffffff; }
- a, a:hover, a:visited, a:active, #main-table .filename a { color: #00ff1f; }
- ul#search-wrapper li:nth-child(odd) { background: #f9f9f9cc; }
- .theme-dark .btn-outline-primary { color: #00ff1f; border-color: #00ff1f; }
- .theme-dark .btn-outline-primary:hover, .theme-dark .btn-outline-primary:active { background-color: #028211;}
- </style>
- <?php endif; ?>
- </head>
- <body class="<?php echo (FM_THEME == "dark") ? 'theme-dark' : ''; ?> <?php echo $isStickyNavBar; ?>">
- <!-- loading start -->
- <style>
- #loadingMask{
- position: fixed;
- top: 0;
- bottom: 0;
- left: 0;
- right: 0;
- z-index: 1000000;
- background: white;
- opacity: 0.5;
- display: none;
- }
- /* Spinner Circle Rotation */
- .sp {
- width: 32px;
- height: 32px;
- clear: both;
- margin: 20px auto;
- }
- .sp-circle {
- border: 4px rgba(0, 0, 0, 0.25) solid;
- border-top: 4px black solid;
- border-radius: 50%;
- -webkit-animation: spCircRot .6s infinite linear;
- animation: spCircRot .6s infinite linear;
- }
- @-webkit-keyframes spCircRot {
- from {
- -webkit-transform: rotate(0deg);
- }
- to {
- -webkit-transform: rotate(359deg);
- }
- }
- @keyframes spCircRot {
- from {
- transform: rotate(0deg);
- }
- to {
- transform: rotate(359deg);
- }
- }
- /* Spinner 3Balls Scale */
- .sp-3balls, .sp-3balls:before, .sp-3balls:after {
- border-radius: 50%!important;
- background-color: #000;
- width: 18px;
- height: 18px;
- transform-origin: center center;
- display: inline-block;
- }
- .sp-3balls {
- position: relative;
- background-color: black;
- opacity: 1;
- -webkit-animation: spScaleAlpha 1s infinite linear;
- animation: spScaleAlpha 1s infinite linear;
- }
- .sp-3balls:before, .sp-3balls:after {
- content: '';
- position: relative;
- opacity: 0.25;
- }
- .sp-3balls:before {
- left: 30px;
- top: 0px;
- -webkit-animation: spScaleAlphaBefore 1s infinite linear;
- animation: spScaleAlphaBefore 1s infinite linear;
- }
- .sp-3balls:after {
- left: -30px;
- top: -23px;
- -webkit-animation: spScaleAlphaAfter 1s infinite linear;
- animation: spScaleAlphaAfter 1s infinite linear;
- }
- @-webkit-keyframes spScaleAlpha {
- 0% {
- opacity: 1;
- }
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 0.25;
- }
- 100% {
- opacity: 1;
- }
- }
- @keyframes spScaleAlpha {
- 0% {
- opacity: 1;
- }
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 0.25;
- }
- 100% {
- opacity: 1;
- }
- }
- @-webkit-keyframes spScaleAlphaBefore {
- 0% {
- opacity: 0.25;
- }
- 33% {
- opacity: 1;
- }
- 66% {
- opacity: 0.25;
- }
- }
- @keyframes spScaleAlphaBefore {
- 0% {
- opacity: 0.25;
- }
- 33% {
- opacity: 1;
- }
- 66% {
- opacity: 0.25;
- }
- }
- @-webkit-keyframes spScaleAlphaAfter {
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 1;
- }
- 100% {
- opacity: 0.25;
- }
- }
- @keyframes spScaleAlphaAfter {
- 33% {
- opacity: 0.25;
- }
- 66% {
- opacity: 1;
- }
- 100% {
- opacity: 0.25;
- }
- }
- </style>
- <div id="loadingMask" style="z-index: 999999999">
- <div class="row" style="height: 100%;display: flex;align-items: center;">
- <div class="" style="width: 50%;margin-left: 25%;text-align: center;">
- <div class="sp sp-3balls"></div>
- </div>
- </div>
- </div>
- <!-- loading end -->
- <div id="wrapper" class="container-fluid">
- <!-- New Item creation -->
- <div class="modal fade" id="createNewItem" tabindex="-1" role="dialog" aria-label="newItemModalLabel" aria-hidden="true">
- <div class="modal-dialog" role="document">
- <div class="modal-content <?php echo fm_get_theme(); ?>">
- <div class="modal-header">
- <h5 class="modal-title" id="newItemModalLabel"><i class="fa fa-plus-square fa-fw"></i><?php echo lng('CreateNewItem') ?></h5>
- <button type="button" class="close" data-dismiss="modal" aria-label="Close">
- <span aria-hidden="true">×</span>
- </button>
- </div>
- <div class="modal-body">
- <p><label for="newfile"><?php echo lng('ItemType') ?> </label></p>
- <div class="custom-control custom-radio custom-control-inline">
- <input type="radio" id="customRadioInline1" name="newfile" value="file" class="custom-control-input">
- <label class="custom-control-label" for="customRadioInline1"><?php echo lng('File') ?></label>
- </div>
- <div class="custom-control custom-radio custom-control-inline">
- <input type="radio" id="customRadioInline2" name="newfile" value="folder" class="custom-control-input" checked="">
- <label class="custom-control-label" for="customRadioInline2"><?php echo lng('Folder') ?></label>
- </div>
- <p class="mt-3"><label for="newfilename"><?php echo lng('ItemName') ?> </label></p>
- <input type="text" name="newfilename" id="newfilename" value="" class="form-control">
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-outline-primary" data-dismiss="modal"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></button>
- <button type="button" class="btn btn-success" onclick="newfolder('<?php echo fm_enc(FM_PATH) ?>');return false;"><i class="fa fa-check-circle"></i> <?php echo lng('CreateNow') ?></button>
- </div>
- </div>
- </div>
- </div>
- <!-- Modal -->
- <div class="modal fade" id="searchModal" tabindex="-1" role="dialog" aria-labelledby="searchModalLabel" aria-hidden="true">
- <div class="modal-dialog modal-lg" role="document">
- <div class="modal-content <?php echo fm_get_theme(); ?>">
- <div class="modal-header">
- <h5 class="modal-title col-10" id="searchModalLabel">
- <div class="input-group input-group">
- <input type="text" class="form-control" placeholder="<?php echo lng('Search') ?> a files" aria-label="<?php echo lng('Search') ?>" aria-describedby="search-addon3" id="advanced-search" autofocus required>
- <div class="input-group-append">
- <span class="input-group-text" id="search-addon3"><i class="fa fa-search"></i></span>
- </div>
- </div>
- </h5>
- <button type="button" class="close" data-dismiss="modal" aria-label="Close">
- <span aria-hidden="true">×</span>
- </button>
- </div>
- <div class="modal-body">
- <form action="" method="post">
- <div class="lds-facebook"><div></div><div></div><div></div></div>
- <ul id="search-wrapper">
- <p class="m-2">Search file in folder and subfolders...</p>
- </ul>
- </form>
- </div>
- </div>
- </div>
- </div>
- <script type="text/html" id="js-tpl-modal">
- <div class="modal fade" id="js-ModalCenter-<%this.id%>" tabindex="-1" role="dialog" aria-labelledby="ModalCenterTitle" aria-hidden="true">
- <div class="modal-dialog modal-dialog-centered" role="document">
- <div class="modal-content">
- <div class="modal-header">
- <h5 class="modal-title" id="ModalCenterTitle"><%this.title%></h5>
- <button type="button" class="close" data-dismiss="modal" aria-label="Close">
- <span aria-hidden="true">×</span>
- </button>
- </div>
- <div class="modal-body">
- <%this.content%>
- </div>
- <div class="modal-footer">
- <button type="button" class="btn btn-outline-primary" data-dismiss="modal"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></button>
- <%if(this.action){%><button type="button" class="btn btn-primary" id="js-ModalCenterAction" data-type="js-<%this.action%>"><%this.action%></button><%}%>
- </div>
- </div>
- </div>
- </div>
- </script>
- <?php
- }
- /**
- * Show page footer
- */
- function fm_show_footer()
- {
- ?>
- </div>
- <script src="/public/filemanager/js/jquery.min.js"></script>
- <script src="/public/filemanager/js/bootstrap.min.js"></script>
- <script src="/public/filemanager/js/jquery.dataTables.min.js"></script>
- <script src="/public/filemanager/js/ekko-lightbox.min.js"></script>
- <?php if (FM_USE_HIGHLIGHTJS): ?>
- <script src="/public/filemanager/js/highlight.min.js"></script>
- <script>hljs.initHighlightingOnLoad(); var isHighlightingEnabled = true;</script>
- <?php endif; ?>
- <script>
- $(document).on('click', '[data-toggle="lightbox"]', function(event) {
- event.preventDefault();
- var reInitHighlight = function() { if(typeof isHighlightingEnabled !== "undefined" && isHighlightingEnabled) { setTimeout(function () { $('.ekko-lightbox-container pre code').each(function (i, e) { hljs.highlightBlock(e) }); }, 555); } };
- $(this).ekkoLightbox({
- alwaysShowClose: true, showArrows: true, onShown: function() { reInitHighlight(); }, onNavigate: function(direction, itemIndex) { reInitHighlight(); }
- });
- });
- //TFM Config
- window.curi = "/public/filemanager/js/config.json", window.config = null;
- function fm_get_config(){ if(!!window.name){ window.config = JSON.parse(window.name); } else { $.getJSON(window.curi).done(function(c) { if(!!c) { window.name = JSON.stringify(c), window.config = c; } }); }}
- function template(html,options){
- var re=/<\%([^\%>]+)?\%>/g,reExp=/(^( )?(if|for|else|switch|case|break|{|}))(.*)?/g,code='var r=[];\n',cursor=0,match;var add=function(line,js){js?(code+=line.match(reExp)?line+'\n':'r.push('+line+');\n'):(code+=line!=''?'r.push("'+line.replace(/"/g,'\\"')+'");\n':'');return add}
- while(match=re.exec(html)){add(html.slice(cursor,match.index))(match[1],!0);cursor=match.index+match[0].length}
- add(html.substr(cursor,html.length-cursor));code+='return r.join("");';return new Function(code.replace(/[\r\t\n]/g,'')).apply(options)
- }
- function newfolder(e) {
- var t = document.getElementById("newfilename").value, n = document.querySelector('input[name="newfile"]:checked').value;
- null !== t && "" !== t && n && (window.location.hash = "#", window.location.search = "fm_usr=<?php echo $_GET['fm_usr'];?>&p=" + encodeURIComponent(e) + "&new=" + encodeURIComponent(t) + "&type=" + encodeURIComponent(n))
- }
- function rename(e, t) {var n = prompt("New name", t);null !== n && "" !== n && n != t && (window.location.search = "fm_usr=<?php echo $_GET['fm_usr'];?>&p=" + encodeURIComponent(e) + "&ren=" + encodeURIComponent(t) + "&to=" + encodeURIComponent(n))}
- function change_checkboxes(e, t) { for (var n = e.length - 1; n >= 0; n--) e[n].checked = "boolean" == typeof t ? t : !e[n].checked }
- function get_checkboxes() { for (var e = document.getElementsByName("file[]"), t = [], n = e.length - 1; n >= 0; n--) (e[n].type = "checkbox") && t.push(e[n]); return t }
- function select_all() { change_checkboxes(get_checkboxes(), !0) }
- function unselect_all() { change_checkboxes(get_checkboxes(), !1) }
- function invert_all() { change_checkboxes(get_checkboxes()) }
- function checkbox_toggle() { var e = get_checkboxes(); e.push(this), change_checkboxes(e) }
- function backup(e, t) { //Create file backup with .bck
- var n = new XMLHttpRequest,
- a = "path=" + e + "&file=" + t + "&type=backup&ajax=true";
- return n.open("POST", "", !0), n.setRequestHeader("Content-type", "application/x-www-form-urlencoded"), n.onreadystatechange = function () {
- 4 == n.readyState && 200 == n.status && alert(n.responseText)
- }, n.send(a), !1
- }
- // Toast message
- function toast(txt) { var x = document.getElementById("snackbar");x.innerHTML=txt;x.className = "show";setTimeout(function(){ x.className = x.className.replace("show", ""); }, 3000); }
- //Save file
- function edit_save(e, t) {
- var n = "ace" == t ? editor.getSession().getValue() : document.getElementById("normal-editor").value;
- if (n) {
- if(true){
- var data = {ajax: true, content: n, type: 'save'};
- $.ajax({
- type: "POST",
- url: window.location,
- // The key needs to match your method's input parameter (case-sensitive).
- data: JSON.stringify(data),
- contentType: "multipart/form-data-encoded; charset=utf-8",
- //dataType: "json",
- success: function(mes){alert("Saved Successfully"); window.onbeforeunload = function() {return}},
- failure: function(mes) {alert("Error: try again");},
- error: function(mes) {alert(`<p style="background-color:red">${mes.responseText}</p>`);}
- });
- }
- else{
- var a = document.createElement("form");
- a.setAttribute("method", "POST"), a.setAttribute("action", "");
- var o = document.createElement("textarea");
- o.setAttribute("type", "textarea"), o.setAttribute("name", "savedata");
- var c = document.createTextNode(n);
- o.appendChild(c), a.appendChild(o), document.body.appendChild(a), a.submit()
- }
- }
- }
- //Check latest version
- function latest_release_info(v) {
- if(!!window.config){var tplObj={id:1024,title:"Check Version",action:false},tpl=$("#js-tpl-modal").html();
- if(window.config.version!=v){tplObj.content=window.config.newUpdate;}else{tplObj.content=window.config.noUpdate;}
- $('#wrapper').append(template(tpl,tplObj));$("#js-ModalCenter-1024").modal('show');}else{fm_get_config();}
- }
- function show_new_pwd() { $(".js-new-pwd").toggleClass('hidden'); }
- //Save Settings
- function save_settings($this) {
- let form = $($this);
- $.ajax({
- type: form.attr('method'), url: form.attr('action'), data: form.serialize()+"&ajax="+true,
- success: function (data) {if(data) { window.location.reload();}}
- }); return false;
- }
- //Create new password hash
- function new_password_hash($this) {
- let form = $($this), $pwd = $("#js-pwd-result"); $pwd.val('');
- $.ajax({
- type: form.attr('method'), url: form.attr('action'), data: form.serialize()+"&ajax="+true,
- success: function (data) { if(data) { $pwd.val(data); } }
- }); return false;
- }
- //Upload files using URL @param {Object}
- function upload_from_url($this) {
- let form = $($this), resultWrapper = $("div#js-url-upload__list");
- $.ajax({
- type: form.attr('method'), url: form.attr('action'), data: form.serialize()+"&ajax="+true,
- beforeSend: function() { form.find("input[name=uploadurl]").attr("disabled","disabled"); form.find("button").hide(); form.find(".lds-facebook").addClass('show-me'); },
- success: function (data) {
- if(data) {
- data = JSON.parse(data);
- if(data.done) {
- resultWrapper.append('<div class="alert alert-success row">Uploaded Successful: '+data.done.name+'</div>'); form.find("input[name=uploadurl]").val('');
- } else if(data['fail']) { resultWrapper.append('<div class="alert alert-danger row">Error: '+data.fail.message+'</div>'); }
- form.find("input[name=uploadurl]").removeAttr("disabled");form.find("button").show();form.find(".lds-facebook").removeClass('show-me');
- }
- },
- error: function(xhr) {
- form.find("input[name=uploadurl]").removeAttr("disabled");form.find("button").show();form.find(".lds-facebook").removeClass('show-me');console.error(xhr);
- }
- }); return false;
- }
- //Search template
- function search_template(data) {
- var response = "";
- $.each(data, function (key, val) {
- response += `<li><a href="?fm_usr=<?php echo $_GET['fm_usr']?>&p=${val.path}&view=${val.name}">${val.path}/${val.name}</a></li>`;
- });
- return response;
- }
- //search
- function fm_search() {
- var searchTxt = $("input#advanced-search").val(), searchWrapper = $("ul#search-wrapper"), path = $("#js-search-modal").attr("href"), _html = "", $loader = $("div.lds-facebook");
- if(!!searchTxt && searchTxt.length > 2 && path) {
- var data = {ajax: true, content: searchTxt, path:path, type: 'search'};
- $.ajax({
- type: "POST",
- url: window.location,
- data: data,
- beforeSend: function() {
- searchWrapper.html('');
- $loader.addClass('show-me');
- },
- success: function(data){
- $loader.removeClass('show-me');
- data = JSON.parse(data);
- if(data && data.length) {
- _html = search_template(data);
- searchWrapper.html(_html);
- } else { searchWrapper.html('<p class="m-2">No result found!<p>'); }
- },
- error: function(xhr) { $loader.removeClass('show-me'); searchWrapper.html('<p class="m-2">ERROR: Try again later!</p>'); },
- failure: function(mes) { $loader.removeClass('show-me'); searchWrapper.html('<p class="m-2">ERROR: Try again later!</p>');}
- });
- } else { searchWrapper.html("OOPS: minimum 3 characters required!"); }
- }
- //on mouse hover image preview
- !function(s){s.previewImage=function(e){var o=s(document),t=".previewImage",a=s.extend({xOffset:20,yOffset:-20,fadeIn:"fast",css:{padding:"5px",border:"1px solid #cccccc","background-color":"#fff"},eventSelector:"[data-preview-image]",dataKey:"previewImage",overlayId:"preview-image-plugin-overlay"},e);return o.off(t),o.on("mouseover"+t,a.eventSelector,function(e){s("p#"+a.overlayId).remove();var o=s("<p>").attr("id",a.overlayId).css("position","absolute").css("display","none").append(s('<img class="c-preview-img">').attr("src",s(this).data(a.dataKey)));a.css&&o.css(a.css),s("body").append(o),o.css("top",e.pageY+a.yOffset+"px").css("left",e.pageX+a.xOffset+"px").fadeIn(a.fadeIn)}),o.on("mouseout"+t,a.eventSelector,function(){s("#"+a.overlayId).remove()}),o.on("mousemove"+t,a.eventSelector,function(e){s("#"+a.overlayId).css("top",e.pageY+a.yOffset+"px").css("left",e.pageX+a.xOffset+"px")}),this},s.previewImage()}(jQuery);
- // Dom Ready Event
- $(document).ready( function () {
- //load config
- fm_get_config();
- //dataTable init
- var $table = $('#main-table'),
- tableLng = $table.find('th').length,
- _targets = (tableLng && tableLng == 7 ) ? [0, 4,5,6] : tableLng == 5 ? [0,4] : [3],
- mainTable = $('#main-table').DataTable({"paging": false, "info": false, "columnDefs": [{"targets": _targets, "orderable": false}]
- });
- //search
- $('#search-addon').on( 'keyup', function () {
- mainTable.search( this.value ).draw();
- });
- $("input#advanced-search").on('keyup', function (e) {
- if (e.keyCode === 13) { fm_search(); }
- });
- $('#search-addon3').on( 'click', function () { fm_search(); });
- //upload nav tabs
- $(".fm-upload-wrapper .card-header-tabs").on("click", 'a', function(e){
- e.preventDefault();let target=$(this).data('target');
- $(".fm-upload-wrapper .card-header-tabs a").removeClass('active');$(this).addClass('active');
- $(".fm-upload-wrapper .card-tabs-container").addClass('hidden');$(target).removeClass('hidden');
- });
- });
- $('.refreshCdn').click(function(){
- var path = $(this).data('href');
- if(confirm('确定刷新CDN目录:'+path)){
- showLoading()
- $.post('/config/refreshCDN',{path:path},function(res){
- hideLoading()
- if(typeof res =='string')res = JSON.parse(res);
- alert(res.msg)
- })
- }
- })
- $('.asyncProd').click(function(){
- var path = $(this).data('href');
- if(confirm('确定同步目录或文件:'+path+' 到正式环境')){
- showLoading()
- $.post('/config/syncBundleDir',{path:path},function(res){
- hideLoading()
- if(typeof res =='string')res = JSON.parse(res);
- alert(res.msg)
- })
- }
- })
- $('.refreshJsonConfig').click(function(){
- var path = $(this).data('href');
- var type = $(this).data('type');
- console.log(path)
- if(confirm('确定刷新:'+path+' JSON配置')){
- showLoading()
- $.post('/config/refreshJsonConfig',{path:path,type:type},function(res){
- hideLoading()
- if(typeof res =='string')res = JSON.parse(res);
- alert(res.msg)
- })
- }
- })
- function copyText(text){
- if (!navigator.clipboard) {
- fallbackCopyTextToClipboard(text);
- return;
- }
- navigator.clipboard.writeText(text).then(function() {
- console.log('Async: Copying to clipboard was successful!');
- toast('复制成功')
- }, function(err) {
- console.error('Async: Could not copy text: ', err);
- });
- }
- function fallbackCopyTextToClipboard(text) {
- // 1.创建一个可选中元素
- let textArea = document.createElement("textarea");
- textArea.value = text;
- // 2.使用定位,阻止页面滚动
- textArea.style.top = "0";
- textArea.style.left = "0";
- textArea.style.position = "fixed";
- document.body.appendChild(textArea);
- textArea.focus();
- textArea.select();
- try {
- var successful = document.execCommand('copy');
- var msg = successful ? 'successful' : 'unsuccessful';
- if(successful)toast('复制成功')
- console.log('Fallback: Copying text command was ' + msg);
- } catch (err) {
- console.error('Fallback: Oops, unable to copy', err);
- }
- // 3.移除元素
- document.body.removeChild(textArea);
- }
- </script>
- <?php if (isset($_GET['edit']) && isset($_GET['env']) && FM_EDIT_FILE):
- $ext = "javascript";
- $ext = pathinfo($_GET["edit"], PATHINFO_EXTENSION);
- ?>
- <script src="/public/filemanager/js/ace.js"></script>
- <script>
- var editor = ace.edit("editor");
- editor.getSession().setMode( {path:"ace/mode/<?php echo $ext; ?>", inline:true} );
- //editor.setTheme("ace/theme/twilight"); //Dark Theme
- function ace_commend (cmd) { editor.commands.exec(cmd, editor); }
- editor.commands.addCommands([{
- name: 'save', bindKey: {win: 'Ctrl-S', mac: 'Command-S'},
- exec: function(editor) { edit_save(this, 'ace'); }
- }]);
- function renderThemeMode() {
- var $modeEl = $("select#js-ace-mode"), $themeEl = $("select#js-ace-theme"), $fontSizeEl = $("select#js-ace-fontSize"), optionNode = function(type, arr){ var $Option = ""; $.each(arr, function(i, val) { $Option += "<option value='"+type+i+"'>" + val + "</option>"; }); return $Option; },
- _data = {"aceTheme":{"bright":{"chrome":"Chrome","clouds":"Clouds","crimson_editor":"Crimson Editor","dawn":"Dawn","dreamweaver":"Dreamweaver","eclipse":"Eclipse","github":"GitHub","iplastic":"IPlastic","solarized_light":"Solarized Light","textmate":"TextMate","tomorrow":"Tomorrow","xcode":"XCode","kuroir":"Kuroir","katzenmilch":"KatzenMilch","sqlserver":"SQL Server"},"dark":{"ambiance":"Ambiance","chaos":"Chaos","clouds_midnight":"Clouds Midnight","dracula":"Dracula","cobalt":"Cobalt","gruvbox":"Gruvbox","gob":"Green on Black","idle_fingers":"idle Fingers","kr_theme":"krTheme","merbivore":"Merbivore","merbivore_soft":"Merbivore Soft","mono_industrial":"Mono Industrial","monokai":"Monokai","pastel_on_dark":"Pastel on dark","solarized_dark":"Solarized Dark","terminal":"Terminal","tomorrow_night":"Tomorrow Night","tomorrow_night_blue":"Tomorrow Night Blue","tomorrow_night_bright":"Tomorrow Night Bright","tomorrow_night_eighties":"Tomorrow Night 80s","twilight":"Twilight","vibrant_ink":"Vibrant Ink"}},"aceMode":{"javascript":"JavaScript","abap":"ABAP","abc":"ABC","actionscript":"ActionScript","ada":"ADA","apache_conf":"Apache Conf","asciidoc":"AsciiDoc","asl":"ASL","assembly_x86":"Assembly x86","autohotkey":"AutoHotKey","apex":"Apex","batchfile":"BatchFile","bro":"Bro","c_cpp":"C and C++","c9search":"C9Search","cirru":"Cirru","clojure":"Clojure","cobol":"Cobol","coffee":"CoffeeScript","coldfusion":"ColdFusion","csharp":"C#","csound_document":"Csound Document","csound_orchestra":"Csound","csound_score":"Csound Score","css":"CSS","curly":"Curly","d":"D","dart":"Dart","diff":"Diff","dockerfile":"Dockerfile","dot":"Dot","drools":"Drools","edifact":"Edifact","eiffel":"Eiffel","ejs":"EJS","elixir":"Elixir","elm":"Elm","erlang":"Erlang","forth":"Forth","fortran":"Fortran","fsharp":"FSharp","fsl":"FSL","ftl":"FreeMarker","gcode":"Gcode","gherkin":"Gherkin","gitignore":"Gitignore","glsl":"Glsl","gobstones":"Gobstones","golang":"Go","graphqlschema":"GraphQLSchema","groovy":"Groovy","haml":"HAML","handlebars":"Handlebars","haskell":"Haskell","haskell_cabal":"Haskell Cabal","haxe":"haXe","hjson":"Hjson","html":"HTML","html_elixir":"HTML (Elixir)","html_ruby":"HTML (Ruby)","ini":"INI","io":"Io","jack":"Jack","jade":"Jade","java":"Java","json":"JSON","jsoniq":"JSONiq","jsp":"JSP","jssm":"JSSM","jsx":"JSX","julia":"Julia","kotlin":"Kotlin","latex":"LaTeX","less":"LESS","liquid":"Liquid","lisp":"Lisp","livescript":"LiveScript","logiql":"LogiQL","lsl":"LSL","lua":"Lua","luapage":"LuaPage","lucene":"Lucene","makefile":"Makefile","markdown":"Markdown","mask":"Mask","matlab":"MATLAB","maze":"Maze","mel":"MEL","mixal":"MIXAL","mushcode":"MUSHCode","mysql":"MySQL","nix":"Nix","nsis":"NSIS","objectivec":"Objective-C","ocaml":"OCaml","pascal":"Pascal","perl":"Perl","perl6":"Perl 6","pgsql":"pgSQL","php_laravel_blade":"PHP (Blade Template)","php":"PHP","puppet":"Puppet","pig":"Pig","powershell":"Powershell","praat":"Praat","prolog":"Prolog","properties":"Properties","protobuf":"Protobuf","python":"Python","r":"R","razor":"Razor","rdoc":"RDoc","red":"Red","rhtml":"RHTML","rst":"RST","ruby":"Ruby","rust":"Rust","sass":"SASS","scad":"SCAD","scala":"Scala","scheme":"Scheme","scss":"SCSS","sh":"SH","sjs":"SJS","slim":"Slim","smarty":"Smarty","snippets":"snippets","soy_template":"Soy Template","space":"Space","sql":"SQL","sqlserver":"SQLServer","stylus":"Stylus","svg":"SVG","swift":"Swift","tcl":"Tcl","terraform":"Terraform","tex":"Tex","text":"Text","textile":"Textile","toml":"Toml","tsx":"TSX","twig":"Twig","typescript":"Typescript","vala":"Vala","vbscript":"VBScript","velocity":"Velocity","verilog":"Verilog","vhdl":"VHDL","visualforce":"Visualforce","wollok":"Wollok","xml":"XML","xquery":"XQuery","yaml":"YAML","django":"Django"},"fontSize":{8:8,10:10,11:11,12:12,13:13,14:14,15:15,16:16,17:17,18:18,20:20,22:22,24:24,26:26,30:30}};
- if(_data && _data.aceMode) { $modeEl.html(optionNode("ace/mode/", _data.aceMode)); }
- if(_data && _data.aceTheme) { var lightTheme = optionNode("ace/theme/", _data.aceTheme.bright), darkTheme = optionNode("ace/theme/", _data.aceTheme.dark); $themeEl.html("<optgroup label=\"Bright\">"+lightTheme+"</optgroup><optgroup label=\"Dark\">"+darkTheme+"</optgroup>");}
- if(_data && _data.fontSize) { $fontSizeEl.html(optionNode("", _data.fontSize)); }
- $modeEl.val( editor.getSession().$modeId );
- $themeEl.val( editor.getTheme() );
- $fontSizeEl.val(12).change(); //set default font size in drop down
- }
- $(function(){
- renderThemeMode();
- $(".js-ace-toolbar").on("click", 'button', function(e){
- e.preventDefault();
- let cmdValue = $(this).attr("data-cmd"), editorOption = $(this).attr("data-option");
- if(cmdValue && cmdValue != "none") {
- ace_commend(cmdValue);
- } else if(editorOption) {
- if(editorOption == "fullscreen") {
- (void 0!==document.fullScreenElement&&null===document.fullScreenElement||void 0!==document.msFullscreenElement&&null===document.msFullscreenElement||void 0!==document.mozFullScreen&&!document.mozFullScreen||void 0!==document.webkitIsFullScreen&&!document.webkitIsFullScreen)
- &&(editor.container.requestFullScreen?editor.container.requestFullScreen():editor.container.mozRequestFullScreen?editor.container.mozRequestFullScreen():editor.container.webkitRequestFullScreen?editor.container.webkitRequestFullScreen(Element.ALLOW_KEYBOARD_INPUT):editor.container.msRequestFullscreen&&editor.container.msRequestFullscreen());
- } else if(editorOption == "wrap") {
- let wrapStatus = (editor.getSession().getUseWrapMode()) ? false : true;
- editor.getSession().setUseWrapMode(wrapStatus);
- } else if(editorOption == "help") {
- var helpHtml="";$.each(window.config.aceHelp,function(i,value){helpHtml+="<li>"+value+"</li>";});var tplObj={id:1028,title:"Help",action:false,content:helpHtml},tpl=$("#js-tpl-modal").html();$('#wrapper').append(template(tpl,tplObj));$("#js-ModalCenter-1028").modal('show');
- }
- }
- });
- $("select#js-ace-mode, select#js-ace-theme, select#js-ace-fontSize").on("change", function(e){
- e.preventDefault();
- let selectedValue = $(this).val(), selectionType = $(this).attr("data-type");
- if(selectedValue && selectionType == "mode") {
- editor.getSession().setMode(selectedValue);
- } else if(selectedValue && selectionType == "theme") {
- editor.setTheme(selectedValue);
- }else if(selectedValue && selectionType == "fontSize") {
- editor.setFontSize(parseInt(selectedValue));
- }
- });
- });
- </script>
- <?php endif; ?>
- <div id="snackbar"></div>
- <script>
- function showLoading() {
- $('#loadingMask').show();
- console.log('showLoading')
- }
- function hideLoading() {
- $('#loadingMask').hide();
- console.log('hideLoading')
- }
- </script>
- </body>
- </html>
- <?php
- }
- /**
- * Show image
- * @param string $img
- */
- function fm_show_image($img)
- {
- $modified_time = gmdate('D, d M Y 00:00:00') . ' GMT';
- $expires_time = gmdate('D, d M Y 00:00:00', strtotime('+1 day')) . ' GMT';
- $img = trim($img);
- $images = fm_get_images();
- $image = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAEElEQVR42mL4//8/A0CAAQAI/AL+26JNFgAAAABJRU5ErkJggg==';
- if (isset($images[$img])) {
- $image = $images[$img];
- }
- $image = base64_decode($image);
- if (function_exists('mb_strlen')) {
- $size = mb_strlen($image, '8bit');
- } else {
- $size = strlen($image);
- }
- if (function_exists('header_remove')) {
- header_remove('Cache-Control');
- header_remove('Pragma');
- } else {
- header('Cache-Control:');
- header('Pragma:');
- }
- header('Last-Modified: ' . $modified_time, true, 200);
- header('Expires: ' . $expires_time);
- header('Content-Length: ' . $size);
- header('Content-Type: image/png');
- echo $image;
- exit;
- }
- /**
- * Language Translation System
- * @param string $txt
- * @return string
- */
- function lng($txt) {
- global $lang;
- // English Language
- $tr['en']['AppName'] = 'Tiny File Manager';
- $tr['en']['AppTitle'] = '文件管理器';
- $tr['en']['Login'] = '登录';
- $tr['en']['Username'] = '用户名';
- $tr['en']['Password'] = '密码';
- $tr['en']['Logout'] = '登出';
- $tr['en']['Move'] = '移动';
- $tr['en']['Copy'] = '复制';
- $tr['en']['Save'] = '保存';
- $tr['en']['SelectAll'] = '全选';
- $tr['en']['UnSelectAll'] = '取消全选';
- $tr['en']['File'] = '文件';
- $tr['en']['Back'] = '返回';
- $tr['en']['Size'] = '大小';
- $tr['en']['Perms'] = '权限';
- $tr['en']['Modified'] = '修改';
- $tr['en']['Owner'] = '拥有者';
- $tr['en']['Search'] = '查找';
- $tr['en']['NewItem'] = '新建';
- $tr['en']['Folder'] = '文件夹';
- $tr['en']['Delete'] = '删除';
- $tr['en']['Rename'] = '重名命';
- $tr['en']['CopyTo'] = '复制到';
- $tr['en']['DirectLink'] = '复制链接';
- $tr['en']['UploadingFiles'] = '上传文件';
- $tr['en']['ChangePermissions'] = '修改权限';
- $tr['en']['Copying'] = '复制中';
- $tr['en']['CreateNewItem'] = '创建项目';
- $tr['en']['Name'] = '名称';
- $tr['en']['AdvancedEditor'] = '高级编辑';
- $tr['en']['RememberMe'] = '记住账号';
- $tr['en']['Actions'] = '执行';
- $tr['en']['Upload'] = '上传';
- $tr['en']['Cancel'] = '取消';
- $tr['en']['InvertSelection'] = '反转选择';
- $tr['en']['DestinationFolder'] = '目标文件夹';
- $tr['en']['ItemType'] = '项目类型';
- $tr['en']['ItemName'] = '项目名';
- $tr['en']['CreateNow'] = '立即建立';
- $tr['en']['Download'] = '下载';
- $tr['en']['Open'] = '打开';
- $tr['en']['UnZip'] = '解压';
- $tr['en']['UnZipToFolder'] = '解压到文件夹';
- $tr['en']['Edit'] = '编辑';
- $tr['en']['NormalEditor'] = '普通编辑';
- $tr['en']['BackUp'] = '返回上一页';
- $tr['en']['SourceFolder'] = '源文件夹';
- $tr['en']['Files'] = '目录';
- $tr['en']['Move'] = '移动';
- $tr['en']['Change'] = '变化';
- $tr['en']['Settings'] = '设置';
- $tr['en']['Language'] = '语言';
- $tr['en']['MemoryUsed'] = '使用的内存';
- $tr['en']['PartitionSize'] = '分区大小';
- $tr['en']['ErrorReporting'] = '错误报告';
- $tr['en']['ShowHiddenFiles'] = '显示隐藏文件';
- $tr['en']['Full size'] = '总大小';
- $tr['en']['Help'] = '帮助';
- $tr['en']['Free of'] = '硬盘大小';
- $tr['en']['Preview'] = '查看';
- $tr['en']['Help Documents'] = '帮助文档';
- $tr['en']['Report Issue'] = '报告问题';
- $tr['en']['Generate'] = '生成';
- $tr['en']['FullSize'] = '总大小';
- $tr['en']['FreeOf'] = '硬盘大小';
- $tr['en']['CalculateFolderSize']= '计算文件夹大小';
- $tr['en']['ProcessID'] = '进程ID';
- $tr['en']['Created'] = '创建';
- $tr['en']['HideColumns'] = '隐藏权限/所有者列';
- $tr['en']['Folder is empty'] = '文件夹空';
- $tr['en']['Check Latest Version'] = '查看最新版本';
- $tr['en']['Generate new password hash'] = '生成新的密码哈希';
- $tr['en']['You are logged in'] = '您已登录';
- $tr['en']['Login failed. Invalid username or password'] = '登录失败。 用户名或密码无效';
- $tr['en']['password_hash not supported, Upgrade PHP version'] = 'password_hash不支持,升级PHP版本';
- $i18n = fm_get_translations($tr);
- $tr = $i18n ? $i18n : $tr;
- if (!strlen($lang)) $lang = 'en';
- if (isset($tr[$lang][$txt])) return fm_enc($tr[$lang][$txt]);
- else if (isset($tr['en'][$txt])) return fm_enc($tr['en'][$txt]);
- else return "$txt";
- }
- /**
- * Get base64-encoded images
- * @return array
- */
- function fm_get_images()
- {
- return array(
- 'favicon' => 'Qk04AgAAAAAAADYAAAAoAAAAEAAAABAAAAABABAAAAAAAAICAAASCwAAEgsAAAAAAAAAAAAAIQQhBCEEIQQhBCEEIQQhBCEEIQ
- QhBCEEIQQhBCEEIQQhBCEEIQQhBHNO3n/ef95/vXetNSEEIQQhBCEEIQQhBCEEIQQhBCEEc07ef95/3n/ef95/1lohBCEEIQQhBCEEIQQhBCEEIQ
- RzTt5/3n8hBDFG3n/efyEEIQQhBCEEIQQhBCEEIQQhBHNO3n/efyEEMUbef95/IQQhBCEEIQQhBCEEIQQhBCEErTVzTnNOIQQxRt5/3n8hBCEEIQ
- QhBCEEIQQhBCEEIQQhBCEEIQQhBDFG3n/efyEEIQQhBCEEIQQhBCEEIQQhBCEEIQQxRt5/3n+cc2stIQQhBCEEIQQhBCEEIQQhBCEEIQQIIZxz3n
- /ef5xzay0hBCEEIQQhBCEEIQQhBCEEIQQhBCEEIQQhBDFG3n/efyEEIQQhBCEEIQQhBCEEIQQhBK01c05zTiEEMUbef95/IQQhBCEEIQQhBCEEIQ
- QhBCEEc07ef95/IQQxRt5/3n8hBCEEIQQhBCEEIQQhBCEEIQRzTt5/3n8hBDFG3n/efyEEIQQhBCEEIQQhBCEEIQQhBKUUOWfef95/3n/ef95/IQ
- QhBCEEIQQhBCEEIQQhBCEEIQQhBJRW3n/ef95/3n8hBCEEIQQhBCEEIQQhBCEEIQQhBCEEIQQhBCEEIQQhBCEEIQQhBCEEIQQAAA=='
- );
- }
- ?>
|