6.0 KiB
+++ title = "Export Files" description = "Downloads all files from docspell." weight = 65 +++
export-files.sh
This script can be used to download all files from docspell that have been uploaded before and the item metadata.
It downloads the original files, those that have been uploaded and not the converted pdf files.
The item's metadata are stored next to the files to provide more information about the item: corresponent, tags, dates, custom fields etc. This contains most of your user supplied data.
This script is intended for having your data outside and independent of docspell. Another good idea for a backup strategy is to take database dumps and storing the releases of docspell next to this dump.
Files are stored into the following folder structure (below the given target directory):
- yyyy-mm (item date)
- A3…XY (item id)
- somefile.pdf (attachments with name)
- metadata.json (json file with items metadata)
By default, files are not overwritten, it stops if existing files are encountered. This and some other things can be changed using environment variables:
DS_USER
the account name for login, it is asked if not availableDS_PASS
the password for login, it is asked if not availableOVERWRITE_FILE=
ify
then overwriting existing files is ok. Default isn
.SKIP_FILE=
ify
then existing files are skipped (supersedesOVERWRITE_FILE
). Default isn
.DROP_ITEM=
ify
the item folder is removed before attempting to download it. If this is set toy
then the above options don't make sense, since they operate on the files inside the item folder. Default isn
.
Docspell sends the sha256 hash with each file via the ETag header. This is used to do a integrity check after downloading.
Requirements
It is a bash script that additionally needs curl and jq to be available.
Usage
./export-files.sh <docspell-base-url> <target-directory>
For example, if docspell is at http://localhost:7880
:
./export-files.sh http://localhost:7880 /tmp/ds-downloads
The script asks for your account name and password. It then logs in and goes through all items downloading the metadata as json and the attachments.
Example Run
fish> env SKIP_FILE=y DS_USER=demo DS_PASS=test ./export-files.sh http://localhost:7880 /tmp/download
Login to Docspell.
Using url: http://localhost:7880
Login successful
Downloading 73 items…
Get next items with offset=0, limit=100
Get item 57Znskthf3g-X7RP1fxzE2U-dwr4vM6Yjnn-b7s1PoCznhz
- Download 'something.txt' (8HbeFornAUN-kBCyc8bHSVr-bnLBYDzgRQ7-peMZzyTzM2X)
- Checksum ok.
Get item 94u5Pt39q6N-7vKu3LugoRj-zohGS4ie4jb-68bW5gXU6Jd
- Download 'letter-en.pdf' (6KNNmoyqpew-RAkdwEmQgBT-QDqdY97whZA-4k2rmbssdfQ)
- Checksum ok.
Get item 7L9Fh53RVG4-vGSt2G2YUcY-cvpBKRXQgBn-omYpg6xQXyD
- Download 'mail.html' (A6yTYKrDc7y-xU3whmLB1kB-TGhEAVb12mo-RUw5u9PsYMo)
- Checksum ok.
Get item DCn9UtWUtvF-2qjxB5PXGEG-vqRUUU7JUJH-zBBrmSeGYPe
- Download 'Invoice_7340224.pdf' (6FWdjxJh7yB-CCjY39p6uH9-uVLbmGfm25r-cw6RksrSx4n)
- Checksum ok.
…
The resulting directory looks then like this:
…
├── 2020-08
│ ├── 6t27gQQ4TfW-H4uAmkYyiSe-rBnerFE2v5F-9BdqbGEhMcv
│ │ ├── 52241.pdf
│ │ └── metadata.json
│ └── 9qwT2GuwEvV-s9UuBQ4w7o9-uE8AdMc7PwL-GFDd62gduAm
│ ├── DOC-20191223-155707.jpg
│ └── metadata.json
├── 2020-09
│ ├── 2CM8C9VaVAT-sVJiKyUPCvR-Muqr2Cqvi6v-GXhRtg6eomA
│ │ ├── letter with spaces.pdf
│ │ └── metadata.json
│ ├── 4sXpX2Sc9Ex-QX1M6GtjiXp-DApuDDzGQXR-7pg1QPW9pbs
│ │ ├── analyse.org
│ │ ├── 201703.docx
│ │ ├── 11812_120719.pdf
│ │ ├── letter-de.pdf
│ │ ├── letter-en.pdf
│ │ └── metadata.json
│ ├── 5VhP5Torsy1-15pwJBeRjPi-es8BGnxhWn7-3pBQTJv3zPb
│ │ └── metadata.json
│ ├── 7ePWmK4xCNk-gmvnTDdFwG8-JcN5MDSUNPL-NTZZrho2Jc6
│ │ ├── metadata.json
│ │ └── Rechnung.pdf
…
The metadata.json
file contains all the item metadata. This may be
useful when importing into other tools.
{
"id": "AWCNx7tJgUw-SdrNtRouNJB-FGs6Y2VP5bV-218sFN8mjjk",
"direction": "incoming",
"name": "Ruecksendung.pdf",
"source": "integration",
"state": "confirmed",
"created": 1606171810005,
"updated": 1606422917826,
"itemDate": null,
"corrOrg": null,
"corrPerson": null,
"concPerson": null,
"concEquipment": null,
"inReplyTo": null,
"folder": null,
"dueDate": null,
"notes": null,
"attachments": [
{
"id": "4aPmhrjfR9Z-AgknoW6yVoE-YkffioD2KXV-E6Vm6snH17Q",
"name": "Ruecksendung.converted.pdf",
"size": 57777,
"contentType": "application/pdf",
"converted": true
}
],
"sources": [
{
"id": "4aPmhrjfR9Z-AgknoW6yVoE-YkffioD2KXV-E6Vm6snH17Q",
"name": "Ruecksendung.pdf",
"size": 65715,
"contentType": "application/pdf"
}
],
"archives": [],
"tags": [
{
"id": "EQvJ6AHw19Y-Cdg3gF78zZk-BY2zFtNTwes-J95jpXpzhfw",
"name": "Hupe",
"category": "state",
"created": 1606427083171
},
{
"id": "4xyZoeeELdJ-tJ91GiRLinJ-7bdauy3U1jR-Bzr4VS96bGS",
"name": "Invoice",
"category": "doctype",
"created": 1594249709473
}
],
"customfields": [
{
"id": "5tYmDHin3Kx-HomKkeEVtJN-v99oKxQ8ot6-yFVrEmMayoo",
"name": "amount",
"label": "EUR",
"ftype": "money",
"value": "151.55"
},
{
"id": "3jbwbep8rDs-hNJ9ePRE7gv-21nYMbUj3eb-mKRWAr4xSS2",
"name": "invoice-number",
"label": "Invoice-Nr",
"ftype": "text",
"value": "I454602"
},
{
"id": "AH4p4NUCa9Y-EUkH66wLzxE-Rf2wJPxTAYd-DeGDm4AT4Yg",
"name": "number",
"label": "Number",
"ftype": "numeric",
"value": "0.10"
}
]
}