/shrekd

SHaRe, SHoRten oK Daemon, simple file, paste & url sharing daemon

Primary LanguageRustMIT LicenseMIT

shrekd CI

SHaRe, SHoRten oK Daemon, simple file, paste & url sharing daemon

Notice: This is still in early development and is not intended for production use right now.

Task list

  • Basic functionnality:
    • File upload (PUT /<filename> with streamed binary content)
    • Paste creation (POST /paste, with streamed utf-8 content)
    • Url redirect creation (POST /url with streamed url)
    • Getting record (GET /<slug>)
  • Nice to have:
    • Retain file records filenames and restore it at download
    • Add the full path when returning the URL
    • Retention curve depending on the weight, with expiration in return headers
    • Delete token in return headers, allowing effort-less deletion of a record
    • CI:
    • User-programmable configuration:
      • Custom Slug, best effort
      • Slug length, minimum of sever-configured Slug
      • Expiry date of the Record & Record detention duration
      • Maximum download count
      • Input Checksum verification
      • Password-protected Records
    • UI on GET /:
      • Make a dark/light mode compatible UI
      • Get file creation working
      • Get paste creation working
      • Get url creation working
      • Get user parameters working with the above
      • Try to make a JS-free UI
  • Reliability & Performance:
    • Fix race conditions on files
    • Serialize and deserialize data as binary, not JSON
    • Add unit tests to the project
    • Take care of random slug collision
    • Server-side file encryption
    • Use redis transactions if relevant
    • Clean orphaned files at startup, if relevant and safe
    • Use tracing instead of log for event logging

Abandonned task lists

  • Abuse prevention:

    • Log input IP addresses in the record
    • Set up some kind of rate limiting by IP

    Can easily be done, with a higher reliability through a reverse proxy

Setup

Currently the project requires you to host a Redis server locally for it to function properly.

Setup with docker-compose

You will need docker and docker-compose installed.

Once this is the case, you can run shrekd with:

$ docker-compose up -d

You can also modify the options of SHREKD with environment variable configuration by editing the environment section of the shrekd service.

Contributors

License

MIT License

Copyright (c) 2021 Léon ROUX

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.