Files
copyparty/README.md

1382 lines
69 KiB
Markdown
Raw Normal View History

2019-05-26 16:30:19 +00:00
# ⇆🎉 copyparty
2020-01-19 16:20:49 +01:00
* http file sharing hub (py2/py3) [(on PyPI)](https://pypi.org/project/copyparty/)
2019-05-26 16:30:19 +00:00
* MIT-Licensed, 2019-05-26, ed @ irc.rizon.net
2019-06-25 23:21:15 +00:00
2019-05-26 20:21:54 +00:00
## summary
2021-08-20 19:25:57 +02:00
turn your phone or raspi into a portable file server with resumable uploads/downloads using *any* web browser
2019-05-26 20:21:54 +00:00
2021-09-04 21:07:45 +02:00
* server only needs `py2.7` or `py3.3+`, all dependencies optional
2022-06-20 01:31:29 +02:00
* browse/upload with [IE4](#browser-support) / netscape4.0 on win3.11 (heh)
2022-07-03 13:55:48 +02:00
* *resumable* uploads need `firefox 34+` / `chrome 41+` / `safari 7+`
2019-05-26 20:21:54 +00:00
2022-06-20 01:31:29 +02:00
try the **[read-only demo server](https://a.ocv.me/pub/demo/)** 👀 running from a basement in finland
📷 **screenshots:** [browser](#the-browser) // [upload](#uploading) // [unpost](#unpost) // [thumbnails](#thumbnails) // [search](#searching) // [fsearch](#file-search) // [zip-DL](#zip-downloads) // [md-viewer](#markdown-viewer)
2021-04-25 04:34:06 +02:00
2019-06-25 23:21:15 +00:00
2022-01-14 22:25:06 +01:00
## get the app
<a href="https://f-droid.org/packages/me.ocv.partyup/"><img src="https://ocv.me/fdroid.png" alt="Get it on F-Droid" height="50" /> '' <img src="https://img.shields.io/f-droid/v/me.ocv.partyup.svg" alt="f-droid version info" /></a> '' <a href="https://github.com/9001/party-up"><img src="https://img.shields.io/github/release/9001/party-up.svg?logo=github" alt="github version info" /></a>
2022-01-17 00:31:23 +00:00
(the app is **NOT** the full copyparty server! just a basic upload client, nothing fancy yet)
2022-01-14 22:25:06 +01:00
2021-03-21 09:41:05 +01:00
## readme toc
* top
2021-09-25 18:03:19 +02:00
* [quickstart](#quickstart) - download **[copyparty-sfx.py](https://github.com/9001/copyparty/releases/latest/download/copyparty-sfx.py)** and you're all set!
2021-09-07 21:57:33 +02:00
* [on servers](#on-servers) - you may also want these, especially on servers
2021-08-22 17:23:42 +02:00
* [on debian](#on-debian) - recommended additional steps on debian
* [notes](#notes) - general notes
2021-09-04 21:07:45 +02:00
* [status](#status) - feature summary
2021-08-22 17:23:42 +02:00
* [testimonials](#testimonials) - small collection of user feedback
2021-09-12 23:25:34 +02:00
* [motivations](#motivations) - project goals / philosophy
* [future plans](#future-plans) - some improvement ideas
2021-03-21 09:41:05 +01:00
* [bugs](#bugs)
2021-05-16 09:05:40 +02:00
* [general bugs](#general-bugs)
2021-04-25 03:00:47 +02:00
* [not my bugs](#not-my-bugs)
2021-09-14 23:05:32 +02:00
* [FAQ](#FAQ) - "frequently" asked questions
2021-08-26 01:16:59 +02:00
* [accounts and volumes](#accounts-and-volumes) - per-folder, per-user permissions
2021-08-22 17:23:42 +02:00
* [the browser](#the-browser) - accessing a copyparty server using a web-browser
* [tabs](#tabs) - the main tabs in the ui
2021-09-04 21:21:18 +02:00
* [hotkeys](#hotkeys) - the browser has the following hotkeys
2021-08-22 17:23:42 +02:00
* [navpane](#navpane) - switching between breadcrumbs or navpane
2022-07-06 00:00:56 +02:00
* [thumbnails](#thumbnails) - press `g` or `田` to toggle grid-view instead of the file listing
2021-08-22 17:23:42 +02:00
* [zip downloads](#zip-downloads) - download folders (or file selections) as `zip` or `tar` files
2021-09-07 22:44:48 +02:00
* [uploading](#uploading) - drag files/folders into the web-browser to upload
* [file-search](#file-search) - dropping files into the browser also lets you see if they exist on the server
2021-08-22 17:23:42 +02:00
* [unpost](#unpost) - undo/delete accidental uploads
* [file manager](#file-manager) - cut/paste, rename, and delete files/folders (if you have permission)
2021-09-04 21:21:18 +02:00
* [batch rename](#batch-rename) - select some files and press `F2` to bring up the rename UI
2021-08-22 17:23:42 +02:00
* [markdown viewer](#markdown-viewer) - and there are *two* editors
2021-04-25 03:00:47 +02:00
* [other tricks](#other-tricks)
2021-08-22 17:23:42 +02:00
* [searching](#searching) - search by size, date, path/name, mp3-tags, ...
2021-11-06 22:15:37 +01:00
* [server config](#server-config) - using arguments or config files, or a mix of both
2022-02-13 15:46:33 +01:00
* [ftp-server](#ftp-server) - an FTP server can be started using `--ftp 3921`
2022-08-03 22:20:28 +02:00
* [file indexing](#file-indexing) - enables dedup and music search ++
* [exclude-patterns](#exclude-patterns) - to save some time
* [filesystem guards](#filesystem-guards) - avoid traversing into other filesystems
* [periodic rescan](#periodic-rescan) - filesystem monitoring
* [upload rules](#upload-rules) - set upload rules using volflags
2021-08-22 17:23:42 +02:00
* [compress uploads](#compress-uploads) - files can be autocompressed on upload
2021-09-04 21:21:18 +02:00
* [database location](#database-location) - in-volume (`.hist/up2k.db`, default) or somewhere else
2021-08-22 17:23:42 +02:00
* [metadata from audio files](#metadata-from-audio-files) - set `-e2t` to index tags on upload
2021-11-20 17:51:49 +01:00
* [file parser plugins](#file-parser-plugins) - provide custom parsers to index additional tags, also see [./bin/mtag/README.md](./bin/mtag/README.md)
2021-10-09 22:09:35 +02:00
* [upload events](#upload-events) - trigger a script/program on each upload
2022-03-20 06:15:57 +01:00
* [hiding from google](#hiding-from-google) - tell search engines you dont wanna be indexed
2022-04-29 23:13:37 +02:00
* [themes](#themes)
2021-03-21 20:38:29 +01:00
* [complete examples](#complete-examples)
2021-08-22 17:23:42 +02:00
* [browser support](#browser-support) - TLDR: yes
* [client examples](#client-examples) - interact with copyparty using non-browser clients
* [up2k](#up2k) - quick outline of the up2k protocol, see [uploading](#uploading) for the web-client
2021-09-04 21:21:18 +02:00
* [why chunk-hashes](#why-chunk-hashes) - a single sha512 would be better, right?
2021-09-04 21:40:22 +02:00
* [performance](#performance) - defaults are usually fine - expect `8 GiB/s` download, `1 GiB/s` upload
2021-10-31 06:24:11 +01:00
* [client-side](#client-side) - when uploading files
2021-09-06 08:36:18 +02:00
* [security](#security) - some notes on hardening
* [gotchas](#gotchas) - behavior that might be unexpected
2021-09-25 18:03:19 +02:00
* [recovering from crashes](#recovering-from-crashes)
* [client crashes](#client-crashes)
* [frefox wsod](#frefox-wsod) - firefox 87 can crash during uploads
2021-10-31 15:30:09 +01:00
* [HTTP API](#HTTP-API)
* [read](#read)
* [write](#write)
* [admin](#admin)
* [general](#general)
2021-08-22 17:23:42 +02:00
* [dependencies](#dependencies) - mandatory deps
* [optional dependencies](#optional-dependencies) - install these to enable bonus features
2021-05-26 00:47:43 +02:00
* [install recommended deps](#install-recommended-deps)
2021-03-21 09:41:05 +01:00
* [optional gpl stuff](#optional-gpl-stuff)
2022-02-13 20:44:03 +01:00
* [sfx](#sfx) - the self-contained "binary"
2021-08-26 01:16:59 +02:00
* [sfx repack](#sfx-repack) - reduce the size of an sfx by removing features
2021-03-21 09:41:05 +01:00
* [install on android](#install-on-android)
2021-11-15 20:28:53 +01:00
* [reporting bugs](#reporting-bugs) - ideas for context to include in bug reports
2021-06-19 16:20:35 +02:00
* [building](#building)
* [dev env setup](#dev-env-setup)
* [just the sfx](#just-the-sfx)
* [complete release](#complete-release)
2021-08-22 17:23:42 +02:00
* [todo](#todo) - roughly sorted by priority
2021-07-16 02:56:21 +02:00
* [discarded ideas](#discarded-ideas)
2021-03-21 09:41:05 +01:00
2021-01-02 22:57:48 +01:00
## quickstart
2021-09-04 21:07:45 +02:00
download **[copyparty-sfx.py](https://github.com/9001/copyparty/releases/latest/download/copyparty-sfx.py)** and you're all set!
2021-01-02 22:57:48 +01:00
2022-07-05 23:27:48 +02:00
running the sfx without arguments (for example doubleclicking it on Windows) will give everyone read/write access to the current folder; you may want [accounts and volumes](#accounts-and-volumes)
2021-01-02 22:57:48 +01:00
2021-06-16 18:29:29 +02:00
some recommended options:
2021-09-04 21:07:45 +02:00
* `-e2dsa` enables general [file indexing](#file-indexing)
2021-07-18 22:50:29 +02:00
* `-e2ts` enables audio metadata indexing (needs either FFprobe or Mutagen), see [optional dependencies](#optional-dependencies)
2021-07-24 22:26:52 +02:00
* `-v /mnt/music:/music:r:rw,foo -a foo:bar` shares `/mnt/music` as `/music`, `r`eadable by anyone, and read-write for user `foo`, password `bar`
* replace `:r:rw,foo` with `:r,foo` to only make the folder readable by `foo` and nobody else
2021-09-18 17:50:40 +02:00
* see [accounts and volumes](#accounts-and-volumes) for the syntax and other permissions (`r`ead, `w`rite, `m`ove, `d`elete, `g`et)
2022-07-05 23:27:48 +02:00
* `--ls '**,*,ln,p,r'` to crash on startup if any of the volumes contain a symlink which point outside the volume, as that could give users unintended access (see `--help-ls`)
2021-06-16 18:29:29 +02:00
2021-09-07 21:57:33 +02:00
### on servers
2021-01-02 22:57:48 +01:00
you may also want these, especially on servers:
2021-09-07 21:57:33 +02:00
2021-01-02 22:57:48 +01:00
* [contrib/systemd/copyparty.service](contrib/systemd/copyparty.service) to run copyparty as a systemd service
2021-09-07 21:57:33 +02:00
* [contrib/systemd/prisonparty.service](contrib/systemd/prisonparty.service) to run it in a chroot (for extra security)
2021-05-16 08:52:22 +02:00
* [contrib/nginx/copyparty.conf](contrib/nginx/copyparty.conf) to reverse-proxy behind nginx (for better https)
2021-01-02 22:57:48 +01:00
2021-06-27 00:49:28 +02:00
### on debian
2021-06-27 00:19:37 +02:00
2021-09-04 21:21:18 +02:00
recommended additional steps on debian which enable audio metadata and thumbnails (from images and videos):
2021-06-27 00:19:37 +02:00
* as root, run the following:
2021-06-27 00:49:28 +02:00
`apt install python3 python3-pip python3-dev ffmpeg`
2021-06-27 00:19:37 +02:00
* then, as the user which will be running copyparty (so hopefully not root), run this:
2021-06-27 00:19:37 +02:00
`python3 -m pip install --user -U Pillow pillow-avif-plugin`
2021-06-27 00:49:28 +02:00
(skipped `pyheif-pillow-opener` because apparently debian is too old to build it)
2021-06-27 00:19:37 +02:00
2021-01-02 22:57:48 +01:00
2019-07-05 19:01:04 +00:00
## notes
2021-08-22 17:23:42 +02:00
general notes:
2021-06-07 02:10:54 +02:00
* paper-printing is affected by dark/light-mode! use lightmode for color, darkmode for grayscale
* because no browsers currently implement the media-query to do this properly orz
browser-specific:
2019-07-05 19:01:04 +00:00
* iPhone/iPad: use Firefox to download files
2021-04-25 22:44:50 +02:00
* Android-Chrome: increase "parallel uploads" for higher speed (android bug)
* Android-Firefox: takes a while to select files (their fix for ☝️)
2021-04-26 04:02:22 +02:00
* Desktop-Firefox: ~~may use gigabytes of RAM if your files are massive~~ *seems to be OK now*
2021-09-04 21:21:18 +02:00
* Desktop-Firefox: may stop you from deleting files you've uploaded until you visit `about:memory` and click `Minimize memory usage`
2019-07-05 19:01:04 +00:00
2019-05-26 16:30:19 +00:00
## status
2021-09-04 21:07:45 +02:00
feature summary
2021-05-27 01:42:22 +02:00
2021-02-21 00:26:29 +00:00
* backend stuff
* ☑ sanic multipart parser
2021-07-16 02:44:06 +02:00
* ☑ multiprocessing (actual multithreading)
2021-02-21 00:26:29 +00:00
* ☑ volumes (mountpoints)
2021-07-24 22:26:52 +02:00
* ☑ [accounts](#accounts-and-volumes)
2022-02-13 03:10:53 +01:00
* ☑ [ftp-server](#ftp-server)
2021-02-21 00:26:29 +00:00
* upload
* ☑ basic: plain multipart, ie6 support
2021-08-06 01:48:34 +02:00
* ☑ [up2k](#uploading): js, resumable, multithreaded
2021-02-21 00:29:10 +00:00
* ☑ stash: simple PUT filedropper
2021-08-17 00:23:12 +02:00
* ☑ [unpost](#unpost): undo/delete accidental uploads
2021-02-21 00:29:10 +00:00
* ☑ symlink/discard existing files (content-matching)
2021-02-21 00:26:29 +00:00
* download
* ☑ single files in browser
2021-08-06 01:48:34 +02:00
* ☑ [folders as zip / tar files](#zip-downloads)
2022-07-05 23:27:48 +02:00
* ☑ [FUSE client](https://github.com/9001/copyparty/tree/hovudstraum/bin#copyparty-fusepy) (read-only)
2021-02-21 00:26:29 +00:00
* browser
2021-09-04 21:07:45 +02:00
* ☑ [navpane](#navpane) (directory tree sidebar)
2021-08-06 01:48:34 +02:00
* ☑ file manager (cut/paste, delete, [batch-rename](#batch-rename))
2021-11-06 22:15:37 +01:00
* ☑ audio player (with OS media controls and opus transcoding)
2021-08-05 21:53:51 +02:00
* ☑ image gallery with webm player
2021-11-15 20:28:53 +01:00
* ☑ textfile browser with syntax hilighting
2021-08-06 01:48:34 +02:00
* ☑ [thumbnails](#thumbnails)
2022-04-11 10:38:57 +02:00
* ☑ ...of images using Pillow, pyvips, or FFmpeg
2021-07-16 02:44:06 +02:00
* ☑ ...of videos using FFmpeg
2021-11-15 20:28:53 +01:00
* ☑ ...of audio (spectrograms) using FFmpeg
2021-05-25 19:46:35 +02:00
* ☑ cache eviction (max-age; maybe max-size eventually)
2021-05-16 08:52:22 +02:00
* ☑ SPA (browse while uploading)
2021-02-21 00:29:10 +00:00
* server indexing
2021-08-06 01:48:34 +02:00
* ☑ [locate files by contents](#file-search)
2021-02-21 00:29:10 +00:00
* ☑ search by name/path/date/size
2021-08-06 01:48:34 +02:00
* ☑ [search by ID3-tags etc.](#searching)
2021-02-21 00:26:29 +00:00
* markdown
2021-08-06 01:48:34 +02:00
* ☑ [viewer](#markdown-viewer)
2021-02-21 00:26:29 +00:00
* ☑ editor (sure why not)
2019-05-26 16:30:19 +00:00
2019-06-07 08:54:41 +00:00
2021-07-04 00:32:29 +02:00
## testimonials
small collection of user feedback
2021-07-04 16:04:26 +02:00
`good enough`, `surprisingly correct`, `certified good software`, `just works`, `why`
2021-07-04 00:32:29 +02:00
2021-09-12 23:25:34 +02:00
# motivations
project goals / philosophy
* inverse linux philosophy -- do all the things, and do an *okay* job
* quick drop-in service to get a lot of features in a pinch
* there are probably [better alternatives](https://github.com/awesome-selfhosted/awesome-selfhosted) if you have specific/long-term needs
2022-07-05 23:27:48 +02:00
* but the resumable multithreaded uploads are p slick ngl
2021-09-12 23:25:34 +02:00
* run anywhere, support everything
* as many web-browsers and python versions as possible
* every browser should at least be able to browse, download, upload files
* be a good emergency solution for transferring stuff between ancient boxes
* minimal dependencies
* but optional dependencies adding bonus-features are ok
* everything being plaintext makes it possible to proofread for malicious code
* no preparations / setup necessary, just run the sfx (which is also plaintext)
* adaptable, malleable, hackable
* no build steps; modify the js/python without needing node.js or anything like that
## future plans
some improvement ideas
* the JS is a mess -- a preact rewrite would be nice
* preferably without build dependencies like webpack/babel/node.js, maybe a python thing to assemble js files into main.js
* good excuse to look at using virtual lists (browsers start to struggle when folders contain over 5000 files)
* the UX is a mess -- a proper design would be nice
* very organic (much like the python/js), everything was an afterthought
* true for both the layout and the visual flair
* something like the tron board-room ui (or most other hollywood ones, like ironman) would be :100:
* some of the python files are way too big
* `up2k.py` ended up doing all the file indexing / db management
* `httpcli.py` should be separated into modules in general
# bugs
2021-07-18 22:50:29 +02:00
* Windows: python 3.7 and older cannot read tags with FFprobe, so use Mutagen or upgrade
* Windows: python 2.7 cannot index non-ascii filenames with `-e2d`
2021-03-27 03:07:44 +01:00
* Windows: python 2.7 cannot handle filenames with mojibake
2021-09-04 21:07:45 +02:00
* `--th-ff-jpg` may fix video thumbnails on some FFmpeg versions (macos, some linux)
2021-11-06 22:15:37 +01:00
* `--th-ff-swr` may fix audio thumbnails on some FFmpeg versions
2021-05-16 08:52:22 +02:00
## general bugs
2022-07-05 23:27:48 +02:00
* Windows: if the `up2k.db` (filesystem index) is on a samba-share or network disk, you'll get unpredictable behavior if the share is disconnected for a bit
2022-02-13 03:10:53 +01:00
* use `--hist` or the `hist` volflag (`-v [...]:c,hist=/tmp/foo`) to place the db on a local disk instead
2021-05-16 08:52:22 +02:00
* all volumes must exist / be available on startup; up2k (mtp especially) gets funky otherwise
2022-08-13 00:58:49 +02:00
* [the database can get stuck](https://github.com/9001/copyparty/issues/10)
* has only happened once but that is once too many
* luckily not dangerous for file integrity and doesn't really stop uploads or anything like that
* but would really appreciate some logs if anyone ever runs into it again
* probably more, pls let me know
2021-04-21 21:42:37 +02:00
## not my bugs
2022-04-29 23:13:37 +02:00
* [Chrome issue 1317069](https://bugs.chromium.org/p/chromium/issues/detail?id=1317069) -- if you try to upload a folder which contains symlinks by dragging it into the browser, the symlinked files will not get uploaded
2022-08-20 09:25:29 +02:00
* [Chrome issue 1354816](https://bugs.chromium.org/p/chromium/issues/detail?id=1354816) -- chrome may eat all RAM uploading over plaintext http with `mt` enabled
* more amusingly, [Chrome issue 1354800](https://bugs.chromium.org/p/chromium/issues/detail?id=1354800) -- chrome may eat all RAM uploading in general (altho you probably won't run into this one)
* [Chrome issue 1352210](https://bugs.chromium.org/p/chromium/issues/detail?id=1352210) -- plaintext http may be faster at filehashing than https (but also extremely CPU-intensive and likely to run into the above gc bugs)
2022-08-13 00:58:49 +02:00
2021-11-15 20:28:53 +01:00
* iPhones: the volume control doesn't work because [apple doesn't want it to](https://developer.apple.com/library/archive/documentation/AudioVideo/Conceptual/Using_HTML5_Audio_Video/Device-SpecificConsiderations/Device-SpecificConsiderations.html#//apple_ref/doc/uid/TP40009523-CH5-SW11)
2021-11-16 00:05:35 +01:00
* *future workaround:* enable the equalizer, make it all-zero, and set a negative boost to reduce the volume
* "future" because `AudioContext` is broken in the current iOS version (15.1), maybe one day...
2021-11-15 20:28:53 +01:00
2021-06-20 18:53:58 +02:00
* Windows: folders cannot be accessed if the name ends with `.`
* python or windows bug
2021-07-16 02:44:06 +02:00
* Windows: msys2-python 3.8.6 occasionally throws `RuntimeError: release unlocked lock` when leaving a scoped mutex in up2k
2021-04-21 21:42:37 +02:00
* this is an msys2 bug, the regular windows edition of python is fine
2021-07-18 21:34:36 +02:00
* VirtualBox: sqlite throws `Disk I/O Error` when running in a VM and the up2k database is in a vboxsf
2021-08-06 00:50:29 +02:00
* use `--hist` or the `hist` volflag (`-v [...]:c,hist=/tmp/foo`) to place the db inside the vm instead
2021-07-18 21:34:36 +02:00
* Ubuntu: dragging files from certain folders into firefox or chrome is impossible
* due to snap security policies -- see `snap connections firefox` for the allowlist, `removable-media` permits all of `/mnt` and `/media` apparently
2021-09-14 23:05:32 +02:00
# FAQ
"frequently" asked questions
* is it possible to block read-access to folders unless you know the exact URL for a particular file inside?
2021-09-18 15:38:13 +02:00
* yes, using the [`g` permission](#accounts-and-volumes), see the examples there
* you can also do this with linux filesystem permissions; `chmod 111 music` will make it possible to access files and folders inside the `music` folder but not list the immediate contents -- also works with other software, not just copyparty
2021-09-14 23:05:32 +02:00
* can I make copyparty download a file to my server if I give it a URL?
2022-07-05 23:27:48 +02:00
* not really, but there is a [terrible hack](https://github.com/9001/copyparty/blob/hovudstraum/bin/mtag/wget.py) which makes it possible
2021-09-14 23:05:32 +02:00
2021-07-24 22:26:52 +02:00
# accounts and volumes
2021-11-12 22:30:23 +01:00
per-folder, per-user permissions - if your setup is getting complex, consider making a [config file](./docs/example.conf) instead of using arguments
* much easier to manage, and you can modify the config at runtime with `systemctl reload copyparty` or more conveniently using the `[reload cfg]` button in the control-panel (if logged in as admin)
2022-07-05 23:27:48 +02:00
a quick summary can be seen using `--help-accounts`
2021-11-12 22:30:23 +01:00
configuring accounts/volumes with arguments:
2021-07-24 22:26:52 +02:00
* `-a usr:pwd` adds account `usr` with password `pwd`
* `-v .::r` adds current-folder `.` as the webroot, `r`eadable by anyone
* the syntax is `-v src:dst:perm:perm:...` so local-path, url-path, and one or more permissions to set
2021-09-04 21:07:45 +02:00
* granting the same permissions to multiple accounts:
`-v .::r,usr1,usr2:rw,usr3,usr4` = usr1/2 read-only, 3/4 read-write
2021-07-24 22:26:52 +02:00
permissions:
* `r` (read): browse folder contents, download files, download as zip/tar
2021-09-04 21:07:45 +02:00
* `w` (write): upload files, move files *into* this folder
* `m` (move): move files/folders *from* this folder
2021-07-24 22:26:52 +02:00
* `d` (delete): delete files/folders
2021-09-15 01:01:20 +02:00
* `g` (get): only download files, cannot see folder contents or zip/tar
2021-07-24 22:26:52 +02:00
2021-09-04 21:07:45 +02:00
examples:
2021-07-24 22:26:52 +02:00
* add accounts named u1, u2, u3 with passwords p1, p2, p3: `-a u1:p1 -a u2:p2 -a u3:p3`
* make folder `/srv` the root of the filesystem, read-only by anyone: `-v /srv::r`
* make folder `/mnt/music` available at `/music`, read-only for u1 and u2, read-write for u3: `-v /mnt/music:music:r,u1,u2:rw,u3`
* unauthorized users accessing the webroot can see that the `music` folder exists, but cannot open it
* make folder `/mnt/incoming` available at `/inc`, write-only for u1, read-move for u2: `-v /mnt/incoming:inc:w,u1:rm,u2`
* unauthorized users accessing the webroot can see that the `inc` folder exists, but cannot open it
* `u1` can open the `inc` folder, but cannot see the contents, only upload new files to it
* `u2` can browse it and move files *from* `/inc` into any folder where `u2` has write-access
2021-09-18 15:38:13 +02:00
* make folder `/mnt/ss` available at `/i`, read-write for u1, get-only for everyone else, and enable accesskeys: `-v /mnt/ss:i:rw,u1:g:c,fk=4`
2022-08-03 22:20:28 +02:00
* `c,fk=4` sets the `fk` volflag to 4, meaning each file gets a 4-character accesskey
2021-09-18 15:38:13 +02:00
* `u1` can upload files, browse the folder, and see the generated accesskeys
* other users cannot browse the folder, but can access the files if they have the full file URL with the accesskey
2021-07-24 22:26:52 +02:00
2021-04-25 03:00:47 +02:00
# the browser
2021-08-22 17:23:42 +02:00
accessing a copyparty server using a web-browser
2021-08-17 00:23:12 +02:00
![copyparty-browser-fs8](https://user-images.githubusercontent.com/241032/129635359-d6dd9b07-8079-4020-ad77-2bfdb9ebd8d5.png)
2021-04-25 04:34:06 +02:00
2021-04-25 03:00:47 +02:00
## tabs
2021-08-22 17:23:42 +02:00
the main tabs in the ui
2021-08-17 00:23:12 +02:00
* `[🔎]` [search](#searching) by size, date, path/name, mp3-tags ...
* `[🧯]` [unpost](#unpost): undo/delete accidental uploads
* `[🚀]` and `[🎈]` are the [uploaders](#uploading)
2021-07-30 00:53:15 +02:00
* `[📂]` mkdir: create directories
* `[📝]` new-md: create a new markdown document
* `[📟]` send-msg: either to server-log or into textfiles if `--urlform save`
2021-07-16 02:44:06 +02:00
* `[🎺]` audio-player config options
* `[⚙️]` general client config options
2021-04-25 03:00:47 +02:00
## hotkeys
2021-03-21 09:41:05 +01:00
2021-09-04 21:21:18 +02:00
the browser has the following hotkeys (always qwerty)
2021-09-04 21:07:45 +02:00
* `B` toggle breadcrumbs / [navpane](#navpane)
2021-03-21 09:41:05 +01:00
* `I/K` prev/next folder
2021-07-16 02:44:06 +02:00
* `M` parent folder (or unexpand current)
2021-11-06 22:15:37 +01:00
* `V` toggle folders / textfiles in the navpane
2022-07-05 23:27:48 +02:00
* `G` toggle list / [grid view](#thumbnails) -- same as `田` bottom-right
2021-05-26 00:47:43 +02:00
* `T` toggle thumbnails / icons
2021-12-04 18:52:14 +01:00
* `ESC` close various things
2021-07-25 01:09:14 +02:00
* `ctrl-X` cut selected files/folders
* `ctrl-V` paste
2021-09-04 21:07:45 +02:00
* `F2` [rename](#batch-rename) selected file/folder
2021-07-26 22:47:54 +02:00
* when a file/folder is selected (in not-grid-view):
* `Up/Down` move cursor
2021-07-27 12:26:34 +02:00
* shift+`Up/Down` select and move cursor
* ctrl+`Up/Down` move cursor and scroll viewport
2021-07-26 22:47:54 +02:00
* `Space` toggle file selection
* `Ctrl-A` toggle select all
2021-11-06 22:15:37 +01:00
* when a textfile is open:
* `I/K` prev/next textfile
* `S` toggle selection of open file
* `M` close textfile
2021-05-12 21:20:59 +02:00
* when playing audio:
* `J/L` prev/next song
2021-07-11 06:12:24 +02:00
* `U/O` skip 10sec back/forward
2021-07-15 01:13:15 +02:00
* `0..9` jump to 0%..90%
* `P` play/pause (also starts playing the folder)
2022-06-19 16:05:48 +02:00
* `Y` download file
2021-07-11 06:12:24 +02:00
* when viewing images / playing videos:
* `J/L, Left/Right` prev/next file
* `Home/End` first/last file
2022-07-05 23:27:48 +02:00
* `F` toggle fullscreen
2021-08-12 22:20:32 +02:00
* `S` toggle selection
2021-08-14 18:06:53 +02:00
* `R` rotate clockwise (shift=ccw)
2022-06-19 16:05:48 +02:00
* `Y` download file
2021-07-11 06:12:24 +02:00
* `Esc` close viewer
2021-07-13 02:20:52 +02:00
* videos:
* `U/O` skip 10sec back/forward
2022-07-17 23:45:02 +02:00
* `0..9` jump to 0%..90%
2021-07-13 02:20:52 +02:00
* `P/K/Space` play/pause
* `M` mute
2022-07-05 23:27:48 +02:00
* `C` continue playing next video
* `V` loop entire file
* `[` loop range (start)
* `]` loop range (end)
2021-07-27 20:39:01 +02:00
* when the navpane is open:
2021-06-28 15:34:10 +02:00
* `A/D` adjust tree width
2021-09-04 21:07:45 +02:00
* in the [grid view](#thumbnails):
2021-05-26 00:47:43 +02:00
* `S` toggle multiselect
2021-06-28 15:34:10 +02:00
* shift+`A/D` zoom
2021-07-16 02:44:06 +02:00
* in the markdown editor:
* `^s` save
* `^h` header
* `^k` autoformat table
* `^u` jump to next unicode character
* `^e` toggle editor / preview
2021-07-16 02:56:21 +02:00
* `^up, ^down` jump paragraphs
2021-04-25 03:00:47 +02:00
2021-07-24 22:26:52 +02:00
2021-07-27 20:39:01 +02:00
## navpane
2021-04-25 03:00:47 +02:00
2021-08-22 17:23:42 +02:00
switching between breadcrumbs or navpane
click the `🌲` or pressing the `B` hotkey to toggle between breadcrumbs path (default), or a navpane (tree-browser sidebar thing)
2021-04-25 03:00:47 +02:00
2021-12-04 18:52:14 +01:00
* `[+]` and `[-]` (or hotkeys `A`/`D`) adjust the size
* `[🎯]` jumps to the currently open folder
* `[📃]` toggles between showing folders and textfiles
* `[📌]` shows the name of all parent folders in a docked panel
2021-09-04 21:07:45 +02:00
* `[a]` toggles automatic widening as you go deeper
2021-12-04 18:52:14 +01:00
* `[↵]` toggles wordwrap
* `[👀]` show full name on hover (if wordwrap is off)
2021-04-19 16:41:06 +02:00
2021-03-21 09:41:05 +01:00
2021-05-26 00:47:43 +02:00
## thumbnails
2022-07-05 23:27:48 +02:00
press `g` or `田` to toggle grid-view instead of the file listing and `t` toggles icons / thumbnails
2021-08-22 17:23:42 +02:00
2021-08-17 00:23:12 +02:00
![copyparty-thumbs-fs8](https://user-images.githubusercontent.com/241032/129636211-abd20fa2-a953-4366-9423-1c88ebb96ba9.png)
2021-05-26 00:47:43 +02:00
2022-04-11 10:38:57 +02:00
it does static images with Pillow / pyvips / FFmpeg, and uses FFmpeg for video files, so you may want to `--no-thumb` or maybe just `--no-vthumb` depending on how dangerous your users are
* pyvips is 3x faster than Pillow, Pillow is 3x faster than FFmpeg
* disable thumbnails for specific volumes with volflag `dthumb` for all, or `dvthumb` / `dathumb` / `dithumb` for video/audio/images only
2021-05-26 00:47:43 +02:00
2021-11-06 22:15:37 +01:00
audio files are covnerted into spectrograms using FFmpeg unless you `--no-athumb` (and some FFmpeg builds may need `--th-ff-swr`)
2021-07-15 01:13:15 +02:00
images with the following names (see `--th-covers`) become the thumbnail of the folder they're in: `folder.png`, `folder.jpg`, `cover.png`, `cover.jpg`
2021-06-12 03:06:56 +02:00
2021-06-25 20:04:19 +02:00
in the grid/thumbnail view, if the audio player panel is open, songs will start playing when clicked
2021-12-04 18:52:14 +01:00
* indicated by the audio files having the ▶ icon instead of 💾
2021-06-25 20:04:19 +02:00
2021-05-26 00:47:43 +02:00
2021-03-27 03:34:03 +01:00
## zip downloads
2021-08-22 17:23:42 +02:00
download folders (or file selections) as `zip` or `tar` files
2021-09-04 21:07:45 +02:00
select which type of archive you want in the `[⚙️] config` tab:
2021-03-27 03:35:57 +01:00
2021-03-27 03:34:03 +01:00
| name | url-suffix | description |
|--|--|--|
| `tar` | `?tar` | plain gnutar, works great with `curl \| tar -xv` |
| `zip` | `?zip=utf8` | works everywhere, glitchy filenames on win7 and older |
| `zip_dos` | `?zip` | traditional cp437 (no unicode) to fix glitchy filenames |
| `zip_crc` | `?zip=crc` | cp437 with crc32 computed early for truly ancient software |
* hidden files (dotfiles) are excluded unless `-ed`
2021-07-16 02:44:06 +02:00
* `up2k.db` and `dir.txt` is always excluded
2021-03-27 03:34:03 +01:00
* `zip_crc` will take longer to download since the server has to read each file twice
2021-07-16 02:56:21 +02:00
* this is only to support MS-DOS PKZIP v2.04g (october 1993) and older
* how are you accessing copyparty actually
2021-03-27 03:34:03 +01:00
2021-04-25 04:34:06 +02:00
you can also zip a selection of files or folders by clicking them in the browser, that brings up a selection editor and zip button in the bottom right
2021-08-17 00:23:12 +02:00
![copyparty-zipsel-fs8](https://user-images.githubusercontent.com/241032/129635374-e5136e01-470a-49b1-a762-848e8a4c9cdc.png)
2021-03-27 03:34:03 +01:00
2021-08-22 17:23:42 +02:00
2021-04-25 03:00:47 +02:00
## uploading
2022-07-05 23:27:48 +02:00
drag files/folders into the web-browser to upload (or use the [command-line uploader](https://github.com/9001/copyparty/tree/hovudstraum/bin#up2kpy))
2021-09-07 22:44:48 +02:00
this initiates an upload using `up2k`; there are two uploaders available:
2021-07-30 00:53:15 +02:00
* `[🎈] bup`, the basic uploader, supports almost every browser since netscape 4.0
2022-07-05 23:27:48 +02:00
* `[🚀] up2k`, the good / fancy one
2021-07-30 00:53:15 +02:00
2022-07-05 23:27:48 +02:00
NB: you can undo/delete your own uploads with `[🧯]` [unpost](#unpost)
2021-04-25 03:00:47 +02:00
up2k has several advantages:
* you can drop folders into the browser (files are added recursively)
* files are processed in chunks, and each chunk is checksummed
2021-07-16 02:44:06 +02:00
* uploads autoresume if they are interrupted by network issues
2021-07-16 02:56:21 +02:00
* uploads resume if you reboot your browser or pc, just upload the same files again
2021-04-25 03:00:47 +02:00
* server detects any corruption; the client reuploads affected chunks
* the client doesn't upload anything that already exists on the server
2021-07-16 02:44:06 +02:00
* much higher speeds than ftp/scp/tarpipe on some internet connections (mainly american ones) thanks to parallel connections
2021-04-25 03:00:47 +02:00
* the last-modified timestamp of the file is preserved
2022-07-05 23:27:48 +02:00
see [up2k](#up2k) for details on how it works, or watch a [demo video](https://a.ocv.me/pub/demo/pics-vids/#gf-0f6f5c0d)
2021-04-25 03:00:47 +02:00
2021-08-17 00:23:12 +02:00
![copyparty-upload-fs8](https://user-images.githubusercontent.com/241032/129635371-48fc54ca-fa91-48e3-9b1d-ba413e4b68cb.png)
2021-04-25 03:00:47 +02:00
2022-01-14 22:25:06 +01:00
**protip:** you can avoid scaring away users with [contrib/plugins/minimal-up2k.html](contrib/plugins/minimal-up2k.html) which makes it look [much simpler](https://user-images.githubusercontent.com/241032/118311195-dd6ca380-b4ef-11eb-86f3-75a3ff2e1332.png)
2021-05-14 16:38:07 +02:00
2021-10-31 15:30:09 +01:00
**protip:** if you enable `favicon` in the `[⚙️] settings` tab (by typing something into the textbox), the icon in the browser tab will indicate upload progress
2021-04-25 03:00:47 +02:00
the up2k UI is the epitome of polished inutitive experiences:
* "parallel uploads" specifies how many chunks to upload at the same time
2021-04-25 03:04:24 +02:00
* `[🏃]` analysis of other files should continue while one is uploading
2022-07-16 03:58:58 +02:00
* `[🥔]` shows a simpler UI for faster uploads from slow devices
2021-09-04 21:07:45 +02:00
* `[💭]` ask for confirmation before files are added to the queue
* `[🔎]` switch between upload and [file-search](#file-search) mode
2021-09-07 21:49:00 +02:00
* ignore `[🔎]` if you add files by dragging them into the browser
2021-04-25 03:00:47 +02:00
and then theres the tabs below it,
2021-09-04 21:07:45 +02:00
* `[ok]` is the files which completed successfully
* `[ng]` is the ones that failed / got rejected (already exists, ...)
2021-04-25 03:04:24 +02:00
* `[done]` shows a combined list of `[ok]` and `[ng]`, chronological order
* `[busy]` files which are currently hashing, pending-upload, or uploading
2021-05-02 09:16:14 +02:00
* plus up to 3 entries each from `[done]` and `[que]` for context
2021-04-25 03:04:24 +02:00
* `[que]` is all the files that are still queued
2022-07-05 23:27:48 +02:00
note that since up2k has to read each file twice, `[🎈] bup` can *theoretically* be up to 2x faster in some extreme cases (files bigger than your ram, combined with an internet connection faster than the read-speed of your HDD, or if you're uploading from a cuo2duo)
2021-09-04 21:07:45 +02:00
if you are resuming a massive upload and want to skip hashing the files which already finished, you can enable `turbo` in the `[⚙️] config` tab, but please read the tooltip on that button
2021-08-22 17:23:42 +02:00
2021-04-25 21:42:45 +02:00
### file-search
2021-09-07 22:44:48 +02:00
dropping files into the browser also lets you see if they exist on the server
2021-08-22 17:23:42 +02:00
2021-08-17 00:23:12 +02:00
![copyparty-fsearch-fs8](https://user-images.githubusercontent.com/241032/129635361-c79286f0-b8f1-440e-aaf4-6e929428fac9.png)
2021-04-25 22:44:50 +02:00
2021-09-07 22:44:48 +02:00
when you drag/drop files into the browser, you will see two dropzones: `Upload` and `Search`
2021-09-07 21:49:00 +02:00
> on a phone? toggle the `[🔎]` switch green before tapping the big yellow Search button to select your files
the files will be hashed on the client-side, and each hash is sent to the server, which checks if that file exists somewhere
2021-04-25 21:42:45 +02:00
files go into `[ok]` if they exist (and you get a link to where it is), otherwise they land in `[ng]`
2021-05-16 09:05:40 +02:00
* the main reason filesearch is combined with the uploader is cause the code was too spaghetti to separate it out somewhere else, this is no longer the case but now i've warmed up to the idea too much
2021-04-25 03:00:47 +02:00
2021-04-25 04:34:06 +02:00
2021-08-17 00:23:12 +02:00
### unpost
2021-08-22 17:23:42 +02:00
undo/delete accidental uploads
2021-08-17 00:23:12 +02:00
![copyparty-unpost-fs8](https://user-images.githubusercontent.com/241032/129635368-3afa6634-c20f-418c-90dc-ec411f3b3897.png)
2021-08-22 17:23:42 +02:00
you can unpost even if you don't have regular move/delete access, however only for files uploaded within the past `--unpost` seconds (default 12 hours) and the server must be running with `-e2d`
2021-08-17 00:23:12 +02:00
2021-07-25 01:09:14 +02:00
## file manager
2021-08-22 17:23:42 +02:00
cut/paste, rename, and delete files/folders (if you have permission)
2021-07-25 01:09:14 +02:00
2021-09-04 21:07:45 +02:00
file selection: click somewhere on the line (not the link itsef), then:
* `space` to toggle
* `up/down` to move
* `shift-up/down` to move-and-select
* `ctrl-shift-up/down` to also scroll
* cut: select some files and `ctrl-x`
* paste: `ctrl-v` in another folder
* rename: `F2`
2021-07-25 01:09:14 +02:00
you can move files across browser tabs (cut in one tab, paste in another)
2021-08-05 21:53:51 +02:00
## batch rename
2021-09-04 21:07:45 +02:00
select some files and press `F2` to bring up the rename UI
2021-08-05 21:53:51 +02:00
2021-08-22 17:23:42 +02:00
![batch-rename-fs8](https://user-images.githubusercontent.com/241032/128434204-eb136680-3c07-4ec7-92e0-ae86af20c241.png)
2021-08-05 21:53:51 +02:00
quick explanation of the buttons,
* `[✅ apply rename]` confirms and begins renaming
* `[❌ cancel]` aborts and closes the rename window
* `[↺ reset]` reverts any filename changes back to the original name
* `[decode]` does a URL-decode on the filename, fixing stuff like `&amp;` and `%20`
* `[advanced]` toggles advanced mode
advanced mode: rename files based on rules to decide the new names, based on the original name (regex), or based on the tags collected from the file (artist/title/...), or a mix of both
in advanced mode,
* `[case]` toggles case-sensitive regex
* `regex` is the regex pattern to apply to the original filename; any files which don't match will be skipped
* `format` is the new filename, taking values from regex capturing groups and/or from file tags
* very loosely based on foobar2000 syntax
2021-08-05 21:53:51 +02:00
* `presets` lets you save rename rules for later
available functions:
* `$lpad(text, length, pad_char)`
* `$rpad(text, length, pad_char)`
2021-08-05 21:53:51 +02:00
so,
say you have a file named [`meganeko - Eclipse - 07 Sirius A.mp3`](https://www.youtube.com/watch?v=-dtb0vDPruI) (absolutely fantastic album btw) and the tags are: `Album:Eclipse`, `Artist:meganeko`, `Title:Sirius A`, `tn:7`
you could use just regex to rename it:
2021-08-05 21:56:52 +02:00
* `regex` = `(.*) - (.*) - ([0-9]{2}) (.*)`
* `format` = `(3). (1) - (4)`
* `output` = `07. meganeko - Sirius A.mp3`
2021-08-05 21:53:51 +02:00
or you could use just tags:
2021-08-05 23:14:19 +02:00
* `format` = `$lpad((tn),2,0). (artist) - (title).(ext)`
2021-08-05 21:56:52 +02:00
* `output` = `7. meganeko - Sirius A.mp3`
2021-08-05 21:53:51 +02:00
2021-08-05 23:14:19 +02:00
or a mix of both:
2021-08-05 21:56:52 +02:00
* `regex` = ` - ([0-9]{2}) `
* `format` = `(1). (artist) - (title).(ext)`
* `output` = `07. meganeko - Sirius A.mp3`
2021-08-05 21:53:51 +02:00
the metadata keys you can use in the format field are the ones in the file-browser table header (whatever is collected with `-mte` and `-mtp`)
2021-08-05 21:53:51 +02:00
2021-04-25 04:34:06 +02:00
## markdown viewer
2021-08-22 17:23:42 +02:00
and there are *two* editors
2021-04-25 04:34:06 +02:00
![copyparty-md-read-fs8](https://user-images.githubusercontent.com/241032/115978057-66419080-a57d-11eb-8539-d2be843991aa.png)
* the document preview has a max-width which is the same as an A4 paper when printed
2021-04-25 03:00:47 +02:00
## other tricks
* you can link a particular timestamp in an audio file by adding it to the URL, such as `&20` / `&20s` / `&1m20` / `&t=1:20` after the `.../#af-c8960dab`
2021-11-20 19:33:56 +01:00
* enabling the audio equalizer can help make gapless albums fully gapless in some browsers (chrome), so consider leaving it on with all the values at zero
* get a plaintext file listing by adding `?ls=t` to a URL, or a compact colored one with `?ls=v` (for unix terminals)
2022-07-05 23:27:48 +02:00
* if you are using media hotkeys to switch songs and are getting tired of seeing the OSD popup which Windows doesn't let you disable, consider [./contrib/media-osd-bgone.ps1](contrib/#media-osd-bgoneps1)
2021-09-04 21:40:22 +02:00
* click the bottom-left `π` to open a javascript prompt for debugging
2021-09-06 00:23:35 +02:00
* files named `.prologue.html` / `.epilogue.html` will be rendered before/after directory listings unless `--no-logues`
* files named `README.md` / `readme.md` will be rendered after directory listings unless `--no-readme` (but `.epilogue.html` takes precedence)
2021-04-25 03:00:47 +02:00
2021-08-07 21:11:01 +02:00
## searching
2021-02-22 02:33:30 +01:00
2021-08-22 17:23:42 +02:00
search by size, date, path/name, mp3-tags, ...
2021-08-17 00:23:12 +02:00
![copyparty-search-fs8](https://user-images.githubusercontent.com/241032/129635365-c0ff2a9f-0ee5-4fc3-8bb6-006033cf67b8.png)
2021-04-25 04:34:06 +02:00
2021-02-22 03:33:24 +01:00
when started with `-e2dsa` copyparty will scan/index all your files. This avoids duplicates on upload, and also makes the volumes searchable through the web-ui:
* make search queries by `size`/`date`/`directory-path`/`filename`, or...
2021-04-25 21:42:45 +02:00
* drag/drop a local file to see if the same contents exist somewhere on the server, see [file-search](#file-search)
2021-02-22 02:33:30 +01:00
2021-02-22 03:33:24 +01:00
path/name queries are space-separated, AND'ed together, and words are negated with a `-` prefix, so for example:
* path: `shibayan -bossa` finds all files where one of the folders contain `shibayan` but filters out any results where `bossa` exists somewhere in the path
* name: `demetori styx` gives you [good stuff](https://www.youtube.com/watch?v=zGh0g14ZJ8I&list=PL3A147BD151EE5218&index=9)
2021-02-22 02:33:30 +01:00
2022-07-05 23:27:48 +02:00
the `raw` field allows for more complex stuff such as `( tags like *nhato* or tags like *taishi* ) and ( not tags like *nhato* or not tags like *taishi* )` which finds all songs by either nhato or taishi, excluding collabs (terrible example, why would you do that)
for the above example to work, add the commandline argument `-e2ts` to also scan/index tags from music files, which brings us over to:
2021-03-02 01:02:13 +01:00
2021-08-07 21:11:01 +02:00
# server config
2021-11-06 22:15:37 +01:00
using arguments or config files, or a mix of both:
* config files (`-c some.conf`) can set additional commandline arguments; see [./docs/example.conf](docs/example.conf)
2021-11-12 22:30:23 +01:00
* `kill -s USR1` (same as `systemctl reload copyparty`) to reload accounts and volumes from config files without restarting
* or click the `[reload cfg]` button in the control-panel when logged in as admin
2021-11-06 22:15:37 +01:00
2022-02-13 03:10:53 +01:00
## ftp-server
2022-02-13 15:46:33 +01:00
an FTP server can be started using `--ftp 3921`, and/or `--ftps` for explicit TLS (ftpes)
2022-02-13 03:10:53 +01:00
* based on [pyftpdlib](https://github.com/giampaolo/pyftpdlib)
* needs a dedicated port (cannot share with the HTTP/HTTPS API)
2022-02-13 15:46:33 +01:00
* uploads are not resumable -- delete and restart if necessary
* runs in active mode by default, you probably want `--ftp-pr 12000-13000`
* if you enable both `ftp` and `ftps`, the port-range will be divided in half
2022-02-13 16:38:24 +01:00
* some older software (filezilla on debian-stable) cannot passive-mode with TLS
2022-02-13 03:10:53 +01:00
2021-08-22 17:23:42 +02:00
## file indexing
2022-08-03 22:20:28 +02:00
enables dedup and music search ++
file indexing relies on two database tables, the up2k filetree (`-e2d`) and the metadata tags (`-e2t`), stored in `.hist/up2k.db`. Configuration can be done through arguments, volflags, or a mix of both.
through arguments:
* `-e2d` enables file indexing on upload
2021-09-04 21:07:45 +02:00
* `-e2ds` also scans writable folders for new files on startup
* `-e2dsa` also scans all mounted volumes (including readonly ones)
* `-e2t` enables metadata indexing on upload
2021-09-04 21:07:45 +02:00
* `-e2ts` also scans for tags in all files that don't have tags yet
* `-e2tsr` also deletes all existing tags, doing a full reindex
2022-07-13 00:48:39 +02:00
* `-e2v` verfies file integrity at startup, comparing hashes from the db
* `-e2vu` patches the database with the new hashes from the filesystem
* `-e2vp` panics and kills copyparty instead
2022-08-03 22:20:28 +02:00
the same arguments can be set as volflags, in addition to `d2d`, `d2ds`, `d2t`, `d2ts`, `d2v` for disabling:
* `-v ~/music::r:c,e2dsa,e2tsr` does a full reindex of everything on startup
2021-08-06 00:50:29 +02:00
* `-v ~/music::r:c,d2d` disables **all** indexing, even if any `-e2*` are on
* `-v ~/music::r:c,d2t` disables all `-e2t*` (tags), does not affect `-e2d*`
* `-v ~/music::r:c,d2ds` disables on-boot scans; only index new uploads
* `-v ~/music::r:c,d2ts` same except only affecting tags
2021-06-10 18:08:30 +02:00
note:
* the parser can finally handle `c,e2dsa,e2tsr` so you no longer have to `c,e2dsa:c,e2tsr`
2021-07-16 02:44:06 +02:00
* `e2tsr` is probably always overkill, since `e2ds`/`e2dsa` would pick up any file modifications and `e2ts` would then reindex those, unless there is a new copyparty version with new parsers and the release note says otherwise
2021-06-10 18:08:30 +02:00
* the rescan button in the admin panel has no effect unless the volume has `-e2ds` or higher
2022-07-27 11:48:47 +02:00
### exclude-patterns
2022-08-03 22:20:28 +02:00
to save some time, you can provide a regex pattern for filepaths to only index by filename/path/size/last-modified (and not the hash of the file contents) by setting `--no-hash \.iso$` or the volflag `:c,nohash=\.iso$`, this has the following consequences:
2021-07-16 02:44:06 +02:00
* initial indexing is way faster, especially when the volume is on a network disk
2021-06-10 18:08:30 +02:00
* makes it impossible to [file-search](#file-search)
* if someone uploads the same file contents, the upload will not be detected as a dupe, so it will not get symlinked or rejected
2021-10-12 01:40:19 +02:00
similarly, you can fully ignore files/folders using `--no-idx [...]` and `:c,noidx=\.iso$`
if you set `--no-hash [...]` globally, you can enable hashing for specific volumes using flag `:c,nohash=`
2021-08-07 03:45:50 +02:00
2022-08-03 22:20:28 +02:00
### filesystem guards
avoid traversing into other filesystems using `--xdev` / volflag `:c,xdev`, skipping any symlinks or bind-mounts to another HDD for example
and/or you can `--xvol` / `:c,xvol` to ignore all symlinks leaving the volume's top directory, but still allow bind-mounts pointing elsewhere
**NB: only affects the indexer** -- users can still access anything inside a volume, unless shadowed by another volume
2022-07-27 11:48:47 +02:00
### periodic rescan
filesystem monitoring; if copyparty is not the only software doing stuff on your filesystem, you may want to enable periodic rescans to keep the index up to date
argument `--re-maxage 60` will rescan all volumes every 60 sec, same as volflag `:c,scan=60` to specify it per-volume
uploads are disabled while a rescan is happening, so rescans will be delayed by `--db-act` (default 10 sec) when there is write-activity going on (uploads, renames, ...)
2021-08-07 03:45:50 +02:00
2021-08-07 21:11:01 +02:00
## upload rules
2021-08-07 03:45:50 +02:00
2022-08-03 22:20:28 +02:00
set upload rules using volflags, some examples:
2021-08-07 03:45:50 +02:00
2021-11-12 22:30:23 +01:00
* `:c,sz=1k-3m` sets allowed filesize between 1 KiB and 3 MiB inclusive (suffixes: `b`, `k`, `m`, `g`)
2022-07-17 22:33:08 +02:00
* `:c,df=4g` block uploads if there would be less than 4 GiB free disk space afterwards
2021-08-07 03:45:50 +02:00
* `:c,nosub` disallow uploading into subdirectories; goes well with `rotn` and `rotf`:
* `:c,rotn=1000,2` moves uploads into subfolders, up to 1000 files in each folder before making a new one, two levels deep (must be at least 1)
* `:c,rotf=%Y/%m/%d/%H` enforces files to be uploaded into a structure of subfolders according to that date format
* if someone uploads to `/foo/bar` the path would be rewritten to `/foo/bar/2021/08/06/23` for example
2021-08-07 21:11:01 +02:00
* but the actual value is not verified, just the structure, so the uploader can choose any values which conform to the format string
2021-08-07 03:45:50 +02:00
* just to avoid additional complexity in up2k which is enough of a mess already
2021-08-09 22:17:41 +02:00
* `:c,lifetime=300` delete uploaded files when they become 5 minutes old
2021-08-07 03:45:50 +02:00
you can also set transaction limits which apply per-IP and per-volume, but these assume `-j 1` (default) otherwise the limits will be off, for example `-j 4` would allow anywhere between 1x and 4x the limits you set depending on which processing node the client gets routed to
* `:c,maxn=250,3600` allows 250 files over 1 hour from each IP (tracked per-volume)
* `:c,maxb=1g,300` allows 1 GiB total over 5 minutes from each IP (tracked per-volume)
2021-05-29 23:35:07 +02:00
2021-03-19 00:08:31 +01:00
2021-08-08 02:45:50 +02:00
## compress uploads
2021-09-04 21:21:18 +02:00
files can be autocompressed on upload, either on user-request (if config allows) or forced by server-config
2021-08-08 02:45:50 +02:00
2022-08-03 22:20:28 +02:00
* volflag `gz` allows gz compression
* volflag `xz` allows lzma compression
* volflag `pk` **forces** compression on all files
2021-08-08 02:45:50 +02:00
* url parameter `pk` requests compression with server-default algorithm
* url parameter `gz` or `xz` requests compression with a specific algorithm
* url parameter `xz` requests xz compression
things to note,
* the `gz` and `xz` arguments take a single optional argument, the compression level (range 0 to 9)
2022-08-03 22:20:28 +02:00
* the `pk` volflag takes the optional argument `ALGORITHM,LEVEL` which will then be forced for all uploads, for example `gz,9` or `xz,0`
2021-08-08 02:45:50 +02:00
* default compression is gzip level 9
* all upload methods except up2k are supported
* the files will be indexed after compression, so dupe-detection and file-search will not work as expected
some examples,
2021-11-20 18:50:55 +01:00
* `-v inc:inc:w:c,pk=xz,0`
folder named inc, shared at inc, write-only for everyone, forces xz compression at level 0
* `-v inc:inc:w:c,pk`
same write-only inc, but forces gz compression (default) instead of xz
* `-v inc:inc:w:c,gz`
allows (but does not force) gz compression if client uploads to `/inc?pk` or `/inc?gz` or `/inc?gz=4`
2021-08-08 02:45:50 +02:00
## database location
2021-09-04 21:07:45 +02:00
in-volume (`.hist/up2k.db`, default) or somewhere else
2021-08-22 17:23:42 +02:00
copyparty creates a subfolder named `.hist` inside each volume where it stores the database, thumbnails, and some other stuff
2022-08-03 22:20:28 +02:00
this can instead be kept in a single place using the `--hist` argument, or the `hist=` volflag, or a mix of both:
2021-08-06 00:50:29 +02:00
* `--hist ~/.cache/copyparty -v ~/music::r:c,hist=-` sets `~/.cache/copyparty` as the default place to put volume info, but `~/music` gets the regular `.hist` subfolder (`-` restores default behavior)
2021-06-10 18:08:30 +02:00
note:
* markdown edits are always stored in a local `.hist` subdirectory
2021-06-10 18:08:30 +02:00
* on windows the volflag path is cyglike, so `/c/temp` means `C:\temp` but use regular paths for `--hist`
2021-06-12 01:55:45 +02:00
* you can use cygpaths for volumes too, `-v C:\Users::r` and `-v /c/users::r` both work
2021-03-19 00:08:31 +01:00
## metadata from audio files
2021-08-22 17:23:42 +02:00
set `-e2t` to index tags on upload
`-mte` decides which tags to index and display in the browser (and also the display order), this can be changed per-volume:
2021-08-06 00:50:29 +02:00
* `-v ~/music::r:c,mte=title,artist` indexes and displays *title* followed by *artist*
if you add/remove a tag from `mte` you will need to run with `-e2tsr` once to rebuild the database, otherwise only new files will be affected
2021-09-04 21:07:45 +02:00
but instead of using `-mte`, `-mth` is a better way to hide tags in the browser: these tags will not be displayed by default, but they still get indexed and become searchable, and users can choose to unhide them in the `[⚙️] config` pane
2021-08-02 00:47:07 +02:00
`-mtm` can be used to add or redefine a metadata mapping, say you have media files with `foo` and `bar` tags and you want them to display as `qux` in the browser (preferring `foo` if both are present), then do `-mtm qux=foo,bar` and now you can `-mte artist,title,qux`
2021-03-19 00:08:31 +01:00
tags that start with a `.` such as `.bpm` and `.dur`(ation) indicate numeric value
2021-09-07 23:18:54 +02:00
see the beautiful mess of a dictionary in [mtag.py](https://github.com/9001/copyparty/blob/hovudstraum/copyparty/mtag.py) for the default mappings (should cover mp3,opus,flac,m4a,wav,aif,)
2021-07-18 22:50:29 +02:00
`--no-mutagen` disables Mutagen and uses FFprobe instead, which...
* is about 20x slower than Mutagen
* catches a few tags that Mutagen doesn't
2021-05-27 01:42:22 +02:00
* melodic key, video resolution, framerate, pixfmt
* avoids pulling any GPL code into copyparty
2021-07-18 22:50:29 +02:00
* more importantly runs FFprobe on incoming files which is bad if your FFmpeg has a cve
2021-02-22 02:33:30 +01:00
`--mtag-to` sets the tag-scan timeout; very high default (60 sec) to cater for zfs and other randomly-freezing filesystems. Lower values like 10 are usually safe, allowing for faster processing of tricky files
2021-02-22 02:33:30 +01:00
2021-03-19 00:08:31 +01:00
## file parser plugins
2021-11-20 17:51:49 +01:00
provide custom parsers to index additional tags, also see [./bin/mtag/README.md](./bin/mtag/README.md)
2021-08-22 17:23:42 +02:00
copyparty can invoke external programs to collect additional metadata for files using `mtp` (either as argument or volflag), there is a default timeout of 60sec, and only files which contain audio get analyzed by default (see ay/an/ad below)
2021-03-19 00:08:31 +01:00
2021-03-19 21:22:56 +01:00
* `-mtp .bpm=~/bin/audio-bpm.py` will execute `~/bin/audio-bpm.py` with the audio file as argument 1 to provide the `.bpm` tag, if that does not exist in the audio metadata
* `-mtp key=f,t5,~/bin/audio-key.py` uses `~/bin/audio-key.py` to get the `key` tag, replacing any existing metadata tag (`f,`), aborting if it takes longer than 5sec (`t5,`)
2021-08-06 00:50:29 +02:00
* `-v ~/music::r:c,mtp=.bpm=~/bin/audio-bpm.py:c,mtp=key=f,t5,~/bin/audio-key.py` both as a per-volume config wow this is getting ugly
2021-03-19 00:08:31 +01:00
2022-07-05 23:27:48 +02:00
*but wait, there's more!* `-mtp` can be used for non-audio files as well using the `a` flag: `ay` only do audio files (default), `an` only do non-audio files, or `ad` do all files (d as in dontcare)
2021-05-16 07:04:18 +02:00
2022-07-03 14:23:56 +02:00
* "audio file" also means videos btw, as long as there is an audio stream
2021-05-16 07:04:18 +02:00
* `-mtp ext=an,~/bin/file-ext.py` runs `~/bin/file-ext.py` to get the `ext` tag only if file is not audio (`an`)
2021-05-29 04:18:57 +02:00
* `-mtp arch,built,ver,orig=an,eexe,edll,~/bin/exe.py` runs `~/bin/exe.py` to get properties about windows-binaries only if file is not audio (`an`) and file extension is exe or dll
2022-09-04 01:42:28 +02:00
* if you want to daisychain parsers, use the `p` flag to set processing order
* `-mtp foo=p1,~/a.py` runs before `-mtp foo=p2,~/b.py` and will forward all the tags detected so far as json to the stdin of b.py
* option `c0` disables capturing of stdout/stderr, so copyparty will not receive any tags from the process at all -- instead the invoked program is free to print whatever to the console, just using copyparty as a launcher
* `c1` captures stdout only, `c2` only stderr, and `c3` (default) captures both
* you can control how the parser is killed if it times out with option `kt` killing the entire process tree (default), `km` just the main process, or `kn` let it continue running until copyparty is terminated
2022-07-05 23:27:48 +02:00
2022-07-03 14:23:56 +02:00
if something doesn't work, try `--mtag-v` for verbose error messages
2021-03-19 00:08:31 +01:00
2021-10-09 22:09:35 +02:00
## upload events
trigger a script/program on each upload like so:
```
2022-07-05 23:27:48 +02:00
-v /mnt/inc:inc:w:c,mte=+x1:c,mtp=x1=ad,kn,/usr/bin/notify-send
2021-10-09 22:09:35 +02:00
```
2022-07-05 23:27:48 +02:00
so filesystem location `/mnt/inc` shared at `/inc`, write-only for everyone, appending `x1` to the list of tags to index (`mte`), and using `/usr/bin/notify-send` to "provide" tag `x1` for any filetype (`ad`) with kill-on-timeout disabled (`kn`)
2021-10-09 22:09:35 +02:00
that'll run the command `notify-send` with the path to the uploaded file as the first and only argument (so on linux it'll show a notification on-screen)
note that it will only trigger on new unique files, not dupes
2022-09-04 01:42:28 +02:00
and it will occupy the parsing threads, so fork anything expensive (or set `kn` to have copyparty fork it for you) -- otoh if you want to intentionally queue/singlethread you can combine it with `--mtag-mt 1`
2021-10-09 22:09:35 +02:00
if this becomes popular maybe there should be a less janky way to do it actually
2022-03-20 06:15:57 +01:00
## hiding from google
tell search engines you dont wanna be indexed, either using the good old [robots.txt](https://www.robotstxt.org/robotstxt.html) or through copyparty settings:
* `--no-robots` adds HTTP (`X-Robots-Tag`) and HTML (`<meta>`) headers with `noindex, nofollow` globally
2022-08-03 22:20:28 +02:00
* volflag `[...]:c,norobots` does the same thing for that single volume
* volflag `[...]:c,robots` ALLOWS search-engine crawling for that volume, even if `--no-robots` is set globally
2022-03-20 06:15:57 +01:00
also, `--force-js` disables the plain HTML folder listing, making things harder to parse for search engines
2022-04-29 02:06:56 +02:00
## themes
2022-04-30 02:16:34 +02:00
you can change the default theme with `--theme 2`, and add your own themes by modifying `browser.css` or providing your own css to `--css-browser`, then telling copyparty they exist by increasing `--themes`
2022-04-29 02:06:56 +02:00
2022-04-29 23:13:37 +02:00
<table><tr><td width="33%" align="center"><a href="https://user-images.githubusercontent.com/241032/165864907-17e2ac7d-319d-4f25-8718-2f376f614b51.png"><img src="https://user-images.githubusercontent.com/241032/165867551-fceb35dd-38f0-42bb-bef3-25ba651ca69b.png"></a>
2022-05-16 18:56:53 +02:00
0. classic dark</td><td width="33%" align="center"><a href="https://user-images.githubusercontent.com/241032/168644399-68938de5-da9b-445f-8d92-b51c74b5f345.png"><img src="https://user-images.githubusercontent.com/241032/168644404-8e1a2fdc-6e59-4c41-905e-ba5399ed686f.png"></a>
2. flat pm-monokai</td><td width="33%" align="center"><a href="https://user-images.githubusercontent.com/241032/165864901-db13a429-a5da-496d-8bc6-ce838547f69d.png"><img src="https://user-images.githubusercontent.com/241032/165867560-aa834aef-58dc-4abe-baef-7e562b647945.png"></a>
2022-04-29 23:13:37 +02:00
4. vice</td></tr><tr><td align="center"><a href="https://user-images.githubusercontent.com/241032/165864905-692682eb-6fb4-4d40-b6fe-27d2c7d3e2a7.png"><img src="https://user-images.githubusercontent.com/241032/165867555-080b73b6-6d85-41bb-a7c6-ad277c608365.png"></a>
2022-05-16 19:01:32 +02:00
1. classic light</td><td align="center"><a href="https://user-images.githubusercontent.com/241032/168645276-fb02fd19-190a-407a-b8d3-d58fee277e02.png"><img src="https://user-images.githubusercontent.com/241032/168645280-f0662b3c-9764-4875-a2e2-d91cc8199b23.png"></a>
2022-04-29 23:13:37 +02:00
3. flat light
</td><td align="center"><a href="https://user-images.githubusercontent.com/241032/165864898-10ce7052-a117-4fcf-845b-b56c91687908.png"><img src="https://user-images.githubusercontent.com/241032/165867562-f3003d45-dd2a-4564-8aae-fed44c1ae064.png"></a>
5. <a href="https://blog.codinghorror.com/a-tribute-to-the-windows-31-hot-dog-stand-color-scheme/">hotdog stand</a></td></tr></table>
2022-04-29 02:06:56 +02:00
the classname of the HTML tag is set according to the selected theme, which is used to set colors as css variables ++
* each theme *generally* has a dark theme (even numbers) and a light theme (odd numbers), showing in pairs
* the first theme (theme 0 and 1) is `html.a`, second theme (2 and 3) is `html.b`
* if a light theme is selected, `html.y` is set, otherwise `html.z` is
2022-04-29 23:13:37 +02:00
* so if the dark edition of the 2nd theme is selected, you use any of `html.b`, `html.z`, `html.bz` to specify rules
2022-04-29 02:06:56 +02:00
see the top of [./copyparty/web/browser.css](./copyparty/web/browser.css) where the color variables are set, and there's layout-specific stuff near the bottom
2021-03-21 14:15:55 +01:00
## complete examples
2022-07-06 00:00:56 +02:00
* read-only music server
2022-07-06 00:12:10 +02:00
`python copyparty-sfx.py -v /mnt/nas/music:/music:r -e2dsa -e2ts --no-robots --force-js --theme 2`
2022-07-06 00:00:56 +02:00
* ...with bpm and key scanning
`-mtp .bpm=f,audio-bpm.py -mtp key=f,audio-key.py`
* ...with a read-write folder for `kevin` whose password is `okgo`
`-a kevin:okgo -v /mnt/nas/inc:/inc:rw,kevin`
* ...with logging to disk
`-lo log/cpp-%Y-%m%d-%H%M%S.txt.xz`
2021-03-21 14:15:55 +01:00
# browser support
2021-08-22 17:23:42 +02:00
TLDR: yes
2021-05-14 00:00:15 +02:00
![copyparty-ie4-fs8](https://user-images.githubusercontent.com/241032/118192791-fb31fe00-b446-11eb-9647-898ea8efc1f7.png)
2021-04-25 22:44:50 +02:00
2021-04-03 02:58:50 +02:00
`ie` = internet-explorer, `ff` = firefox, `c` = chrome, `iOS` = iPhone/iPad, `Andr` = Android
2021-08-16 07:37:41 +02:00
| feature | ie6 | ie9 | ie10 | ie11 | ff 52 | c 49 | iOS | Andr |
2021-08-16 08:18:52 +02:00
| --------------- | --- | ---- | ---- | ---- | ----- | ---- | --- | ---- |
2021-08-16 07:37:41 +02:00
| browse files | yep | yep | yep | yep | yep | yep | yep | yep |
| thumbnail view | - | yep | yep | yep | yep | yep | yep | yep |
| basic uploader | yep | yep | yep | yep | yep | yep | yep | yep |
2021-08-16 08:16:52 +02:00
| up2k | - | - | `*1` | `*1` | yep | yep | yep | yep |
2021-08-16 07:37:41 +02:00
| make directory | yep | yep | yep | yep | yep | yep | yep | yep |
| send message | yep | yep | yep | yep | yep | yep | yep | yep |
| set sort order | - | yep | yep | yep | yep | yep | yep | yep |
| zip selection | - | yep | yep | yep | yep | yep | yep | yep |
| file rename | - | yep | yep | yep | yep | yep | yep | yep |
| file cut/paste | - | yep | yep | yep | yep | yep | yep | yep |
2021-10-24 02:57:19 +02:00
| navpane | - | yep | yep | yep | yep | yep | yep | yep |
2021-08-16 07:37:41 +02:00
| image viewer | - | yep | yep | yep | yep | yep | yep | yep |
| video player | - | yep | yep | yep | yep | yep | yep | yep |
| markdown editor | - | - | yep | yep | yep | yep | yep | yep |
2021-09-18 02:07:09 +02:00
| markdown viewer | - | yep | yep | yep | yep | yep | yep | yep |
2021-08-16 07:37:41 +02:00
| play mp3/m4a | - | yep | yep | yep | yep | yep | yep | yep |
| play ogg/opus | - | - | - | - | yep | yep | `*3` | yep |
| **= feature =** | ie6 | ie9 | ie10 | ie11 | ff 52 | c 49 | iOS | Andr |
2021-04-03 08:26:42 +02:00
* internet explorer 6 to 8 behave the same
2021-09-04 21:07:45 +02:00
* firefox 52 and chrome 49 are the final winxp versions
* `*1` yes, but extremely slow (ie10: `1 MiB/s`, ie11: `270 KiB/s`)
2021-11-15 20:28:53 +01:00
* `*3` iOS 11 and newer, opus only, and requires FFmpeg on the server
quick summary of more eccentric web-browsers trying to view a directory index:
2021-05-16 08:52:22 +02:00
| browser | will it blend |
| ------- | ------------- |
2021-05-16 09:05:40 +02:00
| **links** (2.21/macports) | can browse, login, upload/mkdir/msg |
| **lynx** (2.8.9/macports) | can browse, login, upload/mkdir/msg |
| **w3m** (0.5.3/macports) | can browse, login, upload at 100kB/s, mkdir/msg |
| **netsurf** (3.10/arch) | is basically ie6 with much better css (javascript has almost no effect) |
2021-08-16 07:37:41 +02:00
| **opera** (11.60/winxp) | OK: thumbnails, image-viewer, zip-selection, rename/cut/paste. NG: up2k, navpane, markdown, audio |
2022-05-01 11:29:51 +02:00
| **ie4** and **netscape** 4.0 | can browse, upload with `?b=u`, auth with `&pw=wark` |
2022-06-17 00:37:56 +02:00
| **ncsa mosaic** 2.7 | does not get a pass, [pic1](https://user-images.githubusercontent.com/241032/174189227-ae816026-cf6f-4be5-a26e-1b3b072c1b2f.png) - [pic2](https://user-images.githubusercontent.com/241032/174189225-5651c059-5152-46e9-ac26-7e98e497901b.png) |
2021-07-16 02:44:06 +02:00
| **SerenityOS** (7e98457) | hits a page fault, works with `?b=u`, file upload not-impl |
2021-05-16 08:52:22 +02:00
2020-08-08 00:47:54 +00:00
# client examples
2021-08-22 17:23:42 +02:00
interact with copyparty using non-browser clients
2020-08-08 00:47:54 +00:00
* javascript: dump some state into a file (two separate examples)
2021-11-12 22:30:23 +01:00
* `await fetch('//127.0.0.1:3923/', {method:"PUT", body: JSON.stringify(foo)});`
* `var xhr = new XMLHttpRequest(); xhr.open('POST', '//127.0.0.1:3923/msgs?raw'); xhr.send('foo');`
2020-08-08 00:47:54 +00:00
2021-02-25 22:26:03 +01:00
* curl/wget: upload some files (post=file, chunk=stdin)
2021-08-08 02:45:50 +02:00
* `post(){ curl -b cppwd=wark -F act=bput -F f=@"$1" http://127.0.0.1:3923/;}`
2021-02-25 22:26:03 +01:00
`post movie.mkv`
2021-08-08 02:45:50 +02:00
* `post(){ wget --header='Cookie: cppwd=wark' --post-file="$1" -O- http://127.0.0.1:3923/?raw;}`
2021-02-25 22:26:03 +01:00
`post movie.mkv`
2021-08-08 02:45:50 +02:00
* `chunk(){ curl -b cppwd=wark -T- http://127.0.0.1:3923/;}`
2021-02-25 22:26:03 +01:00
`chunk <movie.mkv`
2021-10-01 19:27:21 +02:00
* bash: when curl and wget is not available or too boring
* `(printf 'PUT /junk?pw=wark HTTP/1.1\r\n\r\n'; cat movie.mkv) | nc 127.0.0.1 3923`
* `(printf 'PUT / HTTP/1.1\r\n\r\n'; cat movie.mkv) >/dev/tcp/127.0.0.1/3923`
2021-10-01 02:25:22 +02:00
* python: [up2k.py](https://github.com/9001/copyparty/blob/hovudstraum/bin/up2k.py) is a command-line up2k client [(webm)](https://ocv.me/stuff/u2cli.webm)
2021-10-01 00:33:45 +02:00
* file uploads, file-search, autoresume of aborted/broken uploads
* see [./bin/README.md#up2kpy](bin/README.md#up2kpy)
2021-09-27 23:28:34 +02:00
2020-10-25 08:05:11 +01:00
* FUSE: mount a copyparty server as a local filesystem
* cross-platform python client available in [./bin/](bin/)
* [rclone](https://rclone.org/) as client can give ~5x performance, see [./docs/rclone.md](docs/rclone.md)
2020-08-08 00:47:54 +00:00
2021-06-06 02:53:01 +02:00
* sharex (screenshot utility): see [./contrib/sharex.sxcu](contrib/#sharexsxcu)
2021-02-25 22:26:03 +01:00
copyparty returns a truncated sha512sum of your PUT/POST as base64; you can generate the same checksum locally to verify uplaods:
2021-06-20 18:53:58 +02:00
b512(){ printf "$((sha512sum||shasum -a512)|sed -E 's/ .*//;s/(..)/\\x\1/g')"|base64|tr '+/' '-_'|head -c44;}
2021-02-25 22:26:03 +01:00
b512 <movie.mkv
2021-12-04 18:52:14 +01:00
you can provide passwords using cookie `cppwd=hunter2`, as a url query `?pw=hunter2`, or with basic-authentication (either as the username or password)
2021-09-04 21:40:22 +02:00
2020-08-08 00:47:54 +00:00
2021-04-25 03:00:47 +02:00
# up2k
2021-04-25 22:44:50 +02:00
quick outline of the up2k protocol, see [uploading](#uploading) for the web-client
2021-04-25 03:00:47 +02:00
* the up2k client splits a file into an "optimal" number of chunks
* 1 MiB each, unless that becomes more than 256 chunks
2021-05-16 08:52:22 +02:00
* tries 1.5M, 2M, 3, 4, 6, ... until <= 256 chunks or size >= 32M
2021-05-02 09:16:14 +02:00
* client posts the list of hashes, filename, size, last-modified
2021-04-25 03:00:47 +02:00
* server creates the `wark`, an identifier for this upload
* `sha512( salt + filesize + chunk_hashes )`
* and a sparse file is created for the chunks to drop into
* client uploads each chunk
* header entries for the chunk-hash and wark
* server writes chunks into place based on the hash
* client does another handshake with the hashlist; server replies with OK or a list of chunks to reupload
2021-09-04 21:07:45 +02:00
up2k has saved a few uploads from becoming corrupted in-transfer already; caught an android phone on wifi redhanded in wireshark with a bitflip, however bup with https would *probably* have noticed as well (thanks to tls also functioning as an integrity check)
2022-07-12 21:22:02 +02:00
regarding the frequent server log message during uploads;
`6.0M 106M/s 2.77G 102.9M/s n948 thank 4/0/3/1 10042/7198 00:01:09`
2022-07-12 21:22:02 +02:00
* this chunk was `6 MiB`, uploaded at `106 MiB/s`
* on this http connection, `2.77 GiB` transferred, `102.9 MiB/s` average, `948` chunks handled
* client says `4` uploads OK, `0` failed, `3` busy, `1` queued, `10042 MiB` total size, `7198 MiB` and `00:01:09` left
2022-07-12 21:22:02 +02:00
2021-09-04 21:07:45 +02:00
## why chunk-hashes
2021-09-04 21:21:18 +02:00
a single sha512 would be better, right?
2021-09-04 21:07:45 +02:00
2022-07-05 23:27:48 +02:00
this is due to `crypto.subtle` [not yet](https://github.com/w3c/webcrypto/issues/73) providing a streaming api (or the option to seed the sha512 hasher with a starting hash)
2021-09-04 21:07:45 +02:00
as a result, the hashes are much less useful than they could have been (search the server by sha512, provide the sha512 in the response http headers, ...)
2022-08-13 00:58:49 +02:00
however it allows for hashing multiple chunks in parallel, greatly increasing upload speed from fast storage (NVMe, raid-0 and such)
* both the [browser uploader](#uploading) and the [commandline one](https://github.com/9001/copyparty/blob/hovudstraum/bin/up2k.py) does this now, allowing for fast uploading even from plaintext http
2021-09-04 21:07:45 +02:00
hashwasm would solve the streaming issue but reduces hashing speed for sha512 (xxh128 does 6 GiB/s), and it would make old browsers and [iphones](https://bugs.webkit.org/show_bug.cgi?id=228552) unsupported
2022-07-05 23:27:48 +02:00
* blake2 might be a better choice since xxh is non-cryptographic, but that gets ~15 MiB/s on slower androids
2021-04-25 03:00:47 +02:00
2021-07-09 17:10:37 +02:00
# performance
2021-09-04 21:40:22 +02:00
defaults are usually fine - expect `8 GiB/s` download, `1 GiB/s` upload
2021-08-22 17:23:42 +02:00
2021-07-09 17:10:37 +02:00
below are some tweaks roughly ordered by usefulness:
* `-q` disables logging and can help a bunch, even when combined with `-lo` to redirect logs to file
* `--http-only` or `--https-only` (unless you want to support both protocols) will reduce the delay before a new connection is established
* `--hist` pointing to a fast location (ssd) will make directory listings and searches faster when `-e2d` or `-e2t` is set
2021-10-12 01:40:19 +02:00
* `--no-hash .` when indexing a network-disk if you don't care about the actual filehashes and only want the names/tags searchable
2021-07-09 17:12:21 +02:00
* `-j` enables multiprocessing (actual multithreading) and can make copyparty perform better in cpu-intensive workloads, for example:
2021-07-09 17:10:37 +02:00
* huge amount of short-lived connections
* really heavy traffic (downloads/uploads)
2021-07-09 17:12:21 +02:00
...however it adds an overhead to internal communication so it might be a net loss, see if it works 4 u
2021-07-09 17:10:37 +02:00
2021-10-31 06:24:11 +01:00
## client-side
when uploading files,
* chrome is recommended, at least compared to firefox:
* up to 90% faster when hashing, especially on SSDs
* up to 40% faster when uploading over extremely fast internets
* but [up2k.py](https://github.com/9001/copyparty/blob/hovudstraum/bin/up2k.py) can be 40% faster than chrome again
* if you're cpu-bottlenecked, or the browser is maxing a cpu core:
* up to 30% faster uploads if you hide the upload status list by switching away from the `[🚀]` up2k ui-tab (or closing it)
2022-08-13 00:58:49 +02:00
* optionally you can switch to the lightweight potato ui by clicking the `[🥔]`
2021-10-31 15:30:09 +01:00
* switching to another browser-tab also works, the favicon will update every 10 seconds in that case
2021-10-31 06:24:11 +01:00
* unlikely to be a problem, but can happen when uploding many small files, or your internet is too fast, or PC too slow
2021-09-06 00:23:35 +02:00
# security
some notes on hardening
2022-06-19 16:05:48 +02:00
* option `-s` is a shortcut to set the following options:
* `--no-thumb` disables thumbnails and audio transcoding to stop copyparty from running `FFmpeg`/`Pillow`/`VIPS` on uploaded files, which is a [good idea](https://www.cvedetails.com/vulnerability-list.php?vendor_id=3611) if anonymous upload is enabled
* `--no-mtag-ff` uses `mutagen` to grab music tags instead of `FFmpeg`, which is safer and faster but less accurate
* `--dotpart` hides uploads from directory listings while they're still incoming
* `--no-robots` and `--force-js` makes life harder for crawlers, see [hiding from google](#hiding-from-google)
* option `-ss` is a shortcut for the above plus:
* `--no-logues` and `--no-readme` disables support for readme's and prologues / epilogues in directory listings, which otherwise lets people upload arbitrary `<script>` tags
* `--unpost 0`, `--no-del`, `--no-mv` disables all move/delete support
* `--hardlink` creates hardlinks instead of symlinks when deduplicating uploads, which is less maintenance
* however note if you edit one file it will also affect the other copies
* `--vague-403` returns a "404 not found" instead of "403 forbidden" which is a common enterprise meme
* `--nih` removes the server hostname from directory listings
* option `-sss` is a shortcut for the above plus:
* `-lo cpp-%Y-%m%d-%H%M%S.txt.xz` enables logging to disk
* `-ls **,*,ln,p,r` does a scan on startup for any dangerous symlinks
other misc notes:
2021-09-15 23:17:02 +02:00
2021-09-18 17:50:40 +02:00
* you can disable directory listings by giving permission `g` instead of `r`, only accepting direct URLs to files
2022-08-03 22:20:28 +02:00
* combine this with volflag `c,fk` to generate per-file accesskeys; users which have full read-access will then see URLs with `?k=...` appended to the end, and `g` users must provide that URL including the correct key to avoid a 404
2021-09-15 23:17:02 +02:00
2021-09-06 00:23:35 +02:00
## gotchas
behavior that might be unexpected
* users without read-access to a folder can still see the `.prologue.html` / `.epilogue.html` / `README.md` contents, for the purpose of showing a description on how to use the uploader for example
2021-09-25 18:03:19 +02:00
# recovering from crashes
## client crashes
### frefox wsod
firefox 87 can crash during uploads -- the entire browser goes, including all other browser tabs, everything turns white
however you can hit `F12` in the up2k tab and use the devtools to see how far you got in the uploads:
* get a complete list of all uploads, organized by statuts (ok / no-good / busy / queued):
`var tabs = { ok:[], ng:[], bz:[], q:[] }; for (var a of up2k.ui.tab) tabs[a.in].push(a); tabs`
* list of filenames which failed:
`var ng = []; for (var a of up2k.ui.tab) if (a.in != 'ok') ng.push(a.hn.split('<a href=\"').slice(-1)[0].split('\">')[0]); ng`
2021-09-25 18:03:19 +02:00
* send the list of filenames to copyparty for safekeeping:
`await fetch('/inc', {method:'PUT', body:JSON.stringify(ng,null,1)})`
2021-10-31 15:30:09 +01:00
# HTTP API
* table-column `params` = URL parameters; `?foo=bar&qux=...`
* table-column `body` = POST payload
* method `jPOST` = json post
* method `mPOST` = multipart post
* method `uPOST` = url-encoded post
* `FILE` = conventional HTTP file upload entry (rfc1867 et al, filename in `Content-Disposition`)
authenticate using header `Cookie: cppwd=foo` or url param `&pw=foo`
## read
| method | params | result |
|--|--|--|
| GET | `?ls` | list files/folders at URL as JSON |
| GET | `?ls&dots` | list files/folders at URL as JSON, including dotfiles |
| GET | `?ls=t` | list files/folders at URL as plaintext |
| GET | `?ls=v` | list files/folders at URL, terminal-formatted |
| GET | `?b` | list files/folders at URL as simplified HTML |
| GET | `?tree=.` | list one level of subdirectories inside URL |
| GET | `?tree` | list one level of subdirectories for each level until URL |
| GET | `?tar` | download everything below URL as a tar file |
| GET | `?zip=utf-8` | download everything below URL as a zip file |
| GET | `?ups` | show recent uploads from your IP |
| GET | `?ups&filter=f` | ...where URL contains `f` |
2021-11-06 22:15:37 +01:00
| GET | `?mime=foo` | specify return mimetype `foo` |
2021-10-31 15:30:09 +01:00
| GET | `?raw` | get markdown file at URL as plaintext |
2021-11-06 22:15:37 +01:00
| GET | `?txt` | get file at URL as plaintext |
| GET | `?txt=iso-8859-1` | ...with specific charset |
2021-10-31 15:30:09 +01:00
| GET | `?th` | get image/video at URL as thumbnail |
2021-11-06 22:15:37 +01:00
| GET | `?th=opus` | convert audio file to 128kbps opus |
2021-11-15 20:28:53 +01:00
| GET | `?th=caf` | ...in the iOS-proprietary container |
2021-10-31 15:30:09 +01:00
| method | body | result |
|--|--|--|
| jPOST | `{"q":"foo"}` | do a server-wide search; see the `[🔎]` search tab `raw` field for syntax |
| method | params | body | result |
|--|--|--|--|
| jPOST | `?tar` | `["foo","bar"]` | download folders `foo` and `bar` inside URL as a tar file |
## write
| method | params | result |
|--|--|--|
| GET | `?move=/foo/bar` | move/rename the file/folder at URL to /foo/bar |
| method | params | body | result |
|--|--|--|--|
| PUT | | (binary data) | upload into file at URL |
| PUT | `?gz` | (binary data) | compress with gzip and write into file at URL |
| PUT | `?xz` | (binary data) | compress with xz and write into file at URL |
| mPOST | | `act=bput`, `f=FILE` | upload `FILE` into the folder at URL |
| mPOST | `?j` | `act=bput`, `f=FILE` | ...and reply with json |
| mPOST | | `act=mkdir`, `name=foo` | create directory `foo` at URL |
| GET | `?delete` | | delete URL recursively |
| jPOST | `?delete` | `["/foo","/bar"]` | delete `/foo` and `/bar` recursively |
| uPOST | | `msg=foo` | send message `foo` into server log |
| mPOST | | `act=tput`, `body=TEXT` | overwrite markdown document at URL |
server behavior of `msg` can be reconfigured with `--urlform`
## admin
| method | params | result |
|--|--|--|
2021-11-06 22:15:37 +01:00
| GET | `?reload=cfg` | reload config files and rescan volumes |
2021-10-31 15:30:09 +01:00
| GET | `?scan` | initiate a rescan of the volume which provides URL |
| GET | `?stack` | show a stacktrace of all threads |
## general
| method | params | result |
|--|--|--|
| GET | `?pw=x` | logout |
2019-06-10 15:47:08 +00:00
# dependencies
2019-06-07 08:54:41 +00:00
2021-08-22 17:23:42 +02:00
mandatory deps:
2021-03-02 01:02:13 +01:00
* `jinja2` (is built into the SFX)
2019-06-07 08:54:41 +00:00
2021-05-25 06:14:25 +02:00
## optional dependencies
2021-08-22 17:23:42 +02:00
install these to enable bonus features
2022-02-13 20:44:03 +01:00
enable ftp-server:
* for just plaintext FTP, `pyftpdlib` (is built into the SFX)
* with TLS encryption, `pyftpdlib pyopenssl`
2021-05-25 06:14:25 +02:00
enable music tags:
2021-03-02 01:02:13 +01:00
* either `mutagen` (fast, pure-python, skips a few tags, makes copyparty GPL? idk)
2021-07-18 22:50:29 +02:00
* or `ffprobe` (20x slower, more accurate, possibly dangerous depending on your distro and users)
2021-03-02 00:31:08 +01:00
2021-09-04 21:07:45 +02:00
enable [thumbnails](#thumbnails) of...
2022-04-11 10:38:57 +02:00
* **images:** `Pillow` and/or `pyvips` and/or `ffmpeg` (requires py2.7 or py3.5+)
2021-11-06 22:15:37 +01:00
* **videos/audio:** `ffmpeg` and `ffprobe` somewhere in `$PATH`
2022-04-11 10:38:57 +02:00
* **HEIF pictures:** `pyvips` or `ffmpeg` or `pyheif-pillow-opener` (requires Linux or a C compiler)
* **AVIF pictures:** `pyvips` or `ffmpeg` or `pillow-avif-plugin`
* **JPEG XL pictures:** `pyvips` or `ffmpeg`
`pyvips` gives higher quality thumbnails than `Pillow` and is 320% faster, using 270% more ram: `sudo apt install libvips42 && python3 -m pip install --user -U pyvips`
2021-05-28 05:01:12 +02:00
2021-05-25 03:37:01 +02:00
2021-05-26 00:47:43 +02:00
## install recommended deps
2021-05-25 03:37:01 +02:00
```
python -m pip install --user -U jinja2 mutagen Pillow
```
2019-06-10 15:47:08 +00:00
2021-03-17 00:55:27 +01:00
## optional gpl stuff
2021-03-17 01:37:59 +01:00
some bundled tools have copyleft dependencies, see [./bin/#mtag](bin/#mtag)
2021-03-17 00:55:27 +01:00
2021-07-16 02:56:21 +02:00
these are standalone programs and will never be imported / evaluated by copyparty, and must be enabled through `-mtp` configs
2021-03-17 00:55:27 +01:00
2020-05-06 00:39:21 +02:00
# sfx
2022-02-13 20:44:03 +01:00
the self-contained "binary" [copyparty-sfx.py](https://github.com/9001/copyparty/releases/latest/download/copyparty-sfx.py) will unpack itself and run copyparty, assuming you have python installed of course
2020-05-06 00:39:21 +02:00
2020-06-24 23:53:23 +00:00
## sfx repack
2021-08-26 01:16:59 +02:00
reduce the size of an sfx by removing features
2021-08-22 17:23:42 +02:00
2021-07-16 02:44:06 +02:00
if you don't need all the features, you can repack the sfx and save a bunch of space; all you need is an sfx and a copy of this repo (nothing else to download or build, except if you're on windows then you need msys2 or WSL)
2021-11-15 20:28:53 +01:00
* `393k` size of original sfx.py as of v1.1.3
* `310k` after `./scripts/make-sfx.sh re no-cm`
* `269k` after `./scripts/make-sfx.sh re no-cm no-hl`
2020-05-06 00:39:21 +02:00
2020-05-13 01:12:33 +02:00
the features you can opt to drop are
2021-11-08 21:11:10 +01:00
* `cm`/easymde, the "fancy" markdown editor, saves ~82k
2021-11-06 22:15:37 +01:00
* `hl`, prism, the syntax hilighter, saves ~41k
2021-09-05 18:55:28 +02:00
* `fnt`, source-code-pro, the monospace font, saves ~9k
* `dd`, the custom mouse cursor for the media player tray tab, saves ~2k
2020-05-06 00:39:21 +02:00
2020-05-13 01:12:33 +02:00
for the `re`pack to work, first run one of the sfx'es once to unpack it
2020-05-06 00:39:21 +02:00
2021-11-15 20:28:53 +01:00
**note:** you can also just download and run [scripts/copyparty-repack.sh](scripts/copyparty-repack.sh) -- this will grab the latest copyparty release from github and do a few repacks; works on linux/macos (and windows with msys2 or WSL)
2020-11-19 01:23:24 +01:00
2020-05-06 00:39:21 +02:00
2019-06-13 11:38:05 +00:00
# install on android
2019-06-10 15:47:08 +00:00
2019-06-13 11:38:05 +00:00
install [Termux](https://termux.com/) (see [ocv.me/termux](https://ocv.me/termux/)) and then copy-paste this into Termux (long-tap) all at once:
2019-06-10 15:47:08 +00:00
```sh
2022-05-12 23:10:54 +02:00
apt update && apt -y full-upgrade && apt update && termux-setup-storage && apt -y install python && python -m ensurepip && python -m pip install --user -U copyparty
2019-06-13 11:43:05 +00:00
echo $?
2019-06-10 15:47:08 +00:00
```
2020-11-19 01:23:24 +01:00
after the initial setup, you can launch copyparty at any time by running `copyparty` anywhere in Termux
2019-06-10 15:47:08 +00:00
2022-05-12 23:10:54 +02:00
if you want thumbnails, `apt -y install ffmpeg`
* or if you want to use vips instead, `apt -y install libvips && python -m pip install --user -U wheel && python -m pip install --user -U pyvips && (cd /data/data/com.termux/files/usr/lib/; ln -s libgobject-2.0.so{,.0}; ln -s libvips.so{,.42})`
2019-06-10 15:47:08 +00:00
2021-11-15 20:28:53 +01:00
# reporting bugs
ideas for context to include in bug reports
2022-07-16 20:43:26 +02:00
in general, commandline arguments (and config file if any)
2021-11-15 20:28:53 +01:00
if something broke during an upload (replacing FILENAME with a part of the filename that broke):
```
journalctl -aS '48 hour ago' -u copyparty | grep -C10 FILENAME | tee bug.log
```
2022-07-16 20:43:26 +02:00
if there's a wall of base64 in the log (thread stacks) then please include that, especially if you run into something freezing up or getting stuck, for example `OperationalError('database is locked')` -- alternatively you can visit `/?stack` to see the stacks live, so http://127.0.0.1:3923/?stack for example
2021-11-15 20:28:53 +01:00
2021-06-19 16:20:35 +02:00
# building
## dev env setup
2022-06-16 01:07:15 +02:00
you need python 3.9 or newer due to type hints
the rest is mostly optional; if you need a working env for vscode or similar
2019-06-25 23:21:15 +00:00
2019-06-10 15:47:08 +00:00
```sh
2020-04-14 22:42:43 +00:00
python3 -m venv .venv
. .venv/bin/activate
2022-06-16 01:07:15 +02:00
pip install jinja2 strip_hints # MANDATORY
2021-06-19 16:20:35 +02:00
pip install mutagen # audio metadata
2022-06-16 01:07:15 +02:00
pip install pyftpdlib # ftp server
2021-06-19 16:20:35 +02:00
pip install Pillow pyheif-pillow-opener pillow-avif-plugin # thumbnails
2022-06-16 01:07:15 +02:00
pip install black==21.12b0 click==8.0.2 bandit pylint flake8 isort mypy # vscode tooling
2019-06-10 02:34:35 +00:00
```
2019-06-07 08:54:41 +00:00
2019-06-10 15:47:08 +00:00
2021-06-19 16:20:35 +02:00
## just the sfx
2021-09-04 21:21:18 +02:00
first grab the web-dependencies from a previous sfx (assuming you don't need to modify something in those):
2021-06-19 16:20:35 +02:00
```sh
rm -rf copyparty/web/deps
curl -L https://github.com/9001/copyparty/releases/latest/download/copyparty-sfx.py >x.py
python3 x.py -h
rm x.py
2021-07-16 02:44:06 +02:00
mv /tmp/pe-copyparty/copyparty/web/deps/ copyparty/web/deps/
2021-06-19 16:20:35 +02:00
```
then build the sfx using any of the following examples:
```sh
2022-02-13 20:44:03 +01:00
./scripts/make-sfx.sh # regular edition
./scripts/make-sfx.sh gz no-cm # gzip-compressed + no fancy markdown editor
2021-06-19 16:20:35 +02:00
```
## complete release
2021-08-22 17:23:42 +02:00
also builds the sfx so skip the sfx section above
2019-06-25 23:21:15 +00:00
in the `scripts` folder:
* run `make -C deps-docker` to build all dependencies
2022-07-05 23:27:48 +02:00
* run `./rls.sh 1.2.3` which uploads to pypi + creates github release + sfx
2019-06-25 23:21:15 +00:00
2019-06-29 20:19:32 +00:00
# todo
2019-06-10 15:47:08 +00:00
roughly sorted by priority
2021-09-07 00:05:51 +02:00
* nothing! currently
2021-04-03 04:13:51 +02:00
2021-07-16 02:56:21 +02:00
## discarded ideas
2021-04-03 04:13:51 +02:00
2021-07-16 02:44:06 +02:00
* reduce up2k roundtrips
* start from a chunk index and just go
* terminate client on bad data
* not worth the effort, just throw enough conncetions at it
2021-06-29 23:00:28 +02:00
* single sha512 across all up2k chunks?
* crypto.subtle cannot into streaming, would have to use hashwasm, expensive
2021-06-02 09:42:33 +02:00
* separate sqlite table per tag
* performance fixed by skipping some indexes (`+mt.k`)
* audio fingerprinting
* only makes sense if there can be a wasm client and that doesn't exist yet (except for olaf which is agpl hence counts as not existing)
* `os.copy_file_range` for up2k cloning
* almost never hit this path anyways
2021-04-03 04:13:51 +02:00
* up2k partials ui
2021-06-02 09:42:33 +02:00
* feels like there isn't much point
2021-04-03 04:13:51 +02:00
* cache sha512 chunks on client
2022-07-05 23:27:48 +02:00
* too dangerous -- overtaken by turbo mode
2021-04-03 04:13:51 +02:00
* comment field
2021-06-02 09:42:33 +02:00
* nah
2021-04-03 04:13:51 +02:00
* look into android thumbnail cache file format
2021-06-02 09:42:33 +02:00
* absolutely not
2021-07-04 00:32:29 +02:00
* indexedDB for hashes, cfg enable/clear/sz, 2gb avail, ~9k for 1g, ~4k for 100m, 500k items before autoeviction
* blank hashlist when up-ok to skip handshake
* too many confusing side-effects
2021-09-07 00:05:51 +02:00
* hls framework for Someone Else to drop code into :^)
* probably not, too much stuff to consider -- seeking, start at offset, task stitching (probably np-hard), conditional passthru, rate-control (especially multi-consumer), session keepalive, cache mgmt...