From: Jerome Jutteau Date: Mon, 18 May 2015 12:29:45 +0000 (+0200) Subject: move documentation to README.md X-Git-Tag: 1.1~76^2 X-Git-Url: https://git.p6c8.net/jirafeau_mojo42.git/commitdiff_plain/9093d4ec5187ecd2638bae1f2f9decce6b501642?ds=inline;hp=2fa05274bd24134ecf87bda06ce2626483ec3513 move documentation to README.md Signed-off-by: Jerome Jutteau --- diff --git a/README.md b/README.md new file mode 100644 index 0000000..c76c287 --- /dev/null +++ b/README.md @@ -0,0 +1,185 @@ +# Introduction + +Welcome to the official Jirafeau project, an [Open-Source software](http://en.wikipedia.org/wiki/Open-source_software). + +Jirafeau is a web site permitting to upload a file in a simple way and give an unique link to it. + +A demonstration of the latest version is available on [jirafeau.net](http://jirafeau.net/) + +![Screenshot1](http://i.imgur.com/TPjh48P.png) + +**Main features**: +- One upload => One download link & One delete linkp +- Send any large files (thanks to HTML5) +- NO database, only use basic PHP +- Shows progression: speed, percentage and remaining upload time +- Preview content in browser (if possible) +- Optional Password protection (for uploading or downloading) +- Time limitation +- Option to self-destruct after reading +- Simple language support :gb: :fr: :de: :it: +- Small administration interface +- File level [Deduplication](http://en.wikipedia.org/wiki/Data_deduplication) for storage optimization +- A basic Terms Of Service which can be adapted to your needs +- Shortened URLs using base 64 encoding +- API interface +- Optional data encryption +- Skins +... + +Jirafeau is a fork of the original project [Jyraphe](http://home.gna.org/jyraphe/) based on the 0.5 (stable version) with a **lot** of modifications. + +As it's original project, Jirafeau is made in the [KISS](http://en.wikipedia.org/wiki/KISS_principle) way (Keep It Simple, Stupid). + +Jirafeau project won't evolve to a file manager and will focus to keep a very few dependencies + +# Screenshots + +Here are some screenshots: +- [Installation part 1](http://i.imgur.com/hmpT1eN.jpg) +- [Installation part 2](http://i.imgur.com/2e0UGKE.jpg) +- [Installation part 3](http://i.imgur.com/ofAjLXh.jpg) +- [Installation part 4](http://i.imgur.com/WXqnfqJ.jpg) +- [Upload 1](http://i.imgur.com/SBmSwzJ.jpg) +- [Upload 2](http://i.imgur.com/wzPkb1Z.jpg) +- [Upload 3](http://i.imgur.com/i6n95kv.jpg) +- [Upload 4](http://i.imgur.com/P2oS1MY.jpg) + +# Installation +- [Download](https://gitlab.com/mojo42/Jirafeau/repository/archive.zip) the last version of Jirafeau from Gitlab +- Upload files on your web server +- Don't forget to set owner of uploaded files if you need to +- Get your web browser and go to you install location (e.g. ```http://your-web-site.org/jirafeau/```) and follow instructions +- Some options are not configured from the minimal installation wizard, you may take a look at option documentation in ```lib/config.original.php``` and customize your ```lib/config.local.php``` + +# Security + +```var``` directory contain all files and links. It is randomly named to limit access but you may add better protection to prevent un-authorized access to it. +You have several options: +- Configure a ```.htaccess``` +- Move var folder to a place on your server which can't be directly accessed +- Disable automatic listing on your web server config or place a index.html in var's sub-directory (this is a limited solution) + +If you are using Apache, you can add the following lineto your configuration to prevent people to access to your ```var``` folder: + +```RedirectMatch 301 ^/var-.* http://my.service.jirafeau ``` + +You should also remove un-necessessary write access once the installation is done (ex: configuration file). + +An other obvious basic security is to let access users to the site by https. + +# Few notes about server side encryption + +Data encryption can be activated in options. This feature makes the server encrypt data and send the decryt key to the user (inside download URL). +The decrypt key is not stored on the server so if you loose an url, you won't be able to retrieve file content. +In case of security troubles on the server, attacker won't be able to access files. + +By activating this feature, you have to be aware of few things: +- Data encryption has a cost (cpu) and it takes more time for downloads to complete once file sent. +- During the download, the server will decrypt on the fly (and use resource). +- This feature needs to have the mcrypt php module. +- File de-duplication will stop to work (as we can't compare two encrypted files). +- Be sure you server do not log client's requests. +- Don't forget to activate https. + +In a next step, encryption will be made by the client (in javascript), see issue #10. + +# FAQ + +### Can I add a new language in Jirafeau ? + +Of-course ! Translations are easy to make and no technical knowledge is required. + +Simply go to [Jirafeau's Weblate](https://hosted.weblate.org/projects/jirafeau/master/) + +If you want to add a new language in the list, feel free to contact us or leave a comment in #9 + +### How do I upgrade my Jirafeau ? + +If you have installed Jirafeau using git, it's pretty simple: just make a git pull and chown/chmod files who have the owner changed. + +If you have installed Jirafeau just by uploading files on your server, you can take the [last version](https://gitlab.com/mojo42/Jirafeau/repository/archive.zip), overwrite files and chown/chmod files if needed. + +After upgrading, you can compare your ```lib/config.local.php``` and ```lib/config.original.php``` to see if new configuration items are available. + +If you have some troubles: +- It should probably come from your ```lib/config.local.php``` (configuration syntax may have changed). Just compare it with ```lib/config.original.php``` +- Check owner/permissions of your files. + +Anyway you should off-course make a backup of your current installation before doing anything :) + +### How can I limit upload access ? + +There are two ways to limit upload access (but not download): +- you can set one or more passwords in order to access the upload interface, or/and +- you can configure a list of authorized IP ([CIDR notation](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing#CIDR_notation)) which are allowed to access to the upload page + +Check documentation of ```upload_password``` and ```upload_ip``` parameters in [lib/config.original.php](https://gitlab.com/mojo42/Jirafeau/blob/master/lib/config.original.php). + +### I found a bug, what should I do ? + +Feel free to open a bug in the [gitlab's issues](https://gitlab.com/mojo42/Jirafeau/issues) + +### How to set maximum file size ? + +If your browser supports HTML5 file API, you can send files as big as you want. + +For browsers who does not support HTML5 file API, the limitation come from PHP configuration. +You have to set [post_max_size](http://php.net/manual/en/ini.core.php#ini.post-max-size) and [upload_max_filesize](http://php.net/manual/en/ini.core.php#ini.upload-max-filesize) in your php configuration. + +If you don't want to allow unlimited upload size, you can still setup a maximal file size in Jirafeau's setting (see ```maximal_upload_size``` in your configuration) + +### How can I edit an option ? + +Documentation of all default options are located in [lib/config.original.php](https://gitlab.com/mojo42/Jirafeau/blob/master/lib/config.original.php) +If you want to change an option, just edit your ```lib/config.local.php``` + +### How can I access the admin interface ? + +Just go to ```/admin.php``` + +### How can I use the scripting interface ? + +Simply go to ```/script.php``` with your web browser. + +### My downloads are incomplete or my uploads fails + +Be sure your PHP installation is not using safe mode, it may cause timeouts. + +### Why forking ? + +The original project seems not to be continued anymore and I prefer to add more features and increase security from a stable version. + +### What can we expect in the future ? + +Check [issues](https://gitlab.com/mojo42/Jirafeau/issues) to check open bugs and incoming new stuff :) + +### What is the Jirafeau's license ? + +Jirafeau is licensed under [AGPLv3](https://gitlab.com/mojo42/Jirafeau/blob/master/COPYING) + +### How do I modify the TOS (terms of use) ? + +Just edit ```tos.php``` and configure ```$org``` and ```$contact``` variables. + +### What about this file deduplication thing ? + +Jirafeau use a very simple file level deduplication for storage optimization. + +This mean that if some people upload several times the same file, this will only store one time the file and increment a counter. + +If someone use his delete link or an admin cleans expired links, this will decrement the counter corresponding to the file. + +If the counter falls to zero, the file is destroyed. + +### What is the difference between "delete link" and "delete file and links" in admin interface ? + +As explained in the previous question, files with the same md5 hash are not duplicated and a reference counter stores the number of links pointing to a single file. +So: +- The button "delete link" will delete the reference to the file but might not destroy the file. +- The button "delete file and links" will delete all references pointing to the file and will destroy the file. + +### How to contact someone from Jirafeau ? + +Feel free to create an issue if you found a bug, else you can send an email at j.jutteau A.T gmail .DOT. com + diff --git a/README.txt b/README.txt deleted file mode 100644 index 6d9da0c..0000000 --- a/README.txt +++ /dev/null @@ -1,12 +0,0 @@ -Any project would be sad without it's README file :) - -Jirafeau is a web site permitting to upload a file in a simple way and give -an unique link to it. - -Jirafeau is an Open-Source project under AGPL v3 license (see COPYING file) - -To install Jirafeau project, just open your browser and go to /install.php - -For more informations on Jirafeau project, go to it's web page: - -https://gitlab.com/mojo42/Jirafeau/wikis/home diff --git a/lib/template/footer.php b/lib/template/footer.php index d947421..7b9e188 100644 --- a/lib/template/footer.php +++ b/lib/template/footer.php @@ -3,7 +3,7 @@


agplv3 | - | + |