1
0
mirror of https://github.com/prasathmani/tinyfilemanager.git synced 2025-07-14 22:06:19 +02:00

159 Commits

Author SHA1 Message Date
4777022e13 Update SECURITY.md 2024-09-16 11:17:33 +05:30
0f58c2ca65 Add powershell file extension to text format for opening in editor. () 2024-09-10 03:39:29 +05:30
b602dcd172 Fix typos. () 2024-08-04 12:08:43 +05:30
1bcc240119 Added missing translatable string. Update pt-br translation. () 2024-07-05 04:43:26 +05:30
8b330b75a4 Update default font size to in jQuery initialization () 2024-06-24 08:13:07 +05:30
f120daa607 Update README.md 2024-06-06 09:23:44 +05:30
e27e1abeb4 remove email address 2024-06-06 09:20:20 +05:30
a4d96e0eaf Add JSON Parse Error Handling in Upload Script ()
* Add JSON Parse Error Handling in Upload Script

* Update tinyfilemanager.php

* Update tinyfilemanager.php
2024-05-31 09:45:09 +05:30
843e240757 Update tinyfilemanager.php 2024-05-28 06:50:00 +05:30
ecec756b71 Update tinyfilemanager.php 2024-05-28 04:51:37 +05:30
8366e1bc29 Expanded the list of files recognized as compressed () 2024-05-27 09:29:54 +05:30
d8fceac7dd Fix () 2024-05-27 09:27:33 +05:30
a306f4f1f7 Add --no-cache to 'apk add' command in order to reduce docker image size () 2024-05-26 10:39:06 +05:30
a1ae0fa729 fix: Does not respect directory tree while uploading a folder containing sub-folders () 2024-05-01 10:01:27 +05:30
ca4b1b1743 Disable excluded extension name from viewing () 2024-03-25 11:09:24 +05:30
8e87afae5b Fix wrong phpdoc of print_external() () 2023-09-14 15:05:36 +05:30
43063e4746 Update tinyfilemanager.php ()
changing String "Filter" to "Search"
2023-08-28 12:29:45 +05:30
47359d3f4e Update translation.json ()
Updated Dutch translation
2023-08-11 01:14:37 +05:30
eb8f3d80bc random_bytes() only for >PHP7 () 2023-06-29 07:31:24 +05:30
f380478197 Typo & make text bold ()
* Fix typo

* Make text bold for consistency

Also dropping the plural 's'
2023-05-16 08:17:43 +05:30
f7a2f77008 reduce feof() calls ()
micro-optimization: when doing large file copies, this will reduce the number of feof() calls. for example, if copying 100MB, this will save approximately 25,599 feof() calls (255 feof() calls for every MB) - also feofs() may do an actual syscall, and syscalls are relatively expensive/time-consuming.
2023-05-15 09:53:25 +05:30
dabc4ea36e Fix highlightjs_style in config.php being ignored ()
highlightjs_style variable is being used before config.php gets parsed, so preview style is always vs. This PR fixes that by moving config.php parsing to be before external resource calls.
2023-05-11 09:55:15 +05:30
7ec19c1659 Resize preview image and implement zoom in/out ()
* Resize preview image and implement zoom in/out

* Remove redundant class name
2023-05-03 14:11:59 +05:30
8486c7a240 Add configurable path display modes for better privacy and clarity () 2023-04-26 20:46:52 +05:30
8194249b66 login (Redirecting to Main domain of website instead of tfm.php) fix ()
When logged in it takes to the website's main URL. For example, if I have tfm in www.example.com/tfm/index.php (index.php is tfm) then after logging in it redirects to www.example.com and then have to press back on the browser then it takes to www.example.com/tfm/index.php
2023-04-24 07:00:47 +05:30
da77df785a Fix typo. () 2023-04-23 19:59:23 +05:30
00541fc469 Fix upload of existing files () 2023-04-21 19:21:31 +05:30
7ca87c9163 added bengali translation () 2023-04-21 10:06:09 +05:30
f6a93653be use stream_copy_to_stream ()
* use stream_copy_to_stream

