Aplicación web "El Almacén de archivos" sitio ligero para compartir archivos https://botadero.rmgss.net

Rodrigo Garcia 9664aa8fc7 fix css padding 5 years ago
botadero 9664aa8fc7 fix css padding 5 years ago
cronjobs e0a65de9f4 + INSTALL.es.md supervisorctl 5 years ago
docs 2315e42f55 +- improve docs about install 5 years ago
tests 1e6e812642 +- upload request answer 5 years ago
.gitignore 85bca6910a - config files + config samples 5 years ago
LICENSE 505dbcb306 Cambiada licencia a AGPL, agregado contador de descargas basico 8 years ago
README.md 95c913bd16 +- improving doc about crontab 5 years ago
app.ini e3d2e21793 + INSTALL.es.md 5 years ago
botadero.py cf2479543c +- estructura del punto inicial, paquete 'database' 6 years ago
cronjobs.py c9cd659520 Agregando paquete cronjobs y modulo para llamarlo 5 years ago
manage.py 9b1aeb1b10 fix creacion de tablas a partir de database/models.py 6 years ago
requirements.txt 2220da5e97 + uwsgi as requirements 5 years ago
run.sh e0a65de9f4 + INSTALL.es.md supervisorctl 5 years ago
wsgi.py e777cd6178 + uwsgi file 5 years ago

README.md

Servicio web centralizado para compartir archivos en una red local o internet.

Un directorio público donde cualquiera puede subir archivos y estos se pueden descargar libremente.

Para ahorrar espacio de almacenamiento, los archivos se borran después de un número ajustable de tiempo (días, minutos o segundos) y también se evita la posiblidad de subir archivos duplicados usando algoritmos para obtener digestos sha1, md5, sha256, etc.

Entre las funcionalidades que se pueden ajustar están:

  • Intervalo de borrado.
  • Almacenamiento máximo para archivos.
  • Almacenamiento máximo por tamaño de archivo.
  • Intervalo de borrado por tamaño de archivos.
  • Nivel de verbosidad en archivos de reportes.
  • Selección de algoritmo para digestos.
  • Comprobación acelerada de digestos.
  • Borrado de archivos usando passwords.
  • Unidad de tiempo.

Esta aplicación no guarda datos sobre quién sube los archivos, licencia AGPL.

Instalación

Se utiliza python3 con el micro framework Flask, se puede instalar con los siguientes pasos:

Despliegue en producción en docs/INSTALL.es.md

Para desarrollo
# descargar el repositorio
git clone https://notabug.org/strysg/botadero
cd botadero
# crear entorno virtual python 3
virtualenv --python=python3 venv
# activar entorno virtual
. venv/bin/activate
# instalar dependencias
pip install -r rquirements.txt
# variables de entorno
export FLASK_APP=botadero.py
export FLASK_ENV=development
# ejecutar en modo desarrollo
flask run

# ejecutar pruebas (desarrollo)
pytest

La aplicación necesita que se ejecute el script cronjobs.py que se encarga de actualizar el tiempo restante de los archivos y eliminarlos. Es recomendable agregar la ejecución de este script como tarea programada, en sistemas UNIX por ejemplo agregando una entrada en /etc/crontab.

*/1 *   * * *   user    cd /home/user/alamcenArchivos; export FLASK_ENV=production;venv/bin/python3 cronjobs.py >> cronjobs.log 2>&1

Despliegue

pronto.

El Botadero

Centralized web server to share files on a local network or over the internet.

A public directory where anyone can upload files and so they can be freely downlaoded.

To save storage, files are deleted after an adjustable number of days and file duplication is avoided by using sha1, md5, sha256, etc. digests.

Some customizable features are:

  • File deletion interval.
  • Maximun file storage size.
  • Maximun file size for files.
  • Deletion interval per file size.
  • Verbosity level to log files.
  • Digest algorithm selection.
  • Accelerated digest.
  • File deletion using password.
  • Time unit.

This application does not store data about who upload files, AGPL License.

Install

It uses python3 and micro framework Flask, can be installed following:

soon.

For development
# download project
git clone https://notabug.org/strysg/botadero
cd botadero
# create python 3 virtual environment
virtualenv --python=python3 venv
# activate it
. venv/bin/activate
# install dependencies
pip install -r rquirements.txt
# environment variables
export FLASK_APP=botadero.py
export FLASK_ENV=development
# run development mode
flask run

# testing
pytest

The aplication requires the script cronjob.py to be executed, this updates the files ramaining time and also removes them if necesary. It is recomended to make the execution of this script a cronjob, on UNIX system for instance adding to /etc/crontab.

*/2 *    * * *   user    export FLASK_ENV=production; /home/user/almacenArchivos/venv/bin/python3 /home/user/almacenArchivos/cronjobs.py

Deploy

soon.