it's simpler, and should be faster.
For example, stream_copy_to_stream can use sendfile ( https://man7.org/linux/man-pages/man2/sendfile.2.html ) on operating systems supporting it, which is faster and use less RAM than fread()+fwrite() (because it avoids copying data to/from userland, doing the copy entirely in-kernel~)

* fix loop early return, and workaround bug

* use feof

ref https://github.com/prasathmani/tinyfilemanager/issues/1016#issuecomment-1502081506
2023-04-21 10:05:45 +05:30
85f35bc28f Check if posix_getpwuid/posix_getgrgid calls were successful () 2023-04-21 10:03:20 +05:30
3a90a5916a tell git to always commit .php in unix-newlines ()
so hopefully we don't get a repeat of https://github.com/prasathmani/tinyfilemanager/pull/994#issuecomment-1502035505
2023-04-11 07:51:47 +05:30
6a6eb8abec Prevent logout issue after page was cached ()
Logout may not work otherwise, browser reloads cached page from disk instead of sending GET request ?logout=1 to server.
2023-03-31 04:16:23 +05:30
bf024c7c84 Update tinyfilemanager.php 2023-03-17 10:22:19 +05:30
d705da604c Update Romanian translations () 2023-02-26 21:18:19 +05:30
94f1c92d80 publish additional docker tags () 2023-02-22 13:06:26 +05:30
bbb2114918 Update README.md 2023-02-22 07:20:52 +05:30
e071b2372c Add External CDN resources configurable 2023-02-22 07:16:25 +05:30
ba1b499d2b Allow configuration for strict CSPs and GDPR () 2023-02-22 06:25:35 +05:30
6775bcb176 AceEditor: hide vertical ruler () 2023-02-22 06:24:00 +05:30
4b2aef8737 Added extensions and removed the duplicated entries ()
added new extensions used in different linux/windows environments and removed duplicate entries
2023-02-16 20:54:55 +05:30
1eed63cf1b make upload chunk size configureable ()
nginx supports only 1MB per default
2023-02-16 16:18:40 +05:30
200d9d6d49 Fix french translation ()
Better and native french translation with official terms such as "haché" for hashing, which is the officiel term from PHP.
2023-02-05 10:35:07 +05:30
cddd7eaab0 Deploy path traversal fix ()
Co-authored-by: root <root@chevaliers.lan>
2023-01-25 11:46:20 +05:30
dd1ba6795c Fixes ajax ability to handle requests when auth disabled () 2023-01-25 08:23:45 +05:30
9c4d30d7b5 Fixes couple issues with confirmDailog ()
* Fixes naming for confirmDailog id, otherwise dialog won't work

* Removes destroying form as browser complains that it can't process request from disconnected form
2023-01-25 08:22:27 +05:30
12baf03ef5 Removes sed from Dockerfile ()
They were needed before because they changed example config.php so make it workable.
Now we don't have it and running sed against main file just removes a lot of code
and forces data path for directory
2023-01-24 08:04:37 +05:30
dc529dd590 Fix save settings not working 2023-01-22 02:06:14 +05:30
69ccd952fc Bug fix: Delete confirm dialog will work wrong aflter cancel. ()
* Bug fix: Only delete first file/directory when clicking the delete button multiple times and canceling.

* Add variable name for delete dialog
2023-01-19 21:41:48 +05:30
69495db9b4 Subfolder links fix ()
Download and Direct link problems when using with a subfolder, possible simple solution.
2023-01-19 21:41:00 +05:30
313acf1b78 Update README.md 2023-01-13 11:09:18 +05:30
ac672b832c update screenshot 2022-12-03 12:07:18 +05:30
789b98f136 Download and Direct link problems when using with a subfolder. 2022-12-03 06:17:55 +00:00
97fd394a0f Update README.md 2022-12-02 08:29:37 +05:30
8f2f65b9fc Bug Fix , , 2022-12-02 02:43:24 +00:00
31b988db79 Translation supplement ()
* update zh-cn lang

* Translation supplement

* update zh-cn lang
2022-11-30 16:40:57 +05:30
d09cc2f445 Complete all Chinese translations () 2022-11-30 11:01:57 +05:30
5a00707890 Update tinyfilemanager.php () 2022-11-27 20:59:39 +05:30
cfb9a57d5e Fix the problem of login failure when $root_url is defined ()
Fix the problem that `FM_ROOT_URL` and `$_SERVER['REQUEST_URI']` are repeated, causing login redirection to fail when `$root_url` is defined
2022-11-26 18:52:34 +05:30
652c05914f Update FUNDING.yml 2022-11-25 16:38:42 +05:30
e30ec1dfd2 update download buffer and fix 2022-11-25 07:00:19 +00:00
610cea8ecd Fix - , , , , 2022-11-25 03:09:46 +00:00
d4019e6e10 Update Italian translations () 2022-11-23 22:10:29 +05:30
f20d3e9e06 Fix phpdoc types () 2022-11-23 22:07:04 +05:30
c4ab436f6d Complete French translation () 2022-11-22 06:27:33 +05:30
e5c78e8ab9 cosmetic changes and dark theme color update 2022-11-20 19:01:08 +05:30
f8cedbcf59 Fix Security related issues 2022-11-20 16:59:29 +05:30
df80b73436 Refactor Code and Update Doc 2022-11-20 15:04:25 +05:30
8de16a4c8a Major update on security, improved UI and bug fix. 2022-11-19 19:55:39 +00:00
4d8d4a3aba Update tinyfilemanager.php 2022-11-07 22:48:15 +05:30
fce0f5bacb Fix warning message 2022-11-07 22:42:07 +05:30
59c6b9b26a Downloading file - PHP warning loop "Permission denied" ()
* Bugfix: Stop looping error when downloading a file with no access.

* Delete .history directory

ignore .history
2022-11-07 22:24:56 +05:30
be49a13b8e Fixes advanced search not working. ()
Fix 
2022-11-07 22:23:01 +05:30
2c0e6d216e Update tinyfilemanager.php () 2022-10-31 21:19:21 +05:30
805308a013 remove latest version checker 2022-09-01 16:25:29 +05:30
2a2d81ce78 Removes php ext installs as their are already installed in base () 2022-08-31 11:23:19 +05:30
2eb00ab3de Adds json mime type as text type to allow edit json files () 2022-08-25 09:50:39 +05:30
74727fe48a Add webm to videos () 2022-08-06 11:17:47 +05:30
6190ae69e9 word change mistranslated in Spanish () 2022-07-14 09:01:59 +05:30
3a3033bdce Added .yml, .yaml and .toml extensions. ()
These are common config file extensions.
2022-07-14 07:16:02 +05:30
afe1227caa Update russia translate and fix bug ()
* fix bug

if $calc_folder is enabled and there are insufficient permissions for one of the subfolders, then "PHP Fatal error: Uncaught RuntimeException: SplFileInfo::getSize()"

* lng() update

added lng() and delete unesed

* update russia translate
2022-07-14 07:14:54 +05:30
cda40e22f1 More accurate ip recognition () () 2022-07-14 07:13:49 +05:30
b24887d4fd Removed unused function ()
To fix: Undefined constant 'FM_EXTENSION'
2022-07-07 12:01:02 +05:30
17de8af81b PHP "divide by zero" error when unzipping 0 byte (very small) .zip files 2022-06-29 02:14:35 +00:00
50ccd29623 Fix advanced search issue for read-only user ()
$_POST['type']=="search" not reachable if FM_READONLY is true
2022-05-27 11:06:25 +05:30
04c1d45b5f resolve sorting issues, keep back button at top () 2022-05-05 03:51:21 +05:30
ca94f23c47 Update tinyfilemanager.php 2022-04-18 12:51:55 +05:30
a65f8ff8b5 fix download Content-Type header () 2022-04-11 13:39:51 +05:30
13b2bd0164 Add missing lines for German translation ()
* added missing lines for German translation

* small correction
2022-04-07 22:16:43 +05:30
ccf18947c8 Add Galician language ()
Add Galician language - gl
2022-03-20 12:48:48 +05:30
d4d620fe66 Fix Dutch translation ()
* Fix Dutch translation

* fix dutch translation
2022-03-20 12:47:03 +05:30
4d7078829d Update translation.json () 2022-03-07 08:47:58 +05:30
7bd9483728 Fix incorrect path of the version svg () 2022-03-06 19:38:08 +05:30
179e13c4a6 Add danish language () 2022-02-21 10:47:37 +05:30
4ff141bb15 Update translation.json () 2022-02-14 08:24:38 +05:30
9b2bb18acb Optimized and refactored fm_get_directorysize() function, and added validation. () 2022-02-12 23:15:38 +05:30
7103691048 Fix - typo error 2022-02-12 13:54:22 +05:30
85821736c0 Update version 2022-02-12 13:48:19 +05:30
e474ade92b Client IP behind proxy ()
Function added for IP filtering when the filemanager is hosted behind a web proxy.

I've added a function for this to the file, not sure how else to implement it since everything is one file.
2022-02-12 13:28:26 +05:30
ad30a3a1f3 Add Global Readonly ()
Added a global readonly variable that will force readonly mode both when
not using the auth system and for all users if the auth system is being
used.

Co-authored-by: Prasath Mani <prasathmani@users.noreply.github.com>
2022-02-12 13:22:56 +05:30
bb1d1d3801 added name of the file being edited ()
added name of the file being edited and a back button in a better location
2022-02-12 13:17:35 +05:30
c3a2f1d604 Chunked file upload ()
Removes any PHP or server-side file-upload limits by using file chunks
2022-02-12 13:16:07 +05:30
154947ef83 apply fix to path traversal vulnerability ()
Co-authored-by: João Maurício <joao.goncalves.mauricio@pwc.com>
2022-02-12 10:34:05 +05:30
bc9096fad3 Update translation.json ()
Improved Romanian translation.
2022-01-28 07:44:37 +05:30
3d28d8cb8e Update tinyfilemanager.php ()
Changed "Folder is empty" message to be language-specific.
2022-01-28 07:43:56 +05:30
9b85951cfc fix "400 bad request" when saving files () 2022-01-21 08:06:27 +05:30
d125c6736b Add Romanian language ()
* Add Romanian language

Add Romanian language w/o diacrytics!
Traducere & adaptare in limba romana fara diacritice!

* Fix typo's
2021-12-21 17:45:58 +05:30
f8d4d9cb17 added Dutch translation ()
* added Dutch translation

* fix typo
2021-12-21 11:01:36 +05:30
08cb4b0fce Fix a non well formatted numeric value encountered & Notice: Undefined offset in fm_get_filesize() ()
For non `well formatted numeric value encountered`, see 
For `Notice: Undefined offset 9` (current implementation result) see: https://3v4l.org/1qHit#v5.0.0
For new impementation result, see: https://3v4l.org/d0UBh#v5.0.0
2021-12-13 10:15:09 +05:30
95d41a9518 Just a little fix with missing " in button HTML ()
Its a little html fix- its about 1787 line- the class value it not closed.
```
<button type="button" class="btn btn-sm btn-outline-primary name="Save"
```
changed to:

```
<button type="button" class="btn btn-sm btn-outline-primary" name="Save"
```
2021-12-03 07:16:32 +05:30
6bdc5ccfb3 Update Indonesian translations () 2021-11-22 09:03:41 +05:30
2046bbde72 Patched the RCE ()
I have patched the file upload directory traversal to Authenticated Remote Code Execution Vulnerability.
2021-11-12 08:31:02 +05:30
c1718ff4c5 Vietnamese translation update ()
I have updated the Vietnamese translation under the code "vi" to be more complete.
2021-09-18 09:59:08 +05:30
1db6713019 fix: document docker image name. () 2021-09-05 08:47:26 +05:30
c89e1d18de Update README.md 2021-09-03 11:30:25 +05:30
d401028eb6 Update README.md 2021-09-03 11:18:41 +05:30
f6ac9cc63f Update README.md 2021-09-03 11:14:46 +05:30
a22edfca00 feat: add Dockerfile and auto publish. () 2021-09-03 11:13:23 +05:30
55706b2f8b Adding a Slovenian translation ()
I added a Slovenian translation under the code "sl" and the name "Slovensko".
2021-08-09 20:06:08 +05:30
09e2b9a107 Fix saving of empty files ()
When you have a file without content, for example when you cleared you were unable to save it because of an incorrect if-statement. This is the fix for that problem.
2021-08-06 07:43:22 +05:30
9ee41b14d6 Added some missing translations () 2021-08-02 10:39:37 +05:30
8158333d93 Update tinyfilemanager.php ()
fm_get_file_mimes() was causing errors for unknown extensions as it was causing an error as array element was not defined and return value was never checked.  According to https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types and several other resources,  application/octet-stream is the default value for all other cases. An unknown file type should use this type.   I put a check in there to use that by default so a valid value is always returned.

It might be useful to replace this function with the  built-in PHP function mime_content_type() but that adds some additional dependencies as it does not always work out of the box with PHP.
2021-06-05 11:57:53 +05:30
e843adcf0b Fix function name and add extensions for icons ()
* Set icons for more file extensions

* Fix function name
2021-06-05 08:33:57 +05:30
f182e378e3 PHP8 fix and few other changes () 2021-06-01 10:11:15 +05:30
27d7126767 Typo error fix 2021-05-17 15:05:46 +05:30
a62bb38773 PR update and sync 2021-05-17 12:22:16 +05:30
603f048722 Fix PHP 5.X ()
Arrays cannot be used in "define" functions with PHP versions lower than 7.X
Solution given via my professional account (ArlorNaturalScientific)
2021-05-17 11:59:34 +05:30
442843239c 🌐 Update Korean translation () 2021-05-17 11:58:53 +05:30
b63615a4b8 French translation: sort and complete ()
* French - Apply alpha order

* Add missing translations

* Fix missing help
2021-05-17 11:58:19 +05:30
9d78ee8b01 I added the Hungarian language (translation.json) ()
I added support for the Hungarian language.
2021-05-17 11:57:50 +05:30
9b5d2718ab New translations ()
New translations

Novas Traduções
2021-05-17 11:55:47 +05:30
a38d8e3934 Portuguese, with new translations ()
Portuguese, with new translations

Português, Com novas traduções
2021-05-17 11:55:02 +05:30
db3f4c01ea Added in preferences light or dark theme ()
Added in the preferences option to change the light or dark theme,

Now to change the theme will be in the preferences / settings area, along with other settings, and may even have other themes in the future.
2021-05-17 09:24:45 +05:30
c5d481c5cc Fixed Rename with folder quotes ()
Fixed the Rename functionality to work with folders that contain single quotes in them by calling `addslashes` on the path.
2021-04-30 05:57:10 +05:30
a04567d3ba Fix security issues and 2021-04-22 13:41:35 +05:30
03c3f6d7f9 Fixed 3 sinks which caused XSS in filename ()
Co-authored-by: Vaibhav Shinde <vaibhavkshinde20@gmail.com>
2021-03-22 18:26:55 +05:30
95147f5828 remove decoded php codes and code cleanup 2021-02-24 13:33:57 +05:30
dd9d7c09a2 Feat/mixed changes ()
* remove trailing whitespace

Signed-off-by: ccdd13 <78702084+ccdd13@users.noreply.github.com>

* safe include config.php with __DIR__

* replace doc url for $datetime_format from function.date.php to datetime.format.php

Signed-off-by: ccdd13 <ccdd13@users.noreply.github.com>

* put $auth_users & $readonly_users together

Signed-off-by: ccdd13 <ccdd13@users.noreply.github.com>

* update $datetime_format

Signed-off-by: ccdd13 <ccdd13@users.noreply.github.com>

Co-authored-by: ammm ccdd12 <mamok43076@dashseat.com>
Co-authored-by: ccdd13 <ccdd13@users.noreply.github.com>
2021-02-24 12:37:38 +05:30
a19ff20768 Update vendor CDN versions 2021-02-23 11:47:57 +05:30
b03232775e Added Finnish translation ()
Co-authored-by: Jani Kiviranta <jani.kiviranta@hoop.fi>
2021-01-19 06:37:00 +05:30
ef09231454 Fix file size display in file viewer () 2020-12-23 20:46:00 +05:30
6b06fb2532 Norwegian translation[NO] () 2020-12-22 10:52:43 +05:30
2512330dee Update Indonesia translation () 2020-12-06 10:11:21 +05:30
642cab42cc Update German translation () 2020-12-06 10:10:36 +05:30
c03e601bc3 Update translation.json () 2020-11-11 09:48:26 +05:30
0d0e728c79 Update italian translation () 2020-10-23 05:01:18 +05:30
530055df08 Add: Mongolian (cyrillic) language added. ()
Co-authored-by: Davaadorj.U <davaadorju@gmail.com>
2020-09-10 19:57:23 +05:30
5d841d6624 Update russian translation ()
* fix(ru): fix russian translation

* style(ru): sort russian translation alphabetically

* feat(ru): update russian translation
2020-08-26 03:57:06 +05:30
211568ff4c fix(actions): creating a backup in FM_ROOT_PATH () 2020-08-26 03:55:13 +05:30
44bedb9be0 Update Catalan translation ()
* Update translation.json

Update Catalan translation

* Update translation.json

* Update translation.json

* Update translation.json
2020-08-12 07:20:14 +05:30
c8fff90634 fix: prevent double write to file () 2020-08-04 14:00:05 +05:30
a6a28a6356 Fix sorting by date and size ()
Based on suggestions in https://github.com/prasathmani/tinyfilemanager/issues/197
but uses data-sort attribute (from DataTable wiki https://datatables.net/examples/advanced_init/html5-data-attributes.html) instead of invisible characters and also distinguishes files and folders, so they stay grouped even after sort.
(I am sorry for my bad English.)
2020-07-20 05:39:47 +05:30
14ed4fdb92 Update french translation ()
I corrected the french translation
2020-07-20 05:38:12 +05:30
65f7dc448d Fixes , Fixes ()
Fixes setting drop down boxes to the current ace editor mode and theme on page load.
2020-07-20 05:37:41 +05:30
fb31a14873 Added Error Message When File Fails to Write ()
Added error checking and message for when file fails to write on the server side.  Before this change if a write failed on the server side it would still present the user with a misleading "Saved Successfully" Message.
2020-07-20 05:36:47 +05:30
c741ae2212 Notice: A non well formed numeric value encountered ()
Eliminates the following PHP warnings when error reporting is turned on:

Notice: A non well formed numeric value encountered in tinyfilemanager.php on line 2443
Notice: A non well formed numeric value encountered in tinyfilemanager.php on line 2444

This happens because PHP floor and round are expecting a (float), not an (int).
2020-06-27 16:02:09 +05:30
e118d650a3 Correct wrong word in Vietnamese language. ()
Co-authored-by: JHuyVu <jhuyvu@gmail.com>
2020-06-21 08:25:28 +05:30
c260601ef6 Czech translation update ()
Added missing expressions and corrected a few inaccuracies.
2020-06-06 06:09:26 +05:30
462566a31b Remove duplicate code block () 2020-06-02 19:27:37 +05:30
0a92002919 if exist include config.php 2020-05-24 17:07:17 +05:30
10 changed files with 2778 additions and 1113 deletions

2
.gitattributes vendored Normal file

@ -0,0 +1,2 @@
*.php text eol=lf
*.json text eol=lf

2
.github/FUNDING.yml vendored

@ -1,5 +1,5 @@
# These are supported funding model platforms
github: prasathmani
patreon: ccpprogrammers
open_collective: tinyfilemanager
ko_fi: tinyfilemanager

41
.github/workflows/PublishDocker.yml vendored Normal file

@ -0,0 +1,41 @@
name: PublishDocker
on:
push:
branches:
- 'master'
tags:
- '**'
jobs:
docker:
runs-on: ubuntu-latest
steps:
- name: Docker meta
id: meta
uses: docker/metadata-action@v4
with:
images: |
${{ secrets.DOCKERHUB_USERNAME }}/tinyfilemanager
tags: |
type=ref,event=branch
type=ref,event=pr
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
- name: Set up QEMU
uses: docker/setup-qemu-action@v1
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
id: docker_build
uses: docker/build-push-action@v2
with:
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}

26
Dockerfile Normal file

@ -0,0 +1,26 @@
# how to build?
# docker login
## .....input your docker id and password
#docker build . -t tinyfilemanager/tinyfilemanager:master
#docker push tinyfilemanager/tinyfilemanager:master
# how to use?
# docker run -d -v /absolute/path:/var/www/html/data -p 80:80 --restart=always --name tinyfilemanager tinyfilemanager/tinyfilemanager:master
FROM php:7.4-cli-alpine
# if run in China
# RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
RUN apk add --no-cache \
libzip-dev \
oniguruma-dev
RUN docker-php-ext-install \
zip
WORKDIR /var/www/html
COPY tinyfilemanager.php index.php
CMD ["sh", "-c", "php -S 0.0.0.0:80"]

@ -1,22 +1,24 @@
# Tiny File Manager
[![Live demo](https://img.shields.io/badge/Live-Demo-brightgreen.svg?style=flat-square)](https://tinyfilemanager.github.io/demo/)
[![Live demo](https://img.shields.io/badge/Help-Docs-lightgrey.svg?style=flat-square)](https://github.com/prasathmani/tinyfilemanager/wiki)
[![GitHub Release](https://img.shields.io/github/release/qubyte/rubidium.svg?style=flat-square)](https://github.com/prasathmani/tinyfilemanager/releases)
[![GitHub License](https://img.shields.io/github/license/prasathmani/tinyfilemanager.svg?style=flat-square)](https://github.com/prasathmani/tinyfilemanager/blob/master/LICENSE)
[![GitHub Release](https://img.shields.io/github/release/prasathmani/tinyfilemanager.svg?style=flat-square)](https://github.com/prasathmani/tinyfilemanager/releases)
[![GitHub License](https://img.shields.io/github/license/prasathmani/tinyfilemanager.svg?style=flat-square)](https://github.com/prasathmani/tinyfilemanager/blob/master/LICENSE)
[![Paypal](https://img.shields.io/badge/Donate-Paypal-lightgrey.svg?style=flat-square)](https://www.paypal.me/prasathmani)
> TinyFileManager is web based file manager and it is a simple, fast and small file manager with a single file, multi-language ready web application for storing, uploading, editing and managing files and folders online via web browser. The Application runs on PHP 5.5+, It allows the creation of multiple users and each user can have its own directory and a build-in support for managing text files with cloud9 IDE and it supports syntax highlighting for over 150+ languages and over 35+ themes.
![GitHub Sponsors](https://img.shields.io/github/sponsors/prasathmani)
> TinyFileManager is web based PHP file manager and it is a simple, fast and small size in single-file PHP file that can be dropped into any folder on your server, multi-language ready web application for storing, uploading, editing and managing files and folders online via web browser. The Application runs on PHP 5.5+, It allows the creation of multiple users and each user can have its own directory and a build-in support for managing text files with cloud9 IDE and it supports syntax highlighting for over 150+ languages and over 35+ themes.
**Caution!** _Avoid utilizing this script as a standard file manager in public spaces. It is imperative to remove this script from the server after completing any tasks._
## Demo
[Demo](https://tinyfilemanager.github.io/demo/)
Login Details : admin/admin@123 | user/12345
[Demo](https://tinyfilemanager.github.io/demo/)
## Documentation
Tinyfilemanager is highly documented on the [wiki pages](https://github.com/prasathmani/tinyfilemanager/wiki).
Tinyfilemanager is highly documented on the [wiki pages](https://github.com/prasathmani/tinyfilemanager/wiki).
[![Tiny File Manager](screenshot.gif)](screenshot.gif)
@ -38,13 +40,16 @@ Default username/password: **admin/admin@123** and **user/12345**.
To enable/disable authentication set `$use_auth` to true or false.
:information_source: Add your own configuration file [config.php](https://tinyfilemanager.github.io/config-sample.txt) in the same folder to use as additional configuration file.
### :loudspeaker: Features
:information_source: To work offline without CDN resources, use [offline](https://github.com/prasathmani/tinyfilemanager/tree/offline) branch
### :loudspeaker: Features
- :cd: Open Source, light and extremely simple
- :iphone: Mobile friendly view for touch devices
- :information_source: Basic features likes Create, Delete, Modify, View, Quick Preview, Download, Copy and Move files
- :arrow_double_up: Ajax Upload, Ability to drag & drop, upload from URL, multiple files upload with file extensions filter
- :information_source: Basic features likes Create, Delete, Modify, View, Download, Copy and Move files
- :arrow_double_up: Ajax Upload, Ability to drag & drop, upload from URL, multiple files upload with file extensions filter
- :file_folder: Ability to create folders and files
- :gift: Ability to compress, extract files (`zip`, `tar`)
- :sunglasses: Support user permissions - based on session and each user root folder mapping
@ -52,16 +57,75 @@ To enable/disable authentication set `$use_auth` to true or false.
- :pencil2: Cloud9 IDE - Syntax highlighting for over `150+` languages, Over `35+` themes with your favorite programming style
- :page_facing_up: Google/Microsoft doc viewer helps you preview `PDF/DOC/XLS/PPT/etc`. 25 MB can be previewed with the Google Drive viewer
- :zap: Backup files and IP blacklist and whitelist
- :mag_right: Search - Search and filter files using `datatable js`
- :mag_right: Search - Search and filter files using `datatable js`
- :file_folder: Exclude folders and files from listing
- :globe_with_meridians: Multi-language(20+) support and for translations `translation.json` is file required
- :globe_with_meridians: Multi-language(32+) support and for translations `translation.json` is file required
- :bangbang: lots more...
## Deploy by Docker
### <a name=license></a>License, Credit
Make sure you have **already installed docker**, [Install reference](https://docs.docker.com/engine/install/)
> **Notice:** Your need an absolute path, and it will be served by tinyfilemanager.
>
> If you want to serve this project at **raspberry pi or another special platform**, you can download project and **build image by yourself**.
You can execute this following commands:
```shell
$ docker run -d -v /absolute/path:/var/www/html/data -p 80:80 --restart=always --name tinyfilemanager tinyfilemanager/tinyfilemanager:master
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
648dfba9c0ff tinyfilemanager/tinyfilemanager:master "docker-php-entrypoi…" 4 minutes ago Up 4 minutes 0.0.0.0:80->80/tcp, :::80->80/tcp tinyfilemanager
```
Access `http://127.0.0.1/` and enter default username and password, then enjoy it.
DockerHub: [https://hub.docker.com/r/tinyfilemanager/tinyfilemanager](https://hub.docker.com/r/tinyfilemanager/tinyfilemanager)
#### How to change config within docker
Origin:
```php
// 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 = '';
```
Modified:
```php
// 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'].'/data';
// 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 = 'data/';
```
Then, change another config what you want, and add a new volume `-v /absolute/path/index.php:/var/www/html/index.php` in `docker run` command, like this:
```shell
$ docker run -d -v /absolute/path:/var/www/html/data -v /absolute/path/index.php:/var/www/html/index.php -p 80:80 --restart=always --name tinyfilemanager tinyfilemanager/tinyfilemanager:master
```
#### Stop running
If you want to stop a running docker service, or you want to restart a service, you should stop it first, or you got `docker: Error response from daemon: Conflict. The container name "/tinyfilemanager" is already in use by container ...` problem. You can execute this command:
```shell
$ docker rm -f tinyfilemanager
```
### <a name=license></a>License, Credit
- Available under the [GNU license](https://github.com/prasathmani/tinyfilemanager/blob/master/LICENSE)
- Original concept and development by github.com/alexantr/filemanager
- CDN Used - _jQuery, Bootstrap, Font Awesome, Highlight js, ace js, DropZone js, ekko-lightbox js, and DataTable js_
- CDN Used - _jQuery, Bootstrap, Font Awesome, Highlight js, ace js, DropZone js, and DataTable js_
- To report a bug or request a feature, please file an [issue](https://github.com/prasathmani/tinyfilemanager/issues)
- [Contributors](https://github.com/prasathmani/tinyfilemanager/wiki/Authors-and-Contributors)

@ -4,7 +4,7 @@
The team takes security bugs seriously. We appreciate your efforts to responsibly disclose your findings, and will make every effort to acknowledge your contributions.
To report a security issue, email ccpprogrammers[at]gmail.com and include the word "SECURITY" in the subject line.
To report a security issue, email ccpprogrammers[at]gmail[dot]com and include the word "SECURITY" in the subject line.
The team will send a response indicating the next steps in handling your report. After the initial reply to your report you will be kept informed of the progress towards a fix and full announcement.

@ -1,133 +0,0 @@
<?php
/*
#################################################################################################################
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;
// 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(
'admin' => '$2y$10$/K.hjNr84lLNDt8fTXjoI.DBp6PpeyoJ.mGwrrLuCZfAwfSAGqhOW', //admin@123
'user' => '$2y$10$Fg6Dz8oH9fPoZ2jJan5tZuv6Z4Kp7avtQ9bDfrdRntXtPeiMAZyGO' //12345
);
//set application theme
//options - 'light' and 'dark'
$theme = 'light';
// Readonly users
// e.g. array('users', 'guest', ...)
$readonly_users = array(
'user'
);
// 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 = array();
// 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 = 'd.m.y 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;
// max upload file size
$max_upload_size_bytes = 2048;
// 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
);
?>

Binary file not shown.

Before

(image error) Size: 209 KiB

After

(image error) Size: 2.4 MiB

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff