diff --git a/.docker-hub-test b/.docker-hub-test new file mode 100644 index 000000000..6c2dff5ab --- /dev/null +++ b/.docker-hub-test @@ -0,0 +1 @@ +Docker Hub test 2 diff --git a/.travis.yml b/.travis.yml index 8773c486c..fa1785d8d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,8 +7,7 @@ before_install: sudo: false matrix: - include: - - python: "3.4" + include: - python: "3.5" - python: "3.6" - python: "3.7-dev" diff --git a/Dockerfile b/Dockerfile index cfcfbd25c..2b95288e6 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,12 +1,13 @@ -FROM alpine:3.8 +FROM alpine:3.11 LABEL maintainer="The Paperless Project https://github.com/the-paperless-project/paperless" \ contributors="Guy Addadi , Pit Kleyersburg , \ Sven Fischer " -# Copy Pipfiles file and init script +# Copy Pipfiles file, init script and gunicorn.conf COPY Pipfile* /usr/src/paperless/ COPY scripts/docker-entrypoint.sh /sbin/docker-entrypoint.sh +COPY scripts/gunicorn.conf /usr/src/paperless/ # Set export and consumption directories ENV PAPERLESS_EXPORT_DIR=/export \ @@ -26,6 +27,7 @@ RUN apk add --no-cache \ shadow \ sudo \ tesseract-ocr \ + tzdata \ unpaper && \ apk add --no-cache --virtual .build-dependencies \ g++ \ @@ -51,6 +53,9 @@ RUN apk add --no-cache \ adduser -D -u 1000 -G paperless -h /usr/src/paperless paperless && \ chown -Rh paperless:paperless /usr/src/paperless && \ mkdir -p $PAPERLESS_EXPORT_DIR && \ +# Avoid setrlimit warnings +# See: https://gitlab.alpinelinux.org/alpine/aports/issues/11122 + echo 'Set disable_coredump false' >> /etc/sudo.conf && \ # Setup entrypoint chmod 755 /sbin/docker-entrypoint.sh @@ -65,3 +70,5 @@ COPY src/ /usr/src/paperless/src/ COPY data/ /usr/src/paperless/data/ COPY media/ /usr/src/paperless/media/ +# Collect static files +RUN sudo -HEu paperless /usr/src/paperless/src/manage.py collectstatic --clear --no-input diff --git a/Pipfile b/Pipfile index 84a410f51..fa7282ce3 100644 --- a/Pipfile +++ b/Pipfile @@ -15,7 +15,7 @@ django-filter = "*" djangorestframework = "*" factory-boy = "*" filemagic = "*" -fuzzywuzzy = {extras = ["speedup"], version = "==0.15.0"} +fuzzywuzzy = {extras = ["speedup"],version = "==0.15.0"} gunicorn = "*" inotify-simple = "*" langdetect = "*" @@ -36,6 +36,8 @@ pytest-env = "*" pytest-xdist = "*" psycopg2 = "*" djangoql = "*" +whitenoise = "*" +brotli = "*" [dev-packages] ipython = "*" diff --git a/Pipfile.lock b/Pipfile.lock index 29032f6bb..186cb2c83 100644 --- a/Pipfile.lock +++ b/Pipfile.lock @@ -1,7 +1,7 @@ { "_meta": { "hash": { - "sha256": "971e0c975821925652865e34eed1c668bc6f52bb8217b776f35e87a66c936e1b" + "sha256": "229095b1d386419c9716ea1fbb7b42885d6ff686ca7266d317fbac78456754ac" }, "pipfile-spec": 6, "requires": {}, @@ -28,33 +28,72 @@ ], "version": "==1.5" }, - "atomicwrites": { + "appdirs": { "hashes": [ - "sha256:0312ad34fcad8fac3704d441f7b317e50af620823353ec657a53e981f92920c0", - "sha256:ec9ae8adaae229e4f8446952d204a3e4b5fdd2d099f9be3aaf556120135fb3ee" + "sha256:9e5896d1372858f8dd3344faf4e5014d21849c756c8d5701f78f8a103b372d92", + "sha256:d8b24664561d0d34ddfaec54636d502d7cea6e29c3eaf68f3df6180863e2166e" ], - "version": "==1.2.1" + "version": "==1.4.3" }, "attrs": { "hashes": [ - "sha256:10cbf6e27dbce8c30807caf056c8eb50917e0eaafe86347671b57254006c3e69", - "sha256:ca4be454458f9dec299268d472aaa5a11f67a4ff70093396e1ceae9c76cf4bbb" + "sha256:08a96c641c3a74e44eb59afb61a24f2cb9f4d7188748e76ba4bb5edfa3cb7d1c", + "sha256:f7b7ce16570fe9965acd6d30101a28f62fb4a7f9e926b3bbc9b61f8b04247e72" ], - "version": "==18.2.0" + "version": "==19.3.0" }, "babel": { "hashes": [ - "sha256:6778d85147d5d85345c14a26aada5e478ab04e39b078b0745ee6870c2b5cf669", - "sha256:8cba50f48c529ca3fa18cf81fa9403be176d374ac4d60738b839122dfaaa3d23" + "sha256:1aac2ae2d0d8ea368fa90906567f5c08463d98ade155c0c4bfedd6a0f7160e38", + "sha256:d670ea0b10f8b723672d3a6abeb87b565b244da220d76b4dba1b66269ec152d4" ], - "version": "==2.6.0" + "version": "==2.8.0" + }, + "brotli": { + "hashes": [ + "sha256:0538dc1744fd17c314d2adc409ea7d1b779783b89fd95bcfb0c2acc93a6ea5a7", + "sha256:0970a47f471782912d7705160b2b0a9306e68e6fadf9cffcaeb42d8f0951e26c", + "sha256:113f51658e6fe548dce4b3749f6ef6c24de4184ba9c10a909cbee4261c2a5da0", + "sha256:1e1aa9c4d1558889f42749c8baf846007953bfd32c8209230cf1cd1f5ef33495", + "sha256:2f2f4f78f29ac4a45d15b3d9fc3fd9705e0ad313a44b129f6e1d0c6916bad0e2", + "sha256:3269f6de1dd150fd0cce1c158b61ff5ac06d627fd3ae9c6ea03aed26fbbff7ea", + "sha256:3f4a1f6240916c7984c7f2542786710f622992508dafee0b1714e6d340fb9ffd", + "sha256:50dd9ad2a2bb12da4e9002a438672d182f98e546e99952de80280a1e1729664f", + "sha256:5519a4b01b1a4f965083cbfa2ef2b9774c5a5f352341c47b50776ad109423d72", + "sha256:5eb27722d320370315971c427eb8aa7cc0791f2a458840d357ac653bd0ad3a14", + "sha256:5f06b4d5b6f58e5b5c220c2f23cad034dc5efa51b01fde2351ced1605bd980e2", + "sha256:71ceee286ea7ec613f1c36f1c6181864a6ca24ebb55e371276f33d6af8742834", + "sha256:72848d25a5f9e736db4af4512e0c3feecc094d57d241f8f1ae959115a2c39756", + "sha256:743001bca75f4a6b4454be3510feca46f9d61a0c782a9bc2bc684bdb245e279e", + "sha256:7ac98c71a15648fd11bc1f32608b6110e396121280790082e32b9a3109048bc6", + "sha256:9d1c2dd27a1083fefd05b1b2f8df4a6bc2aaa6c21dd82cd41c8ae5e7c23a87f8", + "sha256:a13ce9b419fe9f277c63f700efb0e444331509d1881b5610d2ba7e9080606967", + "sha256:a19ef0952b9d2803df88dff07f45a6c92d5676afb9b8d69cf32232d684036d11", + "sha256:ad766ca8b8c1419b71a22756b45264f45725c86133dc80a7cbe30b6b78c75620", + "sha256:ad7963f261988ee0883816b6b9f206f11461c9b3cb5cfbca0c9ab5adc406d395", + "sha256:af0451e23016631a2f52925a10d738ac4a0f794ac315c30380b22efc0c90cbc6", + "sha256:c16201060c5a3f8742e3deae759014251ac92f382f82bc2a41dc079ff18c3f24", + "sha256:c43b202f65891861a9a336984a103de25de235f756de69e32db893156f767013", + "sha256:c675c6cce4295cb1a692f3de7416aacace7314e064b94bc86e93aceefce7fd3e", + "sha256:d17cec0b992b1434f5f9df9986563605a4d1b1acd5574c87fc2ac014bcbd3316", + "sha256:dc91f6129953861a73d9a65c52a8dd682b561a9ebaf65283541645cab6489917", + "sha256:e2f4cbd1760d2bf2f30e396c2301999aab0191aec031a6a8a04950b2f575a536", + "sha256:f192e6d3556714105c10486bbd6d045e38a0c04d9da3cef21e0a8dfd8e162df4", + "sha256:f775b07026af2b1b0b5a8b05e41571cdcf3a315a67df265d60af301656a5425b", + "sha256:f969ec7f56ba9636679e69ca07fba548312ccaca37412ee823c7f413541ad7e0", + "sha256:f9dc52cd70907aafb99a773b66b156f2f995c7a0d284397c487c8b71ddbef2f9", + "sha256:f9ee88bb52352588ceb811d045b5c9bb1dc38927bc150fd156244f60ff3f59f1", + "sha256:fc7212e36ebeb81aebf7949c92897b622490d7c0e333a479c0395591e7994600" + ], + "index": "pypi", + "version": "==1.0.7" }, "certifi": { "hashes": [ - "sha256:47f9c83ef4c0c621eaef743f133f09fa8a74a9b75f037e8624f83bd1b6626cb7", - "sha256:993f830721089fef441cdfeb4b2c8c9df86f0c63239f06bd025a76a7daddb033" + "sha256:017c25db2a153ce562900032d5bc68e9f191e44e9a0f762f373977de9df1fbb3", + "sha256:25b64c7da4cd7479594d035c08c2d809eb4aab3a26e5a990ea98cc450c320f1f" ], - "version": "==2018.11.29" + "version": "==2019.11.28" }, "chardet": { "hashes": [ @@ -65,110 +104,116 @@ }, "coverage": { "hashes": [ - "sha256:09e47c529ff77bf042ecfe858fb55c3e3eb97aac2c87f0349ab5a7efd6b3939f", - "sha256:0a1f9b0eb3aa15c990c328535655847b3420231af299386cfe5efc98f9c250fe", - "sha256:0cc941b37b8c2ececfed341444a456912e740ecf515d560de58b9a76562d966d", - "sha256:10e8af18d1315de936d67775d3a814cc81d0747a1a0312d84e27ae5610e313b0", - "sha256:1b4276550b86caa60606bd3572b52769860a81a70754a54acc8ba789ce74d607", - "sha256:1e8a2627c48266c7b813975335cfdea58c706fe36f607c97d9392e61502dc79d", - "sha256:2b224052bfd801beb7478b03e8a66f3f25ea56ea488922e98903914ac9ac930b", - "sha256:447c450a093766744ab53bf1e7063ec82866f27bcb4f4c907da25ad293bba7e3", - "sha256:46101fc20c6f6568561cdd15a54018bb42980954b79aa46da8ae6f008066a30e", - "sha256:4710dc676bb4b779c4361b54eb308bc84d64a2fa3d78e5f7228921eccce5d815", - "sha256:510986f9a280cd05189b42eee2b69fecdf5bf9651d4cd315ea21d24a964a3c36", - "sha256:5535dda5739257effef56e49a1c51c71f1d37a6e5607bb25a5eee507c59580d1", - "sha256:5a7524042014642b39b1fcae85fb37556c200e64ec90824ae9ecf7b667ccfc14", - "sha256:5f55028169ef85e1fa8e4b8b1b91c0b3b0fa3297c4fb22990d46ff01d22c2d6c", - "sha256:6694d5573e7790a0e8d3d177d7a416ca5f5c150742ee703f3c18df76260de794", - "sha256:6831e1ac20ac52634da606b658b0b2712d26984999c9d93f0c6e59fe62ca741b", - "sha256:77f0d9fa5e10d03aa4528436e33423bfa3718b86c646615f04616294c935f840", - "sha256:828ad813c7cdc2e71dcf141912c685bfe4b548c0e6d9540db6418b807c345ddd", - "sha256:85a06c61598b14b015d4df233d249cd5abfa61084ef5b9f64a48e997fd829a82", - "sha256:8cb4febad0f0b26c6f62e1628f2053954ad2c555d67660f28dfb1b0496711952", - "sha256:a5c58664b23b248b16b96253880b2868fb34358911400a7ba39d7f6399935389", - "sha256:aaa0f296e503cda4bc07566f592cd7a28779d433f3a23c48082af425d6d5a78f", - "sha256:ab235d9fe64833f12d1334d29b558aacedfbca2356dfb9691f2d0d38a8a7bfb4", - "sha256:b3b0c8f660fae65eac74fbf003f3103769b90012ae7a460863010539bb7a80da", - "sha256:bab8e6d510d2ea0f1d14f12642e3f35cefa47a9b2e4c7cea1852b52bc9c49647", - "sha256:c45297bbdbc8bb79b02cf41417d63352b70bcb76f1bbb1ee7d47b3e89e42f95d", - "sha256:d19bca47c8a01b92640c614a9147b081a1974f69168ecd494687c827109e8f42", - "sha256:d64b4340a0c488a9e79b66ec9f9d77d02b99b772c8b8afd46c1294c1d39ca478", - "sha256:da969da069a82bbb5300b59161d8d7c8d423bc4ccd3b410a9b4d8932aeefc14b", - "sha256:ed02c7539705696ecb7dc9d476d861f3904a8d2b7e894bd418994920935d36bb", - "sha256:ee5b8abc35b549012e03a7b1e86c09491457dba6c94112a2482b18589cc2bdb9" + "sha256:15cf13a6896048d6d947bf7d222f36e4809ab926894beb748fc9caa14605d9c3", + "sha256:1daa3eceed220f9fdb80d5ff950dd95112cd27f70d004c7918ca6dfc6c47054c", + "sha256:1e44a022500d944d42f94df76727ba3fc0a5c0b672c358b61067abb88caee7a0", + "sha256:25dbf1110d70bab68a74b4b9d74f30e99b177cde3388e07cc7272f2168bd1477", + "sha256:3230d1003eec018ad4a472d254991e34241e0bbd513e97a29727c7c2f637bd2a", + "sha256:3dbb72eaeea5763676a1a1efd9b427a048c97c39ed92e13336e726117d0b72bf", + "sha256:5012d3b8d5a500834783689a5d2292fe06ec75dc86ee1ccdad04b6f5bf231691", + "sha256:51bc7710b13a2ae0c726f69756cf7ffd4362f4ac36546e243136187cfcc8aa73", + "sha256:527b4f316e6bf7755082a783726da20671a0cc388b786a64417780b90565b987", + "sha256:722e4557c8039aad9592c6a4213db75da08c2cd9945320220634f637251c3894", + "sha256:76e2057e8ffba5472fd28a3a010431fd9e928885ff480cb278877c6e9943cc2e", + "sha256:77afca04240c40450c331fa796b3eab6f1e15c5ecf8bf2b8bee9706cd5452fef", + "sha256:7afad9835e7a651d3551eab18cbc0fdb888f0a6136169fbef0662d9cdc9987cf", + "sha256:9bea19ac2f08672636350f203db89382121c9c2ade85d945953ef3c8cf9d2a68", + "sha256:a8b8ac7876bc3598e43e2603f772d2353d9931709345ad6c1149009fd1bc81b8", + "sha256:b0840b45187699affd4c6588286d429cd79a99d509fe3de0f209594669bb0954", + "sha256:b26aaf69713e5674efbde4d728fb7124e429c9466aeaf5f4a7e9e699b12c9fe2", + "sha256:b63dd43f455ba878e5e9f80ba4f748c0a2156dde6e0e6e690310e24d6e8caf40", + "sha256:be18f4ae5a9e46edae3f329de2191747966a34a3d93046dbdf897319923923bc", + "sha256:c312e57847db2526bc92b9bfa78266bfbaabac3fdcd751df4d062cd4c23e46dc", + "sha256:c60097190fe9dc2b329a0eb03393e2e0829156a589bd732e70794c0dd804258e", + "sha256:c62a2143e1313944bf4a5ab34fd3b4be15367a02e9478b0ce800cb510e3bbb9d", + "sha256:cc1109f54a14d940b8512ee9f1c3975c181bbb200306c6d8b87d93376538782f", + "sha256:cd60f507c125ac0ad83f05803063bed27e50fa903b9c2cfee3f8a6867ca600fc", + "sha256:d513cc3db248e566e07a0da99c230aca3556d9b09ed02f420664e2da97eac301", + "sha256:d649dc0bcace6fcdb446ae02b98798a856593b19b637c1b9af8edadf2b150bea", + "sha256:d7008a6796095a79544f4da1ee49418901961c97ca9e9d44904205ff7d6aa8cb", + "sha256:da93027835164b8223e8e5af2cf902a4c80ed93cb0909417234f4a9df3bcd9af", + "sha256:e69215621707119c6baf99bda014a45b999d37602cb7043d943c76a59b05bf52", + "sha256:ea9525e0fef2de9208250d6c5aeeee0138921057cd67fcef90fbed49c4d62d37", + "sha256:fca1669d464f0c9831fd10be2eef6b86f5ebd76c724d1e0706ebdff86bb4adf0" ], - "version": "==4.5.2" + "version": "==5.0.3" }, "coveralls": { "hashes": [ - "sha256:ab638e88d38916a6cedbf80a9cd8992d5fa55c77ab755e262e00b36792b7cd6d", - "sha256:b2388747e2529fa4c669fb1e3e2756e4e07b6ee56c7d9fce05f35ccccc913aa0" + "sha256:4b6bfc2a2a77b890f556bc631e35ba1ac21193c356393b66c84465c06218e135", + "sha256:67188c7ec630c5f708c31552f2bcdac4580e172219897c4136504f14b823132f" ], "index": "pypi", - "version": "==1.5.1" + "version": "==1.11.1" }, "dateparser": { "hashes": [ - "sha256:940828183c937bcec530753211b70f673c0a9aab831e43273489b310538dff86", - "sha256:b452ef8b36cd78ae86a50721794bc674aa3994e19b570f7ba92810f4e0a2ae03" + "sha256:983d84b5e3861cb0aa240cad07f12899bb10b62328aae188b9007e04ce37d665", + "sha256:e1eac8ef28de69a554d5fcdb60b172d526d61924b1a40afbbb08df459a36006b" ], "index": "pypi", - "version": "==0.7.0" + "version": "==0.7.2" + }, + "distlib": { + "hashes": [ + "sha256:2e166e231a26b36d6dfe35a48c4464346620f8645ed0ace01ee31822b288de21" + ], + "version": "==0.3.0" }, "django": { "hashes": [ - "sha256:0292a7ad7d8ffc9cfc6a77f043d2e81f5bbc360c0c4a1686e130ef3432437d23", - "sha256:e89f613e3c1f7ff245ffee3560472f9fa9c07060b11f65e1de3cb763f8dcd4b9" + "sha256:665457d4146bbd34ae9d2970fa3b37082d7b225b0671bfd24c337458f229db78", + "sha256:bde46d4dbc410678e89bc95ea5d312dd6eb4c37d0fa0e19c9415cad94addf22f" ], "index": "pypi", - "version": "==2.0.10" + "version": "==2.0.13" }, "django-cors-headers": { "hashes": [ - "sha256:5545009c9b233ea7e70da7dbab7cb1c12afa01279895086f98ec243d7eab46fa", - "sha256:c4c2ee97139d18541a1be7d96fe337d1694623816d83f53cb7c00da9b94acae1" + "sha256:a5960addecc04527ab26617e51b8ed42f0adab4594b24bb0f3c33e2bd3857c3f", + "sha256:a785b5f446f6635810776d9f5f5d23e6a2a2f728ea982648370afaf0dfdf2627" ], "index": "pypi", - "version": "==2.4.0" + "version": "==3.2.1" }, "django-crispy-forms": { "hashes": [ - "sha256:5952bab971110d0b86c278132dae0aa095beee8f723e625c3d3fa28888f1675f", - "sha256:705ededc554ad8736157c666681165fe22ead2dec0d5446d65fc9dd976a5a876" + "sha256:0afc0ba730f52a13c02bfbd0e1423af4577a337d73a8a0ef96f2cbbc5f345ffa", + "sha256:2db711ce31f6f9ef42c16829cc3636e3819f97c1b22a3b706afed679bc417e88" ], "index": "pypi", - "version": "==1.7.2" + "version": "==1.8.1" }, "django-extensions": { "hashes": [ - "sha256:8317a3fe479b1ba3e3a04ecf33fb8d6ccf09bb18f30eab64e34c40a593741d26", - "sha256:a76a61566f1c8d96acc7bcf765080b8e91367a25a2c6f8c5bddd574493839180" + "sha256:1a03c4e8bade575f8c2be6c76456f8a2be3f9b02ab9f47d3535afa9562dc0493", + "sha256:2699cc1d6fb4bd393c0b5832fea4bc685f2ace5800b3c9ff222b2080f161ac04" ], "index": "pypi", - "version": "==2.1.4" + "version": "==2.2.8" }, "django-filter": { "hashes": [ - "sha256:3dafb7d2810790498895c22a1f31b2375795910680ac9c1432821cbedb1e176d", - "sha256:a3014de317bef0cd43075a0f08dfa1d319a7ccc5733c3901fb860da70b0dda68" + "sha256:558c727bce3ffa89c4a7a0b13bc8976745d63e5fd576b3a9a851650ef11c401b", + "sha256:c3deb57f0dd7ff94d7dce52a047516822013e2b441bed472b722a317658cfd14" ], "index": "pypi", - "version": "==2.1.0" + "version": "==2.2.0" }, "djangoql": { "hashes": [ - "sha256:7c488ec4e3362e5389ba3c1169d1ff9a27c4222601f32c6dbf6130ce04330d76" + "sha256:366293d7d4e416f9f7d6e2b98775c2129222fbb4dc660f3e6c7b9e35a3cf3fce" ], "index": "pypi", - "version": "==0.12.3" + "version": "==0.13.1" }, "djangorestframework": { "hashes": [ - "sha256:79c6efbb2514bc50cf25906d7c0a5cfead714c7af667ff4bd110312cd380ae66", - "sha256:a4138613b67e3a223be6c97f53b13d759c5b90d2b433bad670b8ebf95402075f" + "sha256:05809fc66e1c997fd9a32ea5730d9f4ba28b109b9da71fccfa5ff241201fd0a4", + "sha256:e782087823c47a26826ee5b6fa0c542968219263fb3976ec3c31edab23a4001f" ], "index": "pypi", - "version": "==3.9.1" + "version": "==3.11.0" }, "docopt": { "hashes": [ @@ -178,40 +223,39 @@ }, "docutils": { "hashes": [ - "sha256:02aec4bd92ab067f6ff27a38a38a41173bf01bed8f89157768c1573f53e474a6", - "sha256:51e64ef2ebfb29cae1faa133b3710143496eca21c530f3f71424d77687764274", - "sha256:7a4bd47eaf6596e1295ecb11361139febe29b084a87bf005bf899f9a42edc3c6" + "sha256:0c5b78adfbf7762415433f5515cd5c9e762339e23369dbe8000d84a4bf4ab3af", + "sha256:c2de3a60e9e7d07be26b7f2b00ca0309c207e06c100f9cc2a94931fc75a478fc" ], - "version": "==0.14" + "version": "==0.16" }, "execnet": { "hashes": [ - "sha256:a7a84d5fa07a089186a329528f127c9d73b9de57f1a1131b82bb5320ee651f6a", - "sha256:fc155a6b553c66c838d1a22dba1dc9f5f505c43285a878c6f74a79c024750b83" + "sha256:cacb9df31c9680ec5f95553976c4da484d407e85e41c83cb812aa014f0eddc50", + "sha256:d4efd397930c46415f62f8a31388d6be4f27a91d7550eb79bc64a756e0056547" ], - "version": "==1.5.0" + "version": "==1.7.1" }, "factory-boy": { "hashes": [ - "sha256:6f25cc4761ac109efd503f096e2ad99421b1159f01a29dbb917359dcd68e08ca", - "sha256:d552cb872b310ae78bd7429bf318e42e1e903b1a109e899a523293dfa762ea4f" + "sha256:728df59b372c9588b83153facf26d3d28947fc750e8e3c95cefa9bed0e6394ee", + "sha256:faf48d608a1735f0d0a3c9cbf536d64f9132b547dae7ba452c4d99a79e84a370" ], "index": "pypi", - "version": "==2.11.1" + "version": "==2.12.0" }, "faker": { "hashes": [ - "sha256:16342dca4d92bfc83bab6a7daf6650e0ab087605a66bc38f17523fdb01757910", - "sha256:d871ea315b2dcba9138b8344f2c131a76ac62d6227ca39f69b0c889fec97376c" + "sha256:047d4d1791bfb3756264da670d99df13d799bb36e7d88774b1585a82d05dbaec", + "sha256:1b1a58961683b30c574520d0c739c4443e0ef6a185c04382e8cc888273dbebed" ], - "version": "==1.0.2" + "version": "==4.0.0" }, "filelock": { "hashes": [ - "sha256:b8d5ca5ca1c815e1574aee746650ea7301de63d87935b3463d26368b76e31633", - "sha256:d610c1bb404daf85976d7a82eb2ada120f04671007266b708606565dd03b5be6" + "sha256:18d82244ee114f543149c66a6e0c14e9c4f8a1044b5cdaadd0f82159d6a6ff59", + "sha256:929b7d63ec5b7d6b71b0fa5ac14e030b3f70b75747cef1b10da9b879fef15836" ], - "version": "==3.0.10" + "version": "==3.0.12" }, "filemagic": { "hashes": [ @@ -233,11 +277,11 @@ }, "gunicorn": { "hashes": [ - "sha256:aa8e0b40b4157b36a5df5e599f45c9c76d6af43845ba3b3b0efe2c70473c2471", - "sha256:fa2662097c66f920f53f70621c6c58ca4a3c4d3434205e608e121b5b3b71f4f3" + "sha256:1904bb2b8a43658807108d59c3f3d56c2b6121a701161de0ddf9ad140073c626", + "sha256:cd4a810dd51bf497552cf3f863b575dabd73d6ad6a91075b65936b151cbf4f9c" ], "index": "pypi", - "version": "==19.9.0" + "version": "==20.0.4" }, "idna": { "hashes": [ @@ -248,24 +292,24 @@ }, "imagesize": { "hashes": [ - "sha256:3f349de3eb99145973fefb7dbe38554414e5c30abd0c8e4b970a7c9d09f3a1d8", - "sha256:f3832918bc3c66617f92e35f5d70729187676313caa60c187eb0f28b8fe5e3b5" + "sha256:6965f19a6a2039c7d48bca7dba2473069ff854c36ae6f19d2cde309d998228a1", + "sha256:b1f6b5a4eab1f73479a50fb79fcf729514a900c341d8503d62a62dbc4127a2b1" ], - "version": "==1.1.0" + "version": "==1.2.0" }, "inotify-simple": { "hashes": [ - "sha256:fc2c10dd73278a1027d0663f2db51240af5946390f363a154361406ebdddd8dd" + "sha256:db69f2d75603e0e8f72e734854ac445beb60ed38922bc97b7f7a522795ca4c8c" ], "index": "pypi", - "version": "==1.1.8" + "version": "==1.2.1" }, "jinja2": { "hashes": [ - "sha256:74c935a1b8bb9a3947c50a54766a969d4846290e1e788ea44c1392163723c3bd", - "sha256:f84be1bb0040caca4cea721fcbbbbd61f9be9464ca236387158b0feea01914a4" + "sha256:93187ffbc7808079673ef52771baa950426fd664d3aad1d0fa3e95644360e250", + "sha256:b0eaf100007721b5c16c1fc1eecb87409464edc10469ddc9a22a27a99123be49" ], - "version": "==2.10" + "version": "==2.11.1" }, "langdetect": { "hashes": [ @@ -276,101 +320,97 @@ }, "markupsafe": { "hashes": [ - "sha256:048ef924c1623740e70204aa7143ec592504045ae4429b59c30054cb31e3c432", - "sha256:130f844e7f5bdd8e9f3f42e7102ef1d49b2e6fdf0d7526df3f87281a532d8c8b", - "sha256:19f637c2ac5ae9da8bfd98cef74d64b7e1bb8a63038a3505cd182c3fac5eb4d9", - "sha256:1b8a7a87ad1b92bd887568ce54b23565f3fd7018c4180136e1cf412b405a47af", - "sha256:1c25694ca680b6919de53a4bb3bdd0602beafc63ff001fea2f2fc16ec3a11834", - "sha256:1f19ef5d3908110e1e891deefb5586aae1b49a7440db952454b4e281b41620cd", - "sha256:1fa6058938190ebe8290e5cae6c351e14e7bb44505c4a7624555ce57fbbeba0d", - "sha256:31cbb1359e8c25f9f48e156e59e2eaad51cd5242c05ed18a8de6dbe85184e4b7", - "sha256:3e835d8841ae7863f64e40e19477f7eb398674da6a47f09871673742531e6f4b", - "sha256:4e97332c9ce444b0c2c38dd22ddc61c743eb208d916e4265a2a3b575bdccb1d3", - "sha256:525396ee324ee2da82919f2ee9c9e73b012f23e7640131dd1b53a90206a0f09c", - "sha256:52b07fbc32032c21ad4ab060fec137b76eb804c4b9a1c7c7dc562549306afad2", - "sha256:52ccb45e77a1085ec5461cde794e1aa037df79f473cbc69b974e73940655c8d7", - "sha256:5c3fbebd7de20ce93103cb3183b47671f2885307df4a17a0ad56a1dd51273d36", - "sha256:5e5851969aea17660e55f6a3be00037a25b96a9b44d2083651812c99d53b14d1", - "sha256:5edfa27b2d3eefa2210fb2f5d539fbed81722b49f083b2c6566455eb7422fd7e", - "sha256:7d263e5770efddf465a9e31b78362d84d015cc894ca2c131901a4445eaa61ee1", - "sha256:83381342bfc22b3c8c06f2dd93a505413888694302de25add756254beee8449c", - "sha256:857eebb2c1dc60e4219ec8e98dfa19553dae33608237e107db9c6078b1167856", - "sha256:98e439297f78fca3a6169fd330fbe88d78b3bb72f967ad9961bcac0d7fdd1550", - "sha256:bf54103892a83c64db58125b3f2a43df6d2cb2d28889f14c78519394feb41492", - "sha256:d9ac82be533394d341b41d78aca7ed0e0f4ba5a2231602e2f05aa87f25c51672", - "sha256:e982fe07ede9fada6ff6705af70514a52beb1b2c3d25d4e873e82114cf3c5401", - "sha256:edce2ea7f3dfc981c4ddc97add8a61381d9642dc3273737e756517cc03e84dd6", - "sha256:efdc45ef1afc238db84cb4963aa689c0408912a0239b0721cb172b4016eb31d6", - "sha256:f137c02498f8b935892d5c0172560d7ab54bc45039de8805075e19079c639a9c", - "sha256:f82e347a72f955b7017a39708a3667f106e6ad4d10b25f237396a7115d8ed5fd", - "sha256:fb7c206e01ad85ce57feeaaa0bf784b97fa3cad0d4a5737bc5295785f5c613a1" + "sha256:00bc623926325b26bb9605ae9eae8a215691f33cae5df11ca5424f06f2d1f473", + "sha256:09027a7803a62ca78792ad89403b1b7a73a01c8cb65909cd876f7fcebd79b161", + "sha256:09c4b7f37d6c648cb13f9230d847adf22f8171b1ccc4d5682398e77f40309235", + "sha256:1027c282dad077d0bae18be6794e6b6b8c91d58ed8a8d89a89d59693b9131db5", + "sha256:13d3144e1e340870b25e7b10b98d779608c02016d5184cfb9927a9f10c689f42", + "sha256:24982cc2533820871eba85ba648cd53d8623687ff11cbb805be4ff7b4c971aff", + "sha256:29872e92839765e546828bb7754a68c418d927cd064fd4708fab9fe9c8bb116b", + "sha256:43a55c2930bbc139570ac2452adf3d70cdbb3cfe5912c71cdce1c2c6bbd9c5d1", + "sha256:46c99d2de99945ec5cb54f23c8cd5689f6d7177305ebff350a58ce5f8de1669e", + "sha256:500d4957e52ddc3351cabf489e79c91c17f6e0899158447047588650b5e69183", + "sha256:535f6fc4d397c1563d08b88e485c3496cf5784e927af890fb3c3aac7f933ec66", + "sha256:596510de112c685489095da617b5bcbbac7dd6384aeebeda4df6025d0256a81b", + "sha256:62fe6c95e3ec8a7fad637b7f3d372c15ec1caa01ab47926cfdf7a75b40e0eac1", + "sha256:6788b695d50a51edb699cb55e35487e430fa21f1ed838122d722e0ff0ac5ba15", + "sha256:6dd73240d2af64df90aa7c4e7481e23825ea70af4b4922f8ede5b9e35f78a3b1", + "sha256:717ba8fe3ae9cc0006d7c451f0bb265ee07739daf76355d06366154ee68d221e", + "sha256:79855e1c5b8da654cf486b830bd42c06e8780cea587384cf6545b7d9ac013a0b", + "sha256:7c1699dfe0cf8ff607dbdcc1e9b9af1755371f92a68f706051cc8c37d447c905", + "sha256:88e5fcfb52ee7b911e8bb6d6aa2fd21fbecc674eadd44118a9cc3863f938e735", + "sha256:8defac2f2ccd6805ebf65f5eeb132adcf2ab57aa11fdf4c0dd5169a004710e7d", + "sha256:98c7086708b163d425c67c7a91bad6e466bb99d797aa64f965e9d25c12111a5e", + "sha256:9add70b36c5666a2ed02b43b335fe19002ee5235efd4b8a89bfcf9005bebac0d", + "sha256:9bf40443012702a1d2070043cb6291650a0841ece432556f784f004937f0f32c", + "sha256:ade5e387d2ad0d7ebf59146cc00c8044acbd863725f887353a10df825fc8ae21", + "sha256:b00c1de48212e4cc9603895652c5c410df699856a2853135b3967591e4beebc2", + "sha256:b1282f8c00509d99fef04d8ba936b156d419be841854fe901d8ae224c59f0be5", + "sha256:b2051432115498d3562c084a49bba65d97cf251f5a331c64a12ee7e04dacc51b", + "sha256:ba59edeaa2fc6114428f1637ffff42da1e311e29382d81b339c1817d37ec93c6", + "sha256:c8716a48d94b06bb3b2524c2b77e055fb313aeb4ea620c8dd03a105574ba704f", + "sha256:cd5df75523866410809ca100dc9681e301e3c27567cf498077e8551b6d20e42f", + "sha256:cdb132fc825c38e1aeec2c8aa9338310d29d337bebbd7baa06889d09a60a1fa2", + "sha256:e249096428b3ae81b08327a63a485ad0878de3fb939049038579ac0ef61e17e7", + "sha256:e8313f01ba26fbbe36c7be1966a7b7424942f670f38e666995b88d012765b9be" ], - "version": "==1.1.0" + "version": "==1.1.1" }, "more-itertools": { "hashes": [ - "sha256:38a936c0a6d98a38bcc2d03fdaaedaba9f412879461dd2ceff8d37564d6522e4", - "sha256:c0a5785b1109a6bd7fac76d6837fd1feca158e54e521ccd2ae8bfe393cc9d4fc", - "sha256:fe7a7cae1ccb57d33952113ff4fa1bc5f879963600ed74918f1236e212ee50b9" + "sha256:5dd8bcf33e5f9513ffa06d5ad33d78f31e1931ac9a18f33d37e77a180d393a7c", + "sha256:b1ddb932186d8a6ac451e1d95844b382f55e12686d51ca0c68b6f61f2ab7a507" ], - "version": "==5.0.0" + "version": "==8.2.0" }, "packaging": { "hashes": [ - "sha256:0c98a5d0be38ed775798ece1b9727178c4469d9c3b4ada66e8e6b7849f8732af", - "sha256:9e1cbf8c12b1f1ce0bb5344b8d7ecf66a6f8a6e91bcb0c84593ed6d3ab5c4ab3" + "sha256:170748228214b70b672c581a3dd610ee51f733018650740e98c7df862a583f73", + "sha256:e665345f9eef0c621aa0bf2f8d78cf6d21904eef16a93f020240b704a57f1334" ], - "version": "==19.0" + "version": "==20.1" }, "pdftotext": { "hashes": [ - "sha256:e3ad11efe0aa22cbfc46aa1296b2ea5a52ad208b778288311f2801adef178ccb" + "sha256:d37864049581fb13cdcf7b23d4ea23dac7ca2e9c646e8ecac1a39275ab1cae03" ], "index": "pypi", - "version": "==2.1.1" + "version": "==2.1.4" }, "pillow": { "hashes": [ - "sha256:051de330a06c99d6f84bcf582960487835bcae3fc99365185dc2d4f65a390c0e", - "sha256:0ae5289948c5e0a16574750021bd8be921c27d4e3527800dc9c2c1d2abc81bf7", - "sha256:0b1efce03619cdbf8bcc61cfae81fcda59249a469f31c6735ea59badd4a6f58a", - "sha256:163136e09bd1d6c6c6026b0a662976e86c58b932b964f255ff384ecc8c3cefa3", - "sha256:18e912a6ccddf28defa196bd2021fe33600cbe5da1aa2f2e2c6df15f720b73d1", - "sha256:24ec3dea52339a610d34401d2d53d0fb3c7fd08e34b20c95d2ad3973193591f1", - "sha256:267f8e4c0a1d7e36e97c6a604f5b03ef58e2b81c1becb4fccecddcb37e063cc7", - "sha256:3273a28734175feebbe4d0a4cde04d4ed20f620b9b506d26f44379d3c72304e1", - "sha256:4c678e23006798fc8b6f4cef2eaad267d53ff4c1779bd1af8725cc11b72a63f3", - "sha256:4d4bc2e6bb6861103ea4655d6b6f67af8e5336e7216e20fff3e18ffa95d7a055", - "sha256:505738076350a337c1740a31646e1de09a164c62c07db3b996abdc0f9d2e50cf", - "sha256:5233664eadfa342c639b9b9977190d64ad7aca4edc51a966394d7e08e7f38a9f", - "sha256:5d95cb9f6cced2628f3e4de7e795e98b2659dfcc7176ab4a01a8b48c2c2f488f", - "sha256:7eda4c737637af74bac4b23aa82ea6fbb19002552be85f0b89bc27e3a762d239", - "sha256:801ddaa69659b36abf4694fed5aa9f61d1ecf2daaa6c92541bbbbb775d97b9fe", - "sha256:825aa6d222ce2c2b90d34a0ea31914e141a85edefc07e17342f1d2fdf121c07c", - "sha256:9c215442ff8249d41ff58700e91ef61d74f47dfd431a50253e1a1ca9436b0697", - "sha256:a3d90022f2202bbb14da991f26ca7a30b7e4c62bf0f8bf9825603b22d7e87494", - "sha256:a631fd36a9823638fe700d9225f9698fb59d049c942d322d4c09544dc2115356", - "sha256:a6523a23a205be0fe664b6b8747a5c86d55da960d9586db039eec9f5c269c0e6", - "sha256:a756ecf9f4b9b3ed49a680a649af45a8767ad038de39e6c030919c2f443eb000", - "sha256:b117287a5bdc81f1bac891187275ec7e829e961b8032c9e5ff38b70fd036c78f", - "sha256:ba04f57d1715ca5ff74bb7f8a818bf929a204b3b3c2c2826d1e1cc3b1c13398c", - "sha256:cd878195166723f30865e05d87cbaf9421614501a4bd48792c5ed28f90fd36ca", - "sha256:cee815cc62d136e96cf76771b9d3eb58e0777ec18ea50de5cfcede8a7c429aa8", - "sha256:d1722b7aa4b40cf93ac3c80d3edd48bf93b9208241d166a14ad8e7a20ee1d4f3", - "sha256:d7c1c06246b05529f9984435fc4fa5a545ea26606e7f450bdbe00c153f5aeaad", - "sha256:e9c8066249c040efdda84793a2a669076f92a301ceabe69202446abb4c5c5ef9", - "sha256:f227d7e574d050ff3996049e086e1f18c7bd2d067ef24131e50a1d3fe5831fbc", - "sha256:fc9a12aad714af36cf3ad0275a96a733526571e52710319855628f476dcb144e" + "sha256:0a628977ac2e01ca96aaae247ec2bd38e729631ddf2221b4b715446fd45505be", + "sha256:4d9ed9a64095e031435af120d3c910148067087541131e82b3e8db302f4c8946", + "sha256:54ebae163e8412aff0b9df1e88adab65788f5f5b58e625dc5c7f51eaf14a6837", + "sha256:5bfef0b1cdde9f33881c913af14e43db69815c7e8df429ceda4c70a5e529210f", + "sha256:5f3546ceb08089cedb9e8ff7e3f6a7042bb5b37c2a95d392fb027c3e53a2da00", + "sha256:5f7ae9126d16194f114435ebb79cc536b5682002a4fa57fa7bb2cbcde65f2f4d", + "sha256:62a889aeb0a79e50ecf5af272e9e3c164148f4bd9636cc6bcfa182a52c8b0533", + "sha256:7406f5a9b2fd966e79e6abdaf700585a4522e98d6559ce37fc52e5c955fade0a", + "sha256:8453f914f4e5a3d828281a6628cf517832abfa13ff50679a4848926dac7c0358", + "sha256:87269cc6ce1e3dee11f23fa515e4249ae678dbbe2704598a51cee76c52e19cda", + "sha256:875358310ed7abd5320f21dd97351d62de4929b0426cdb1eaa904b64ac36b435", + "sha256:8ac6ce7ff3892e5deaab7abaec763538ffd011f74dc1801d93d3c5fc541feee2", + "sha256:91b710e3353aea6fc758cdb7136d9bbdcb26b53cefe43e2cba953ac3ee1d3313", + "sha256:9d2ba4ed13af381233e2d810ff3bab84ef9f18430a9b336ab69eaf3cd24299ff", + "sha256:a62ec5e13e227399be73303ff301f2865bf68657d15ea50b038d25fc41097317", + "sha256:ab76e5580b0ed647a8d8d2d2daee170e8e9f8aad225ede314f684e297e3643c2", + "sha256:bf4003aa538af3f4205c5fac56eacaa67a6dd81e454ffd9e9f055fff9f1bc614", + "sha256:bf598d2e37cf8edb1a2f26ed3fb255191f5232badea4003c16301cb94ac5bdd0", + "sha256:c18f70dc27cc5d236f10e7834236aff60aadc71346a5bc1f4f83a4b3abee6386", + "sha256:c5ed816632204a2fc9486d784d8e0d0ae754347aba99c811458d69fcdfd2a2f9", + "sha256:dc058b7833184970d1248135b8b0ab702e6daa833be14035179f2acb78ff5636", + "sha256:ff3797f2f16bf9d17d53257612da84dd0758db33935777149b3334c01ff68865" ], "index": "pypi", - "version": "==5.4.1" + "version": "==7.0.0" }, "pluggy": { "hashes": [ - "sha256:8ddc32f03971bfdf900a81961a48ccf2fb677cf7715108f85295c67405798616", - "sha256:980710797ff6a041e9a73a5787804f848996ecaa6f8a1b1e08224a5894f2074a" + "sha256:15b2acde666561e1298d71b523007ed7364de07029219b604cf808bfa1c765b0", + "sha256:966c145cd83c96502c3c3868f50408687b38434af77734af1e9ca461a4081d2d" ], - "version": "==0.8.1" + "version": "==0.13.1" }, "ply": { "hashes": [ @@ -381,99 +421,82 @@ }, "psycopg2": { "hashes": [ - "sha256:02445ebbb3a11a3fe8202c413d5e6faf38bb75b4e336203ee144ca2c46529f94", - "sha256:0e9873e60f98f0c52339abf8f0339d1e22bfe5aae0bcf7aabd40c055175035ec", - "sha256:1148a5eb29073280bf9057c7fc45468592c1bb75a28f6df1591adb93c8cb63d0", - "sha256:259a8324e109d4922b0fcd046e223e289830e2568d6f4132a3702439e5fd532b", - "sha256:28dffa9ed4595429e61bacac41d3f9671bb613d1442ff43bcbec63d4f73ed5e8", - "sha256:314a74302d4737a3865d40ea50e430ce1543c921ba10f39d562e807cfe2edf2a", - "sha256:36b60201b6d215d7658a71493fdf6bd5e60ad9a0cffed39906627ff9f4f3afd3", - "sha256:3f9d532bce54c4234161176ff3b8688ff337575ca441ea27597e112dfcd0ee0c", - "sha256:5d222983847b40af989ad96c07fc3f07e47925e463baa5de716be8f805b41d9b", - "sha256:6757a6d2fc58f7d8f5d471ad180a0bd7b4dd3c7d681f051504fbea7ae29c8d6f", - "sha256:6a0e0f1e74edb0ab57d89680e59e7bfefad2bfbdf7c80eb38304d897d43674bb", - "sha256:6ca703ccdf734e886a1cf53eb702261110f6a8b0ed74bcad15f1399f74d3f189", - "sha256:8513b953d8f443c446aa79a4cc8a898bd415fc5e29349054f03a7d696d495542", - "sha256:9262a5ce2038570cb81b4d6413720484cb1bc52c064b2f36228d735b1f98b794", - "sha256:97441f851d862a0c844d981cbee7ee62566c322ebb3d68f86d66aa99d483985b", - "sha256:a07feade155eb8e69b54dd6774cf6acf2d936660c61d8123b8b6b1f9247b67d6", - "sha256:a9b9c02c91b1e3ec1f1886b2d0a90a0ea07cc529cb7e6e472b556bc20ce658f3", - "sha256:ae88216f94728d691b945983140bf40d51a1ff6c7fe57def93949bf9339ed54a", - "sha256:b360ffd17659491f1a6ad7c928350e229c7b7bd83a2b922b6ee541245c7a776f", - "sha256:b4221957ceccf14b2abdabef42d806e791350be10e21b260d7c9ce49012cc19e", - "sha256:b90758e49d5e6b152a460d10b92f8a6ccf318fcc0ee814dcf53f3a6fc5328789", - "sha256:c669ea986190ed05fb289d0c100cc88064351f2b85177cbfd3564c4f4847d18c", - "sha256:d1b61999d15c79cf7f4f7cc9021477aef35277fc52452cf50fd13b713c84424d", - "sha256:de7bb043d1adaaf46e38d47e7a5f703bb3dab01376111e522b07d25e1a79c1e1", - "sha256:e393568e288d884b94d263f2669215197840d097c7e5b0acd1a51c1ea7d1aba8", - "sha256:ed7e0849337bd37d89f2c2b0216a0de863399ee5d363d31b1e5330a99044737b", - "sha256:f153f71c3164665d269a5d03c7fa76ba675c7a8de9dc09a4e2c2cdc9936a7b41", - "sha256:f1fb5a8427af099beb7f65093cbdb52e021b8e6dbdfaf020402a623f4181baf5", - "sha256:f36b333e9f86a2fba960c72b90c34be6ca71819e300f7b1fc3d2b0f0b2c546cd", - "sha256:f4526d078aedd5187d0508aa5f9a01eae6a48a470ed678406da94b4cd6524b7e" + "sha256:4212ca404c4445dc5746c0d68db27d2cbfb87b523fe233dc84ecd24062e35677", + "sha256:47fc642bf6f427805daf52d6e52619fe0637648fe27017062d898f3bf891419d", + "sha256:72772181d9bad1fa349792a1e7384dde56742c14af2b9986013eb94a240f005b", + "sha256:8396be6e5ff844282d4d49b81631772f80dabae5658d432202faf101f5283b7c", + "sha256:893c11064b347b24ecdd277a094413e1954f8a4e8cdaf7ffbe7ca3db87c103f0", + "sha256:92a07dfd4d7c325dd177548c4134052d4842222833576c8391aab6f74038fc3f", + "sha256:965c4c93e33e6984d8031f74e51227bd755376a9df6993774fd5b6fb3288b1f4", + "sha256:9ab75e0b2820880ae24b7136c4d230383e07db014456a476d096591172569c38", + "sha256:b0845e3bdd4aa18dc2f9b6fb78fbd3d9d371ad167fd6d1b7ad01c0a6cdad4fc6", + "sha256:dca2d7203f0dfce8ea4b3efd668f8ea65cd2b35112638e488a4c12594015f67b", + "sha256:ed686e5926929887e2c7ae0a700e32c6129abb798b4ad2b846e933de21508151", + "sha256:ef6df7e14698e79c59c7ee7cf94cd62e5b869db369ed4b1b8f7b729ea825712a", + "sha256:f898e5cc0a662a9e12bde6f931263a1bbd350cfb18e1d5336a12927851825bb6" ], "index": "pypi", - "version": "==2.7.7" + "version": "==2.8.4" }, "py": { "hashes": [ - "sha256:bf92637198836372b520efcba9e020c330123be8ce527e535d185ed4b6f45694", - "sha256:e76826342cefe3c3d5f7e8ee4316b80d1dd8a300781612ddbc765c17ba25a6c6" + "sha256:5e27081401262157467ad6e7f851b7aa402c5852dbcb3dae06768434de5752aa", + "sha256:c20fdd83a5dbc0af9efd622bee9a5564e278f6380fffcacc43ba6f43db2813b0" ], - "version": "==1.7.0" + "version": "==1.8.1" }, "pycodestyle": { "hashes": [ - "sha256:cbc619d09254895b0d12c2c691e237b2e91e9b2ecf5e84c26b35400f93dcfb83", - "sha256:cbfca99bd594a10f674d0cd97a3d802a1fdef635d4361e1a2658de47ed261e3a" + "sha256:95a2219d12372f05704562a14ec30bc76b05a5b297b21a5dfe3f6fac3491ae56", + "sha256:e40a936c9a450ad81df37f549d676d127b1b66000a6c500caa2b085bc0ca976c" ], "index": "pypi", - "version": "==2.4.0" + "version": "==2.5.0" }, "pygments": { "hashes": [ - "sha256:5ffada19f6203563680669ee7f53b64dabbeb100eb51b61996085e99c03b284a", - "sha256:e8218dd399a61674745138520d0d4cf2621d7e032439341bc3f647bff125818d" + "sha256:2a3fe295e54a20164a9df49c75fa58526d3be48e14aceba6d6b1e8ac0bfd6f1b", + "sha256:98c8aa5a9f778fcd1026a17361ddaf7330d1b7c62ae97c3bb0ae73e0b9b6b0fe" ], - "version": "==2.3.1" + "version": "==2.5.2" }, "pyocr": { "hashes": [ - "sha256:b6ba6263fd92da56627dff6d263d991a2246aacd117d1788f11b93f419ca395f" + "sha256:fa15adc7e1cf0d345a2990495fe125a947c6e09a60ddba0256a1c14b2e603179" ], "index": "pypi", - "version": "==0.5.3" + "version": "==0.7.2" }, "pyparsing": { "hashes": [ - "sha256:66c9268862641abcac4a96ba74506e594c884e3f57690a696d21ad8210ed667a", - "sha256:f6c5ef0d7480ad048c054c37632c67fca55299990fff127850181659eea33fc3" + "sha256:4c830582a84fb022400b85429791bc551f1f4871c33f23e44f353119e92f969f", + "sha256:c342dccb5250c08d45fd6f8b4a559613ca603b57498511740e65cd11a2e7dcec" ], - "version": "==2.3.1" + "version": "==2.4.6" }, "pytest": { "hashes": [ - "sha256:41568ea7ecb4a68d7f63837cf65b92ce8d0105e43196ff2b26622995bb3dc4b2", - "sha256:c3c573a29d7c9547fb90217ece8a8843aa0c1328a797e200290dc3d0b4b823be" + "sha256:0d5fe9189a148acc3c3eb2ac8e1ac0742cb7618c084f3d228baaec0c254b318d", + "sha256:ff615c761e25eb25df19edddc0b970302d2a9091fbce0e7213298d85fb61fef6" ], "index": "pypi", - "version": "==4.1.1" + "version": "==5.3.5" }, "pytest-cov": { "hashes": [ - "sha256:0ab664b25c6aa9716cbf203b17ddb301932383046082c081b9848a0edf5add33", - "sha256:230ef817450ab0699c6cc3c9c8f7a829c34674456f2ed8df1fe1d39780f7c87f" + "sha256:cc6742d8bac45070217169f5f72ceee1e0e55b0221f54bcf24845972d3a47f2b", + "sha256:cdbdef4f870408ebdbfeb44e63e07eb18bb4619fae852f6e760645fa36172626" ], "index": "pypi", - "version": "==2.6.1" + "version": "==2.8.1" }, "pytest-django": { "hashes": [ - "sha256:1a5d33be930e3172fa238643a380414dc369fe8fa4b3c3de25e59ed142950736", - "sha256:e88e471d3d0f9acfb6293bb03d0ee8a33ed978734e92ea6b5312163a6c9e87cc" + "sha256:456fa6854d04ee625d6bbb8b38ca2259e7040a6f93333bfe8bc8159b7e987203", + "sha256:489b904f695f9fb880ce591cf5a4979880afb467763b1f180c07574554bdfd26" ], "index": "pypi", - "version": "==3.4.5" + "version": "==3.8.0" }, "pytest-env": { "hashes": [ @@ -484,10 +507,10 @@ }, "pytest-forked": { "hashes": [ - "sha256:260d03fbd38d5ce41a657759e8d19bc7c8cfa6d0dcfa36c0bc9742d33bc30742", - "sha256:8d05c2e6f33cd4422571b2b1bb309720c398b0549cff499e3e4cde661875ab54" + "sha256:1805699ed9c9e60cb7a8179b8d4fa2b8898098e82d229b0825d8095f0f261100", + "sha256:1ae25dba8ee2e56fb47311c9638f9e58552691da87e82d25b0ce0e4bf52b7d87" ], - "version": "==1.0.1" + "version": "==1.1.3" }, "pytest-sugar": { "hashes": [ @@ -499,35 +522,35 @@ }, "pytest-xdist": { "hashes": [ - "sha256:107e9db0ee30ead02ca93e7d6d4846675f1b2142234f0eb1cd4d76739cd9ae6f", - "sha256:5795f665e112520fa5beab736ad957e7f36ce7d44210f4004be9d99f86529d97" + "sha256:0f46020d3d9619e6d17a65b5b989c1ebbb58fc7b1da8fb126d70f4bac4dfeed1", + "sha256:7dc0d027d258cd0defc618fb97055fbd1002735ca7a6d17037018cf870e24011" ], "index": "pypi", - "version": "==1.26.0" + "version": "==1.31.0" }, "python-dateutil": { "hashes": [ - "sha256:063df5763652e21de43de7d9e00ccf239f953a832941e37be541614732cdfc93", - "sha256:88f9287c0174266bb0d8cedd395cfba9c58e87e5ad86b2ce58859bc11be3cf02" + "sha256:73ebfe9dbf22e832286dafa60473e4cd239f8592f699aa5adaf10050e6e1823c", + "sha256:75bb3f31ea686f1197762692a9ee6a7550b59fc6ca3a1f4b5d7e32fb98e2da2a" ], "index": "pypi", - "version": "==2.7.5" + "version": "==2.8.1" }, "python-dotenv": { "hashes": [ - "sha256:a84569d0e00d178bc5b957f7ff208bf49287cbf61857c31c258c4a91f571527b", - "sha256:c9b1ddd3cdbe75c7d462cb84674d87130f4b948f090f02c7d7144779afb99ae0" + "sha256:8429f459fc041237d98c9ff32e1938e7e5535b5ff24388876315a098027c3a57", + "sha256:ca9f3debf2262170d6f46571ce4d6ca1add60bb93b69c3a29dcb3d1a00a65c93" ], "index": "pypi", - "version": "==0.10.1" + "version": "==0.11.0" }, "python-gnupg": { "hashes": [ - "sha256:45daf020b370bda13a1429c859fcdff0b766c0576844211446f9266cae97fb0e", - "sha256:85c231850a0275c9722f06e34b45a22510b83a6a6e88f93b5ae32ba04c95056c" + "sha256:3353e59949cd2c15efbf1fca45e347d8a22f4bed0d93e9b89b2657bda19cec05", + "sha256:c095a41f310ad7a4fd393406660ac9bd6c175ccaa0f072f9c18f33be8130a27a" ], "index": "pypi", - "version": "==0.4.4" + "version": "==0.4.5" }, "python-levenshtein": { "hashes": [ @@ -537,61 +560,108 @@ }, "pytz": { "hashes": [ - "sha256:32b0891edff07e28efe91284ed9c31e123d84bea3fd98e1f72be2508f43ef8d9", - "sha256:d5f05e487007e29e03409f9398d074e158d920d36eb82eaf66fb1136b0c5374c" + "sha256:1c557d7d0e871de1f5ccd5833f60fb2550652da6be2693c1e02300743d21500d", + "sha256:b02c06db6cf09c12dd25137e563b31700d3b80fcc4ad23abb7a315f2789819be" ], "index": "pypi", - "version": "==2018.9" + "version": "==2019.3" }, "regex": { "hashes": [ - "sha256:0bcd8ab8c812278981df3161db3f94f0ec72f1fa07020173c96f20e74bd7c16a", - "sha256:20b1601b887e1073805adda2f8a09bb4c86dc7629c46c0d7bf28444dcb32920d", - "sha256:3c4327dd686d2e05b1b3d60a256fbf1c93c53001614ed8acd65453e09d40e10f", - "sha256:5e8c6cef2cd964888d5fdf16f3db3dbaaa18c5c5c648161c52c8df065cc26ac5", - "sha256:666b03b1c33ef8105f28ecf0fd26f4480931a91a6e30e29e304c1d9eddce2209", - "sha256:8afb6ecd80154464b1ad31a93228b63832526f9b0291a82a55287ae15c01de79", - "sha256:9326e1c5b9de6e74150bdd424789aecec41c7ecaf9e78bf4c3acfe6868ce1365", - "sha256:e06eac198d9c76bcbe52b987b74ead0d353cfaa9f3d8cd907ec984f4bb20ea1e", - "sha256:eee007ee39a02cb631b74f89f992766b9d7e952a750166f3e5a5baf8c328c070" + "sha256:07b39bf943d3d2fe63d46281d8504f8df0ff3fe4c57e13d1656737950e53e525", + "sha256:0932941cdfb3afcbc26cc3bcf7c3f3d73d5a9b9c56955d432dbf8bbc147d4c5b", + "sha256:0e182d2f097ea8549a249040922fa2b92ae28be4be4895933e369a525ba36576", + "sha256:10671601ee06cf4dc1bc0b4805309040bb34c9af423c12c379c83d7895622bb5", + "sha256:23e2c2c0ff50f44877f64780b815b8fd2e003cda9ce817a7fd00dea5600c84a0", + "sha256:26ff99c980f53b3191d8931b199b29d6787c059f2e029b2b0c694343b1708c35", + "sha256:27429b8d74ba683484a06b260b7bb00f312e7c757792628ea251afdbf1434003", + "sha256:3e77409b678b21a056415da3a56abfd7c3ad03da71f3051bbcdb68cf44d3c34d", + "sha256:4e8f02d3d72ca94efc8396f8036c0d3bcc812aefc28ec70f35bb888c74a25161", + "sha256:4eae742636aec40cf7ab98171ab9400393360b97e8f9da67b1867a9ee0889b26", + "sha256:6a6ae17bf8f2d82d1e8858a47757ce389b880083c4ff2498dba17c56e6c103b9", + "sha256:6a6ba91b94427cd49cd27764679024b14a96874e0dc638ae6bdd4b1a3ce97be1", + "sha256:7bcd322935377abcc79bfe5b63c44abd0b29387f267791d566bbb566edfdd146", + "sha256:98b8ed7bb2155e2cbb8b76f627b2fd12cf4b22ab6e14873e8641f266e0fb6d8f", + "sha256:bd25bb7980917e4e70ccccd7e3b5740614f1c408a642c245019cff9d7d1b6149", + "sha256:d0f424328f9822b0323b3b6f2e4b9c90960b24743d220763c7f07071e0778351", + "sha256:d58e4606da2a41659c84baeb3cfa2e4c87a74cec89a1e7c56bee4b956f9d7461", + "sha256:e3cd21cc2840ca67de0bbe4071f79f031c81418deb544ceda93ad75ca1ee9f7b", + "sha256:e6c02171d62ed6972ca8631f6f34fa3281d51db8b326ee397b9c83093a6b7242", + "sha256:e7c7661f7276507bce416eaae22040fd91ca471b5b33c13f8ff21137ed6f248c", + "sha256:ecc6de77df3ef68fee966bb8cb4e067e84d4d1f397d0ef6fce46913663540d77" ], - "version": "==2019.1.24" + "version": "==2020.1.8" }, "requests": { "hashes": [ - "sha256:502a824f31acdacb3a35b6690b5fbf0bc41d63a24a45c4004352b0242707598e", - "sha256:7bf2a778576d825600030a110f3c0e3e8edc51dfaafe1c146e39a2027784957b" + "sha256:11e007a8a2aa0323f5a921e9e6a2d7e4e67d9877e85773fba9ba6419025cbeb4", + "sha256:9cf5292fcd0f598c671cfc1e0d7d1a7f13bb8085e9a590f48c010551dc6c4b31" ], - "version": "==2.21.0" + "version": "==2.22.0" }, "six": { "hashes": [ - "sha256:3350809f0555b11f552448330d0b52d5f24c91a322ea4a15ef22629740f3761c", - "sha256:d16a0141ec1a18405cd4ce8b4613101da75da0e9a7aec5bdd4fa804d0e0eba73" + "sha256:236bdbdce46e6e6a3d61a337c0f8b763ca1e8717c03b369e87a7ec7ce1319c0a", + "sha256:8f3cd2e254d8f793e7f3d6d9df77b92252b52637291d0f0da013c76ea2724b6c" ], - "version": "==1.12.0" + "version": "==1.14.0" }, "snowballstemmer": { "hashes": [ - "sha256:919f26a68b2c17a7634da993d91339e288964f93c274f1343e3bbbe2096e1128", - "sha256:9f3bcd3c401c3e862ec0ebe6d2c069ebc012ce142cce209c098ccb5b09136e89" + "sha256:209f257d7533fdb3cb73bdbd24f436239ca3b2fa67d56f6ff88e86be08cc5ef0", + "sha256:df3bac3df4c2c01363f3dd2cfa78cce2840a79b9f1c2d2de9ce8d31683992f52" ], - "version": "==1.2.1" + "version": "==2.0.0" }, "sphinx": { "hashes": [ - "sha256:429e3172466df289f0f742471d7e30ba3ee11f3b5aecd9a840480d03f14bcfe5", - "sha256:c4cb17ba44acffae3d3209646b6baec1e215cad3065e852c68cc569d4df1b9f8" + "sha256:5024a67f065fe60d9db2005580074d81f22a02dd8f00a5b1ec3d5f4d42bc88d8", + "sha256:f929b72e0cfe45fa581b8964d54457117863a6a6c9369ecc1a65b8827abd3bf2" ], "index": "pypi", - "version": "==1.8.3" + "version": "==2.4.1" }, - "sphinxcontrib-websupport": { + "sphinxcontrib-applehelp": { "hashes": [ - "sha256:68ca7ff70785cbe1e7bccc71a48b5b6d965d79ca50629606c7861a21b206d9dd", - "sha256:9de47f375baf1ea07cdb3436ff39d7a9c76042c10a769c52353ec46e4e8fc3b9" + "sha256:edaa0ab2b2bc74403149cb0209d6775c96de797dfd5b5e2a71981309efab3897", + "sha256:fb8dee85af95e5c30c91f10e7eb3c8967308518e0f7488a2828ef7bc191d0d5d" ], - "version": "==1.1.0" + "version": "==1.0.1" + }, + "sphinxcontrib-devhelp": { + "hashes": [ + "sha256:6c64b077937330a9128a4da74586e8c2130262f014689b4b89e2d08ee7294a34", + "sha256:9512ecb00a2b0821a146736b39f7aeb90759834b07e81e8cc23a9c70bacb9981" + ], + "version": "==1.0.1" + }, + "sphinxcontrib-htmlhelp": { + "hashes": [ + "sha256:4670f99f8951bd78cd4ad2ab962f798f5618b17675c35c5ac3b2132a14ea8422", + "sha256:d4fd39a65a625c9df86d7fa8a2d9f3cd8299a3a4b15db63b50aac9e161d8eff7" + ], + "version": "==1.0.2" + }, + "sphinxcontrib-jsmath": { + "hashes": [ + "sha256:2ec2eaebfb78f3f2078e73666b1415417a116cc848b72e5172e596c871103178", + "sha256:a9925e4a4587247ed2191a22df5f6970656cb8ca2bd6284309578f2153e0c4b8" + ], + "version": "==1.0.1" + }, + "sphinxcontrib-qthelp": { + "hashes": [ + "sha256:513049b93031beb1f57d4daea74068a4feb77aa5630f856fcff2e50de14e9a20", + "sha256:79465ce11ae5694ff165becda529a600c754f4bc459778778c7017374d4d406f" + ], + "version": "==1.0.2" + }, + "sphinxcontrib-serializinghtml": { + "hashes": [ + "sha256:c0efb33f8052c04fd7a26c0a07f1678e8512e0faec19f4aa8f2473a8b81d5227", + "sha256:db6615af393650bf1151a6cd39120c29abaf93cc60db8c48eb2dddbfdc3a9768" + ], + "version": "==1.1.3" }, "termcolor": { "hashes": [ @@ -601,10 +671,10 @@ }, "text-unidecode": { "hashes": [ - "sha256:5a1375bb2ba7968740508ae38d92e1f889a0832913cb1c447d5e2046061a396d", - "sha256:801e38bd550b943563660a91de8d4b6fa5df60a542be9093f7abf819f86050cc" + "sha256:1311f10e8b895935241623731c2ba64f4c455287888b18189350b67134a822e8", + "sha256:bad6603bb14d279193107714b288be206cac565dfa49aa5b105294dd5c4aab93" ], - "version": "==1.2" + "version": "==1.3" }, "toml": { "hashes": [ @@ -615,31 +685,47 @@ }, "tox": { "hashes": [ - "sha256:04f8f1aa05de8e76d7a266ccd14e0d665d429977cd42123bc38efa9b59964e9e", - "sha256:25ef928babe88c71e3ed3af0c464d1160b01fca2dd1870a5bb26c2dea61a17fc" + "sha256:5c45d08f1dcc9bc97cdea3e5a69c8f4ad042cc37cbe6cf53e126f4a9005b7d3b", + "sha256:73e2ade68cd71a2765ee739ecc27c8c92e9b9c09acbad0f2c5307b20214e0d13" ], "index": "pypi", - "version": "==3.7.0" + "version": "==3.14.4" }, "tzlocal": { "hashes": [ - "sha256:4ebeb848845ac898da6519b9b31879cf13b6626f7184c496037b818e238f2c4e" + "sha256:11c9f16e0a633b4b60e1eede97d8a46340d042e67b670b290ca526576e039048", + "sha256:949b9dd5ba4be17190a80c0268167d7e6c92c62b30026cf9764caf3e308e5590" ], - "version": "==1.5.1" + "version": "==2.0.0" }, "urllib3": { "hashes": [ - "sha256:61bf29cada3fc2fbefad4fdf059ea4bd1b4a86d2b6d15e1c7c0b582b9752fe39", - "sha256:de9529817c93f27c8ccbfead6985011db27bd0ddfcdb2d86f3f663385c6a9c22" + "sha256:2f3db8b19923a873b3e5256dc9c2dedfa883e33d87c690d9c7913e1f40673cdc", + "sha256:87716c2d2a7121198ebcb7ce7cccf6ce5e9ba539041cfbaeecfb641dc0bf6acc" ], - "version": "==1.24.1" + "version": "==1.25.8" }, "virtualenv": { "hashes": [ - "sha256:58c359370401e0af817fb0070911e599c5fdc836166306b04fd0f278151ed125", - "sha256:729f0bcab430e4ef137646805b5b1d8efbb43fe53d4a0f33328624a84a5121f7" + "sha256:08f3623597ce73b85d6854fb26608a6f39ee9d055c81178dc6583803797f8994", + "sha256:de2cbdd5926c48d7b84e0300dea9e8f276f61d186e8e49223d71d91250fbaebd" ], - "version": "==16.3.0" + "version": "==20.0.4" + }, + "wcwidth": { + "hashes": [ + "sha256:8fd29383f539be45b20bd4df0dc29c20ba48654a41e661925e612311e9f3c603", + "sha256:f28b3e8a6483e5d49e7f8949ac1a78314e740333ae305b4ba5defd3e74fb37a8" + ], + "version": "==0.1.8" + }, + "whitenoise": { + "hashes": [ + "sha256:0f9137f74bd95fa54329ace88d8dc695fbe895369a632e35f7a136e003e41d73", + "sha256:62556265ec1011bd87113fb81b7516f52688887b7a010ee899ff1fd18fd22700" + ], + "index": "pypi", + "version": "==5.0.1" } }, "develop": { @@ -652,18 +738,18 @@ }, "decorator": { "hashes": [ - "sha256:33cd704aea07b4c28b3eb2c97d288a06918275dac0ecebdaf1bc8a48d98adb9e", - "sha256:cabb249f4710888a2fc0e13e9a16c343d932033718ff62e1e9bc93a9d3a9122b" + "sha256:54c38050039232e1db4ad7375cfce6748d7b41c29e95a081c8a6d2c30364a2ce", + "sha256:5d19b92a3c8f7f101c8dd86afd86b0f061a8ce4540ab8cd401fa2542756bce6d" ], - "version": "==4.3.2" + "version": "==4.4.1" }, "ipython": { "hashes": [ - "sha256:6a9496209b76463f1dec126ab928919aaf1f55b38beb9219af3fe202f6bbdd12", - "sha256:f69932b1e806b38a7818d9a1e918e5821b685715040b48e59c657b3c7961b742" + "sha256:d9459e7237e2e5858738ff9c3e26504b79899b58a6d49e574d352493d80684c6", + "sha256:f6689108b1734501d3b59c84427259fd5ac5141afe2e846cfa8598eb811886c9" ], "index": "pypi", - "version": "==7.2.0" + "version": "==7.12.0" }, "ipython-genutils": { "hashes": [ @@ -674,25 +760,25 @@ }, "jedi": { "hashes": [ - "sha256:571702b5bd167911fe9036e5039ba67f820d6502832285cde8c881ab2b2149fd", - "sha256:c8481b5e59d34a5c7c42e98f6625e633f6ef59353abea6437472c7ec2093f191" + "sha256:b4f4052551025c6b0b0b193b29a6ff7bdb74c52450631206c262aef9f7159ad2", + "sha256:d5c871cb9360b414f981e7072c52c33258d598305280fef91c6cae34739d65d5" ], - "version": "==0.13.2" + "version": "==0.16.0" }, "parso": { "hashes": [ - "sha256:4b8f9ed80c3a4a3191aa3261505d868aa552dd25649cb13a7d73b6b7315edf2d", - "sha256:5a120be2e8863993b597f1c0437efca799e90e0793c98ae5d4e34ebd00140e31" + "sha256:56b2105a80e9c4df49de85e125feb6be69f49920e121406f15e7acde6c9dfc57", + "sha256:951af01f61e6dccd04159042a0706a31ad437864ec6e25d0d7a96a9fbb9b0095" ], - "version": "==0.3.2" + "version": "==0.6.1" }, "pexpect": { "hashes": [ - "sha256:2a8e88259839571d1251d278476f3eec5db26deb73a70be5ed5dc5435e418aba", - "sha256:3fbd41d4caf27fa4a377bfd16fef87271099463e6fa73e92a52f92dfee5d425b" + "sha256:0b48a55dcb3c05f3329815901ea4fc1537514d6ba867a152b581d69ae3710937", + "sha256:fc65a43959d153d0114afe13997d439c22823a27cefceb5ff35c2178c6784c0c" ], "markers": "sys_platform != 'win32'", - "version": "==4.6.0" + "version": "==4.8.0" }, "pickleshare": { "hashes": [ @@ -703,11 +789,10 @@ }, "prompt-toolkit": { "hashes": [ - "sha256:c1d6aff5252ab2ef391c2fe498ed8c088066f66bc64a8d5c095bbf795d9fec34", - "sha256:d4c47f79b635a0e70b84fdb97ebd9a274203706b1ee5ed44c10da62755cf3ec9", - "sha256:fd17048d8335c1e6d5ee403c3569953ba3eb8555d710bfc548faf0712666ea39" + "sha256:a402e9bf468b63314e37460b68ba68243d55b2f8c4d0192f85a019af3945050e", + "sha256:c93e53af97f630f12f5f62a3274e79527936ed466f038953dfa379d4941f651a" ], - "version": "==2.0.7" + "version": "==3.0.3" }, "ptyprocess": { "hashes": [ @@ -718,31 +803,31 @@ }, "pygments": { "hashes": [ - "sha256:5ffada19f6203563680669ee7f53b64dabbeb100eb51b61996085e99c03b284a", - "sha256:e8218dd399a61674745138520d0d4cf2621d7e032439341bc3f647bff125818d" + "sha256:2a3fe295e54a20164a9df49c75fa58526d3be48e14aceba6d6b1e8ac0bfd6f1b", + "sha256:98c8aa5a9f778fcd1026a17361ddaf7330d1b7c62ae97c3bb0ae73e0b9b6b0fe" ], - "version": "==2.3.1" + "version": "==2.5.2" }, "six": { "hashes": [ - "sha256:3350809f0555b11f552448330d0b52d5f24c91a322ea4a15ef22629740f3761c", - "sha256:d16a0141ec1a18405cd4ce8b4613101da75da0e9a7aec5bdd4fa804d0e0eba73" + "sha256:236bdbdce46e6e6a3d61a337c0f8b763ca1e8717c03b369e87a7ec7ce1319c0a", + "sha256:8f3cd2e254d8f793e7f3d6d9df77b92252b52637291d0f0da013c76ea2724b6c" ], - "version": "==1.12.0" + "version": "==1.14.0" }, "traitlets": { "hashes": [ - "sha256:9c4bd2d267b7153df9152698efb1050a5d84982d3384a37b2c1f7723ba3e7835", - "sha256:c6cb5e6f57c5a9bdaa40fa71ce7b4af30298fbab9ece9815b5d995ab6217c7d9" + "sha256:70b4c6a1d9019d7b4f6846832288f86998aa3b9207c6821f3578a6a6a467fe44", + "sha256:d023ee369ddd2763310e4c3eae1ff649689440d4ae59d7485eb4cfbbe3e359f7" ], - "version": "==4.3.2" + "version": "==4.3.3" }, "wcwidth": { "hashes": [ - "sha256:3df37372226d6e63e1b1e1eda15c594bca98a22d33a23832a90998faa96bc65e", - "sha256:f4ebe71925af7b40a864553f761ed559b43544f8f71746c2d756c7fe788ade7c" + "sha256:8fd29383f539be45b20bd4df0dc29c20ba48654a41e661925e612311e9f3c603", + "sha256:f28b3e8a6483e5d49e7f8949ac1a78314e740333ae305b4ba5defd3e74fb37a8" ], - "version": "==0.1.7" + "version": "==0.1.8" } } } diff --git a/README-de.md b/README-de.md index e3314836a..386f61027 100644 --- a/README-de.md +++ b/README-de.md @@ -22,9 +22,9 @@ Paperless steuert nicht deinen Scanner, es hilft nur damit umzugehen, was der Sc 1. Kaufe einen Dokumentenscanner, der an einen Ort in deinem Netzwerk schreiben kann. Wenn du Inspirationen brauchst, schau in die [Scannerempfehlungen](https://paperless.readthedocs.io/en/latest/scanners.html). 2. Stelle "Scanne zu FTP" oder ähnliches ein. Es sollte möglich sein, eingescannte Bilder ohne etwas tun zu müssen an einen Server hochzuladen. Natürlich kannst du auch die einscannte Datei händisch hochladen, wenn der Scanner automatisches Hochladen nicht unterstützt. Paperless ist es egal, wie die Dokumente in seinen lokalen Konsumordner gelangen. -3. Besitze einen Zielserver, lasse das Papierless-Konsumskript laufen, um die Datei mit OCR zu versehen und sie in einer lokalen Datenbank zu indexieren. +3. Besitze einen Zielserver, lasse das Paperless-Konsumskript laufen, um die Datei mit OCR zu versehen und sie in einer lokalen Datenbank zu indexieren. 4. Benutze die Weboberfläche, um die Datenbank zu durchforsten und zu finden, was du suchst. -5. Lade die PDF-Datei, die du brauchst/möchtest über die Weboberfläche herunter und mach was auch immer du willst damit. Du kannst es auch drucken und versenden, so als wäre es das Original. In den meisten Fällen, wird das niemanden interessieren oder bemerken. +5. Lade die PDF-Datei, die du brauchst/möchtest über die Weboberfläche herunter und mach was auch immer du willst damit. Du kannst es auch drucken und versenden, so als wäre es das Original. In den meisten Fällen wird das niemanden interessieren oder bemerken. Hier das, was du bekommt: @@ -42,7 +42,7 @@ Dies alles ist eine wirklich ziemlich einfache, glänzende und benutzerfreundlic * [ImageMagick](http://imagemagick.org/) wandelt Bilder zwischen Farbe und Graustufen um. * [Tesseract](https://github.com/tesseract-ocr) erledigt die Buchstabenerkennung. -* [Unpaper](https://www.flameeyes.eu/projects/unpaper) bereinigt und begradigt das eingescannte Bild. +* [Unpaper](https://github.com/unpaper/unpaper) bereinigt und begradigt das eingescannte Bild. * [GNU Privacy Guard](https://gnupg.org/) wird als Verschlüsselungsbackend genutzt. * [Python 3](https://python.org/) ist die Sprache des Projekts. * [Pillow](https://pypi.python.org/pypi/pillowfight/) lädt die Bilddaten als Python-Objekt, um sie mit PyOCR zu verwenden. @@ -58,12 +58,14 @@ Dieses Projekt wurde um 2015 gestartet und es gibt viele Leute, die es verwenden Ich entwickle keine neuen Funktionen mehr für Paperless, weil es genau das tut, was ich brauche und meine Aufmerksamkeit meinem neuesten Projekt [Aletheia](https://github.com/danielquinn/aletheia) gewidmet ist. Ich verlasse jedoch nicht das Projekt. Ich bin glücklich damit, Pull Requests zu begutachten und Fragen im Issue-Bereich zu beantworten. Wenn du ein Entwickler bist und eine neue Funktion willst, reihe sie in den Issues ein und/oder sende einen PR! Ich bin glücklich damit, neue Sachen hinzuzufügen, habe aber einfach nicht die Zeit, sie selbst zu erarbeiten. -## Verknüpfte Prjekte +## Verknüpfte Projekte Paperless gibt es bereits seit einer Weile und Leute haben damit angefangen, Sachen rund um Paperless zu entwickeln. Wenn du einer dieser Menschen bist, kannst du dein Projekt zu dieser Liste hinzufügen: +* [Paperless App](https://github.com/bauerj/paperless_app): Eine Android/iOS-App für Paperless. * [Paperless Desktop](https://github.com/thomasbrueggemann/paperless-desktop): Eine Desktop-Oberfläche für deine Paperless-Installation. Läuft auf Mac, Linux und Windows. * [ansible-role-paperless](https://github.com/ovv/ansible-role-paperless): Eine einfache Möglichkeit, Paperless via Ansible laufen zu lassen. +* [paperless-cli](https://github.com/stgarf/paperless-cli): Ein golang Kommandozeilenprogramm, welches mit Paperless interagiert. ## Ähnliche Projekte @@ -73,7 +75,7 @@ Es gibt da draußen auch das Projekt [Mayan EDMS](https://mayan.readthedocs.org/ ## Wichtiger Hinweis -Dokumentenscanner werden typerweise verwendet, um sensible Dokumente zu scannen. Dinge wie die Sozialversicherungsnummer, Steueraufzeichnungen, Rechnungen, etc. Während Paperless die Originaldateien über das Konsumskript verschlüsselt, sind die OCR-Texte *nicht* verschlüsselt und demnach in Klartext gespeichert (es muss durchsuchbar sein, also wenn jemand eine Idee hat, wie man das mit verschlüsselten Daten tun kann: Ich bin ganz Ohr). Das bedeutet, dass Paperless niemals auf einem nicht vertrauten Host laufen sollte. Stattdessen empfehle ich, wenn du es verwenden willst, es lokal auf einem Server in deinem Zuhause laufen zu lassen. +Dokumentenscanner werden typischerweise verwendet, um sensible Dokumente zu scannen. Dinge wie die Sozialversicherungsnummer, Steueraufzeichnungen, Rechnungen, etc. Während Paperless die Originaldateien über das Konsumskript verschlüsselt, sind die OCR-Texte *nicht* verschlüsselt und demnach in Klartext gespeichert (es muss durchsuchbar sein, also wenn jemand eine Idee hat, wie man das mit verschlüsselten Daten tun kann: Ich bin ganz Ohr). Das bedeutet, dass Paperless niemals auf einem nicht vertrauten Host laufen sollte. Stattdessen empfehle ich, wenn du es verwenden willst, es lokal auf einem Server in deinem Zuhause laufen zu lassen. ## Spenden diff --git a/README-el.md b/README-el.md index de62a7516..4fe307c0b 100644 --- a/README-el.md +++ b/README-el.md @@ -41,7 +41,7 @@ * [ImageMagick](http://imagemagick.org/) μετατρέπει τις εικόνες σε έγχρωμες και ασπρόμαυρες. * [Tesseract](https://github.com/tesseract-ocr) κάνει την αναγνώρηση των χαρακτήρων. -* [Unpaper](https://www.flameeyes.eu/projects/unpaper) despeckles and deskews the scanned image. +* [Unpaper](https://github.com/unpaper/unpaper) despeckles and deskews the scanned image. * [GNU Privacy Guard](https://gnupg.org/) χρησιμοποιείται για κρυπτογράφηση στο backend. * [Python 3](https://python.org/) είναι η γλώσσα του project. * [Pillow](https://pypi.python.org/pypi/pillowfight/) Φορτώνει την εικόνα σαν αντικείμενο στην python και μπορεί να χρησιμοποιηθεί με PyOCR @@ -59,6 +59,7 @@ Το Paperless υπάρχει εδώ και κάποιο καιρό και άνθρωποι έχουν αρχίσει να φτιάχνουν πράγματα γύρω από αυτό. Αν είσαι ένας από αυτούς τους ανθρώπους, μπορούμε να βάλουμε το project σου σε αυτήν την λίστα: +* [Paperless App](https://github.com/bauerj/paperless_app): Μια εφαρμογή Android / iOS για Paperless. * [Paperless Desktop](https://github.com/thomasbrueggemann/paperless-desktop): Μια desktop εφαρμογή για εγκατάσταση του Paperless. Τρέχει σε Mac, Linux, και Windows. * [ansible-role-paperless](https://github.com/ovv/ansible-role-paperless): Ένας εύκολο τρόπος για να τρέχει το Paperless μέσω Ansible. diff --git a/README.md b/README.md index 002b857d0..35709b6d8 100644 --- a/README.md +++ b/README.md @@ -46,7 +46,7 @@ This is all really a quite simple, shiny, user-friendly wrapper around some very * [ImageMagick](http://imagemagick.org/) converts the images between colour and greyscale. * [Tesseract](https://github.com/tesseract-ocr) does the character recognition. -* [Unpaper](https://www.flameeyes.eu/projects/unpaper) despeckles and deskews the scanned image. +* [Unpaper](https://github.com/unpaper/unpaper) despeckles and deskews the scanned image. * [GNU Privacy Guard](https://gnupg.org/) is used as the encryption backend. * [Python 3](https://python.org/) is the language of the project. * [Pillow](https://pypi.python.org/pypi/pillowfight/) loads the image data as a python object to be used with PyOCR. @@ -66,6 +66,7 @@ I am no longer doing new development on Paperless as it does exactly what I need Paperless has been around a while now, and people are starting to build stuff on top of it. If you're one of those people, we can add your project to this list: +* [Paperless App](https://github.com/bauerj/paperless_app): An Android/iOS app for Paperless. * [Paperless Desktop](https://github.com/thomasbrueggemann/paperless-desktop): A desktop UI for your Paperless installation. Runs on Mac, Linux, and Windows. * [ansible-role-paperless](https://github.com/ovv/ansible-role-paperless): An easy way to get Paperless running via Ansible. * [paperless-cli](https://github.com/stgarf/paperless-cli): A golang command line binary to interact with a Paperless instance. diff --git a/docker-compose.env.example b/docker-compose.env.example index 51332437d..7117c7dad 100644 --- a/docker-compose.env.example +++ b/docker-compose.env.example @@ -11,12 +11,18 @@ # ...are all explained in that file but can be defined here, since the Docker # installation doesn't make use of paperless.conf. +# Use this variable to set a timezone for the Paperless Docker containers. If not specified, defaults to UTC. +# TZ=America/Los_Angeles # Additional languages to install for text recognition. Note that this is # different from PAPERLESS_OCR_LANGUAGE (default=eng), which defines the # default language used when guessing the language from the OCR output. # PAPERLESS_OCR_LANGUAGES=deu ita +# Set Paperless to use SSL for the web interface. +# Enabling this will require ssl.key and ssl.cert files in paperless' data directory. +# PAPERLESS_USE_SSL=false + # You can change the default user and group id to a custom one # USERMAP_UID=1000 # USERMAP_GID=1000 diff --git a/docker-compose.yml.example b/docker-compose.yml.example index 312467b91..f8c920f95 100644 --- a/docker-compose.yml.example +++ b/docker-compose.yml.example @@ -27,7 +27,7 @@ services: # value with nothing. environment: - PAPERLESS_OCR_LANGUAGES= - command: ["runserver", "--insecure", "--noreload", "0.0.0.0:8000"] + command: ["gunicorn", "-b", "0.0.0.0:8000"] consumer: build: ./ diff --git a/docs/_static/lxc-install.svg b/docs/_static/lxc-install.svg new file mode 100644 index 000000000..7ffe1bbdf --- /dev/null +++ b/docs/_static/lxc-install.svg @@ -0,0 +1,44 @@ + + + + + + + + + + Need to get 1818 kB of archives.Collecting ipython-genutils==0.2.0 (from -r requirements.txt (line 32))24% [Waiting for headers] Setting up libfile-fcntllock-perl (0.22-3build2) ...Collecting sphinxcontrib-websupport==1.1.0 (from -r requirements.txt (line 71))Get:45 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-shm0 amd64 1.13-1 [5572 B] 19% |██████▎ | 614kB 5.2MB/s eta 0:00:01 99% |████████████████████████████████| 3.1MB 6.0MB/s eta 0:00:01 bms@pingu:~$ ex -extensions-2.1.3 django-filter-2.0.0 djangorestframework-3.9.0 docopt-0.6.2 docutils-0.14 execnet-1.5.0 factory-boy-2.11.1 faker-0.Unpacking liblqr-1-0:amd64 (0.4.2-2.1) ...Selecting previously unselected package python3-xdg. 52% |████████████████▉ | 266kB 6.0MB/s eta 0:00:01 62% |████████████████████ | 5.1MB 5.8MB/s eta 0:00:01 100% |████████████████████████████████| 215kB 2.6MB/s 50% [Waiting for headers] 3755 kB/s 8s Downloading https://files.pythonhosted.org/packages/1b/92/a45a140b4024988f65eb76020101fa6da968b43716121595452b8bafb506/pytest_xdis binutils binutils-common binutils-x86-64-linux-gnu build-essential cpp cpp-7 dh-python dpkg-dev fakeroot g++ g++-7 gcc gcc-7 Not uninstalling urllib3 at /usr/lib/python3/dist-packages, outside environment /usr python-crypto-doc gnome-keyring libkf5wallet-bin gir1.2-gnomekeyring-1.0 python-secretstorage-doc python-setuptools-docGet:104 http://archive.ubuntu.com/ubuntu bionic/universe amd64 liblept5 amd64 1.75.3-3 [929 kB] 76% |████████████████████████▌ | 1.5MB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fi.js'bms@pingu:~$ # Lanuch the new machineSelecting previously unselected package libpoppler-cpp0v5:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/he.js'Setting up tesseract-ocr (4.00~git2288-10f4998a-2) ...Adding system user `ftp' (UID 112) ... Downloading https://files.pythonhosted.org/packages/dd/9d/fb75af584b850a902c9ce5ec96ea5c623978113b8a240ab414e1a435df93/pytest_fork 62% |███████████████████▉ | 522kB 5.9MB/s eta 0:00:01 Get:15 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 imagemagick-6-common all 8:6.9.7.4+dfsg-16ubuntu6.4 [60.9 kB]Get:19 http://archive.ubuntu.com/ubuntu bionic/main amd64 poppler-data all 0.4.8-2 [1479 kB]Selecting previously unselected package python-pip-whl.Preparing to unpack .../048-libgsm1_1.0.13-4build1_amd64.deb ...59% [43 libpython3.6-dev 12.1 MB/44.8 MB 27%] 4081 kB/s 9sGet:10 http://archive.ubuntu.com/ubuntu bionic/main amd64 libmpc3 amd64 1.1.0-1 [40.8 kB]49% [10 Sources store 0 B] [18 Packages 2685 B/8570 kB 0%] python3-pip python3-secretstorage python3-setuptools python3-venv python3-wheel python3-xdg python3.6-dev python3.6-venvCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/vi.js'Reading package lists... 88%Receiving objects: 14% (780/5570) Setting up libpoppler-cpp-dev:amd64 (0.62.0-2ubuntu2.5) ... 79% |█████████████████████████▍ | 5.6MB 6.1MB/s eta 0:00:01 Setting up gcc-7-base:amd64 (7.3.0-27ubuntu1~18.04) ...90% [18 Packages store 0 B] [21 Translation-en 2687 B/108 kB 2%] libcups2 libcupsfilters1 libcupsimage2 libdatrie1 libdjvulibre-text libdjvulibre21 libdrm-amdgpu1 libdrm-intel1 libdrm-nouveau2 40% |████████████▉ | 2.9MB 5.9MB/s eta 0:00:01 Extracting templates from packages: 85% Stored in directory: /root/.cache/pip/wheels/7c/06/54/bc84598ba1daf8f970247f550b175aaaee85f68b4b0c5ab2c641% [Waiting for headers] 3755 kB/s 10s Applying sessions.0001_initial... OKSelecting previously unselected package libxrender1:amd64.Selecting previously unselected package vdpau-driver-all:amd64.Get:3 http://archive.ubuntu.com/ubuntu bionic/main amd64 libfontconfig1 amd64 2.12.6-0ubuntu2 [137 kB]Get:83 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libavcodec57 amd64 7:3.4.4-0ubuntu0.18.04.1 [4592 kB] Unpacking libfontconfig1:amd64 (2.12.6-0ubuntu2) ...Unpacking libxcb-shm0:amd64 (1.13-1) ...23% [11 Packages store 0 B] [10 Sources 1142 kB/9051 kB 13%] [Waiting for headers] 91% |█████████████████████████████▎ | 7.4MB 5.9MB/s eta 0:00:01 Preparing to unpack .../095-libdrm-amdgpu1_2.4.91-2_amd64.deb ... 52% |████████████████▉ | 112kB 6.5MB/s eta 0:00:01 Setting up python3-crypto (2.6.1-8ubuntu2) ...Adding new group `paperless' (1000) ...50% [43 libpython3.6-dev 2540 kB/44.8 MB 6%] 4081 kB/s 11sSelecting previously unselected package libjpeg8:amd64. 76% |████████████████████████▍ | 5.4MB 6.0MB/s eta 0:00:01 binutils-doc cpp-doc gcc-7-locales debian-keyring g++-multilib g++-7-multilib gcc-7-doc libstdc++6-7-dbg gcc-multilib autoconf 61% |███████████████████▊ | 614kB 5.9MB/s eta 0:00:01 Stored in directory: /root/.cache/pip/wheels/15/ae/df/a67bf1ed84e9bf230187d36d8dcfd30072bea0236cb059ed91passwd: password updated successfullyGet:26 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 Packages [489 kB] 81% |██████████████████████████▏ | 92kB 5.8MB/s eta 0:00:01 pygments, traitlets, wcwidth, prompt-toolkit, ipython, langdetect, more-itertools, pyparsing, packaging, pdftotext, pillow, pluggy, Unpacking libltdl7:amd64 (2.4.6-2) ...Selecting previously unselected package libdpkg-perl. 10% |███▍ | 204kB 6.0MB/s eta 0:00:01 Selecting previously unselected package libpoppler73:amd64.Get:6 http://security.ubuntu.com/ubuntu bionic-security/main Sources [70.2 kB] Applying documents.0017_auto_20170512_0507... OKPreparing to unpack .../16-liblsan0_8.2.0-1ubuntu2~18.04_amd64.deb ...Enabling module access_compat.Get:38 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libva-drm2 amd64 2.1.0-3 [6880 B]Password: Downloading https://files.pythonhosted.org/packages/21/35/60094dbadd9de2035873390b1cac25e01da605844eba6a07a53a82fa4adc/pdftotext-276% [Waiting for headers] 3755 kB/s 4sCollecting faker==0.9.2 (from -r requirements.txt (line 24))Unpacking libsoxr0:amd64 (0.1.2-3) ...Preparing to unpack .../020-libavahi-common-data_0.7-3.1ubuntu1.1_amd64.deb ...33% [50 libmp3lame0 4061 B/136 kB 3%] Setting up i965-va-driver:amd64 (2.1.0-0ubuntu1) ...Get:34 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 python3-distutils all 3.6.7-1~18.04 [141 kB] Setting up libdatrie1:amd64 (0.2.10-7) ...Get:11 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 liblcms2-2 amd64 2.9-1ubuntu0.1 [139 kB] 83% |██████████████████████████▉ | 6.8MB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/it.js'Preparing to unpack .../09-libapache2-mod-wsgi-py3_4.5.17-1_amd64.deb ... 52% |████████████████▊ | 522kB 5.9MB/s eta 0:00:01 Selecting previously unselected package fontconfig.Get:17 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 liblsan0 amd64 8.2.0-1ubuntu2~18.04 [132 kB]Collecting urllib3==1.24.1 (from -r requirements.txt (line 78)) Downloading https://files.pythonhosted.org/packages/3a/9a/9d878f8d885706e2530402de6417141129a943802c084238914fa6798d97/atomicwriteSelecting previously unselected package libexpat1-dev:amd64.bms@FortBoyard:~$ exi Setting up libgs9-common (9.26~dfsg+0-0ubuntu0.18.04.3) ... 45% |██████████████▍ | 890kB 5.9MB/s eta 0:00:01 bms@pingu:~$ e Collecting tox==3.5.3 (from -r requirements.txt (line 75))Preparing to unpack .../19-libcilkrts5_7.3.0-27ubuntu1~18.04_amd64.deb ...Setting up libatomic1:amd64 (8.2.0-1ubuntu2~18.04) ... 20% |██████▋ | 1.7MB 5.6MB/s eta 0:00:02 Preparing to unpack .../016-libmagickwand-6.q16-3_8%3a6.9.7.4+dfsg-16ubuntu6.4_amd64.deb ...10% [Waiting for headers] 99% |████████████████████████████████| 839kB 6.6MB/s eta 0:00:01 Selecting previously unselected package libcilkrts5:amd64.Unpacking libcups2:amd64 (2.2.7-1ubuntu2.3) ... fonts-noto ghostscript-x i965-va-driver-shaders imagemagick-doc autotrace cups-bsd | lpr | lprng enscript ffmpeg gimp gnuplot 18% |██████ | 501kB 5.8MB/s eta 0:00:01 Get:21 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libavahi-common-data amd64 0.7-3.1ubuntu1.1 [22.1 kB] 52% |████████████████▊ | 4.2MB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/dashboard.css'Setting up libnspr4:amd64 (2:4.18-1ubuntu1) ... Running setup.py bdist_wheel for pdftotext ... \39% [74 libvpx5 2613 B/798 kB 0%] 3755 kB/s 11sPreparing to unpack .../32-python3-lib2to3_3.6.7-1~18.04_all.deb ...52% [43 libpython3.6-dev 4765 kB/44.8 MB 11%] 4081 kB/s 11sSelecting previously unselected package libxfixes3:amd64.48% [10 Sources 8678 kB/9051 kB 96%] Unpacking libmagickcore-6.q16-3-extra:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ...34% [Waiting for headers] Enabling module mime.Creating home directory `/home/paperless' ... 41% |█████████████▏ | 1.1MB 5.9MB/s eta 0:00:01 Preparing to unpack .../079-libxvidcore4_2%3a1.3.5-1_amd64.deb ...Setting up libavahi-common-data:amd64 (0.7-3.1ubuntu1.1) ...bms@FortBoyard:~$ # ssh to my machine running Linux Containers Applying documents.0006_auto_20160123_0430... OKUnpacking libaacs0:amd64 (0.9.0-1) ... Stored in directory: /root/.cache/pip/wheels/98/b0/dd/29e28ff615af3dda4c67cab719dd51357597eabff926976b45 64% |████████████████████▋ | 593kB 5.8MB/s eta 0:00:01 Selecting previously unselected package libdjvulibre-text.Preparing to unpack .../130-optipng_0.7.6-1.1_amd64.deb ...Get:107 http://archive.ubuntu.com/ubuntu bionic/main amd64 libwmf0.2-7 amd64 0.2.8.4-12 [150 kB] 100% |████████████████████████████████| 61kB 3.9MB/s lxc-install.sh 100%[==========================================================>] 2.98K --.-KB/s in 0s Username (leave blank to use 'paperless'): Unpacking libxcb-xfixes0:amd64 (1.13-1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/jquery/jquery.js'Unpacking libpango-1.0-0:amd64 (1.40.14-1ubuntu0.1) ...54% [43 libpython3.6-dev 6805 kB/44.8 MB 15%] 4081 kB/s 10sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/inlines.js'30% [42 libavutil55 2613 B/190 kB 1%] 47% |███████████████ | 3.4MB 5.2MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-calendar.svg'34% [Working] 100% [Working] 4630 kB/s 0s Downloading https://files.pythonhosted.org/packages/cb/89/e3687d3ed99bc882793f82634e9824e62499fdfdc4b1ae39e211c5b05017/tzlocal-1.5Setting up libpoppler-cpp0v5:amd64 (0.62.0-2ubuntu2.5) ...Setting up poppler-data (0.4.8-2) ... 93% |█████████████████████████████▉ | 2.5MB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-addlink.svg'Preparing to unpack .../013-libtiff5_4.0.9-5_amd64.deb ... 65% |█████████████████████ | 2.0MB 6.0MB/s eta 0:00:01 20% |██████▌ | 399kB 5.9MB/s eta 0:00:01 Preparing to unpack .../25-libstdc++-7-dev_7.3.0-27ubuntu1~18.04_amd64.deb ...Preparing to unpack .../102-libilmbase12_2.2.0-11ubuntu2_amd64.deb ...Collecting docutils==0.14 (from -r requirements.txt (line 21))Preparing to unpack .../02-libaprutil1-dbd-sqlite3_1.6.1-2_amd64.deb ...24% [24 gcc-7 2611 B/7455 kB 0%] Selecting previously unselected package libgcc-7-dev:amd64.2.tar.gz(Reading database ... 32755 files and directories currently installed.) Applying documents.0021_document_storage_type... OK Running setup.py bdist_wheel for python-levenshtein ... doneSelecting previously unselected package libalgorithm-merge-perl.Get:81 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libzvbi-common all 0.2.35-13 [32.1 kB] 48% [Waiting for headers] 4081 kB/s 12s63% [43 libpython3.6-dev 16.8 MB/44.8 MB 37%] 4081 kB/s 8sGet:18 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libtsan0 amd64 8.2.0-1ubuntu2~18.04 [288 kB]24% [Waiting for headers] Get:113 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpoppler73 amd64 0.62.0-2ubuntu2.5 [800 kB] '/usr/share/proftpd/templates/welcome.msg' -> '/srv/ftp/welcome.msg.proftpd-new'Selecting previously unselected package libva-x11-2:amd64.Unpacking libva-drm2:amd64 (2.1.0-3) ...nv-0.9.1-py2.py3-none-any.whl netpbm poppler-data python3-olefile python3-pil tesseract-ocr-eng tesseract-ocr-osd va-driver-all vdpau-driver-allSelecting previously unselected package apache2-data.Preparing to unpack .../035-libaacs0_0.9.0-1_amd64.deb ...update-alternatives: using /usr/bin/identify-im6.q16 to provide /usr/bin/identify-im6 (identify-im6) in auto modee 2.8; in order to keep installing from binary please use "pip install psycopg2-binary" instead. For details see: <http://initd.org/ 30% |█████████▉ | 604kB 6.0MB/s eta 0:00:01 Collecting pytest-cov==2.6.0 (from -r requirements.txt (line 54)) 66% |█████████████████████▍ | 5.4MB 906kB/s eta 0:00:03 Building dependency tree... 0%Unpacking libtesseract4 (4.00~git2288-10f4998a-2) ...Ignoring python-levenshtein: markers 'extra == "speedup"' don't match your environment58% [Waiting for headers] 3755 kB/s 7s 97% |███████████████████████████████▏| 6.9MB 37.4MB/s eta 0:00:01 Get:56 http://archive.ubuntu.com/ubuntu bionic/main amd64 libthai-data all 0.1.27-2 [133 kB]Setting up python3-lib2to3 (3.6.7-1~18.04) ... 86% |███████████████████████████▋ | 194kB 5.9MB/s eta 0:00:01 40% |█████████████ | 92kB 5.8MB/s eta 0:00:01 Collecting requests==2.20.0 (from -r requirements.txt (line 67))Collecting djangorestframework==3.9.0 (from -r requirements.txt (line 19))Setting up librsvg2-2:amd64 (2.40.20-2) ...Get:22 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libavahi-common3 amd64 0.7-3.1ubuntu1.1 [21.7 kB] Downloading https://files.pythonhosted.org/packages/d1/e6/adb3be5576f5d27c6faa33f1e9fea8fe5dbd9351db12148de948507e352c/prompt_tooly2.py3-none-any.whl (53kB)Setting up libaprutil1-dbd-sqlite3:amd64 (1.6.1-2) ...Preparing to unpack .../17-libtsan0_8.2.0-1ubuntu2~18.04_amd64.deb ... Not uninstalling pyocr at /usr/lib/python3/dist-packages, outside environment /usr21% [30 libgs9 2611 B/2263 kB 0%] 11% |███▊ | 942kB 3.6MB/s eta 0:00:02 25% [10 Sources 1584 kB/9051 kB 17%] [12 Translation-en 2688 B/91.6 kB 3%] 32% |██████████▌ | 2.7MB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hi.js' 11% |███▋ | 112kB 6.5MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/sorting-icons.svg'Preparing to unpack .../076-libwebpmux3_0.6.1-2_amd64.deb ...Unpacking libxcb-render0:amd64 (1.13-1) ... 48% |███████████████▌ | 3.9MB 6.0MB/s eta 0:00:01 86% |███████████████████████████▋ | 727kB 6.0MB/s eta 0:00:01 Selecting previously unselected package libgsm1:amd64.38% [Waiting for headers] 3755 kB/s 11s Applying auth.0001_initial... OKPreparing to unpack .../129-netpbm_2%3a10.0-15.3build1_amd64.deb ...Selecting previously unselected package dpkg-dev.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ko.js'Unpacking libnss3:amd64 (2:3.35-2ubuntu2.1) ...55% [Waiting for headers] 3755 kB/s 8s Downloading https://files.pythonhosted.org/packages/d0/43/2160a300e0b77a929a980f36ac7427dcef8f4ddac7a8c21e5a8baedad828/tox-3.5.3-pPreparing to unpack .../31-build-essential_12.4ubuntu1_amd64.deb ...Preparing to unpack .../57-python3-xdg_0.25-4ubuntu1_all.deb ...56% [Working] 3755 kB/s 8sPreparing to unpack .../36-fakeroot_1.22-2ubuntu1_amd64.deb ...20.0-py2.py3-none-any.whl (60kB)Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sk.js'Receiving objects: 93% (5181/5570), 4.67 MiB | 3.10 MiB/s 19% [18 libtsan0 2613 B/288 kB 1%] Preparing to unpack .../091-libbdplus0_0.1.2-2_amd64.deb ...28% [24 gcc-7 4531 kB/7455 kB 61%] 16% |█████▏ | 1.3MB 4.3MB/s eta 0:00:02 Setting up libpoppler73:amd64 (0.62.0-2ubuntu2.5) ...Setting up make (4.1-9.1ubuntu1) ... 98% |███████████████████████████████▌| 634kB 5.8MB/s eta 0:00:01 Unpacking libmpx2:amd64 (8.2.0-1ubuntu2~18.04) ...Setting up libwmf0.2-7:amd64 (0.2.8.4-12) ...Get:29 http://archive.ubuntu.com/ubuntu bionic-updates/universe Translation-en [175 kB]Copying '/home/paperless/paperless/src/documents/static/documents/img/tiff.png'Requirement already satisfied: jinja2==2.10 in /usr/lib/python3/dist-packages (from -r requirements.txt (line 35)) Downloading https://files.pythonhosted.org/packages/84/71/c8ca4f5bb1e08401b916c68003acf0a0655df935d74d93bf3f3364b310e0/backcall-0.Get:9 http://archive.ubuntu.com/ubuntu bionic/main amd64 libjbig0 amd64 2.1-3.1build1 [26.7 kB]Preparing to unpack .../003-fontconfig_2.12.6-0ubuntu2_amd64.deb ...Setting up libxcb-present0:amd64 (1.13-1) ... 72% |███████████████████████ | 5.1MB 5.9MB/s eta 0:00:01 Applying auth.0003_alter_user_email_max_length... OKSelecting previously unselected package g++. 68% |█████████████████████▉ | 2.1MB 5.9MB/s eta 0:00:01 Preparing to unpack .../023-libcups2_2.2.7-1ubuntu2.3_amd64.deb ...Unpacking python3-pyocr (0.3.0-1) ...Preparing to unpack .../117-libsensors4_1%3a3.4.0-4_amd64.deb ...Reading package lists... 99%Get:33 http://archive.ubuntu.com/ubuntu bionic/main amd64 hicolor-icon-theme all 0.17-2 [9976 B]Preparing to unpack .../083-libbluray2_1%3a1.0.2-3_amd64.deb ...28% [10 Sources 2262 kB/9051 kB 25%] [Waiting for headers] Unpacking libxcb-present0:amd64 (1.13-1) ...Setting up libjbig0:amd64 (2.1-3.1build1) ... - https://blog.ubuntu.com/2018/12/10/using-gpgpus-with-kubernetesUnpacking tesseract-ocr-eng (4.00~git24-0e00fe6-1.2) ...22% [10 Sources 895 kB/9051 kB 10%] [11 Packages 188 kB/242 kB 78%] Setting up libopus0:amd64 (1.1.2-1ubuntu1) ... Downloading https://files.pythonhosted.org/packages/19/6c/b2ac85b3f0b48ac968af3741c4f020bf272ab9dabbd1643e9c719441099a/factory_boyPreparing to unpack .../126-libxshmfence1_1.3-1_amd64.deb ...info: Executing deferred 'a2enmod wsgi' for package libapache2-mod-wsgi-py312% [3 proftpd-basic 2611 B/2015 kB 0%] Building dependency tree... 50%Selecting previously unselected package python3-crypto.Extracting templates from packages: 42%Enabling module authz_core.Selecting previously unselected package libsensors4:amd64.Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/img/favicon.ico'Unpacking libsnappy1v5:amd64 (1.1.7-1) ... Downloading https://files.pythonhosted.org/packages/3e/6a/a3f909083079d03bde11d06ab23088886bbe25f2c97fbe4bb865e2bf05bc/pytest-sugaPreparing to unpack .../28-make_4.1-9.1ubuntu1_amd64.deb ...Username (leave blank to use 'paperless'): Unpacking libpciaccess0:amd64 (0.14-1) ...Unpacking liblcms2-2:amd64 (2.9-1ubuntu0.1) ... Applying documents.0022_auto_20181007_1420... OKSelecting previously unselected package libxcb-shm0:amd64.Preparing to unpack .../057-libthai0_0.1.27-2_amd64.deb ...Unpacking tesseract-ocr-osd (4.00~git24-0e00fe6-1.2) ...Get:99 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdrm-nouveau2 amd64 2.4.91-2 [16.5 kB] Selecting previously unselected package fonts-droid-fallback.Preparing to unpack .../065-libsnappy1v5_1.1.7-1_amd64.deb ...Unpacking librsvg2-2:amd64 (2.40.20-2) ...Unpacking libgraphite2-3:amd64 (1.3.11-2) ... 48% |███████████████▌ | 1.5MB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/login.css'update-alternatives: using /usr/bin/stream-im6.q16 to provide /usr/bin/stream (stream) in auto modePreparing to unpack .../046-libcairo2_1.15.10-2_amd64.deb ...Preparing to unpack .../037-libva-drm2_2.1.0-3_amd64.deb ... manpages-dev python-pip-whl python3-crypto python3-dev python3-distutils python3-keyring python3-keyrings.alt python3-lib2to3Adding user `paperless' to group `ftpupload' ...Collecting ipython==7.1.1 (from -r requirements.txt (line 33))Setting up python3-wheel (0.30.0-0.2) ...Setting up libpaper1:amd64 (1.1.24+nmu5ubuntu1) ...Selecting previously unselected package libcupsimage2:amd64. 87% |████████████████████████████ | 6.2MB 5.8MB/s eta 0:00:01 Setting up libdjvulibre21:amd64 (3.5.27.1-8) ...Setting up libsnappy1v5:amd64 (1.1.7-1) ...Selecting previously unselected package libalgorithm-diff-perl.Get:26 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libstdc++-7-dev amd64 7.3.0-27ubuntu1~18.04 [1463 kB] 3% |█ | 245kB 1.6MB/s eta 0:00:05 Processing triggers for ufw (0.35-5) ...3 kB]Unpacking libxcb-dri3-0:amd64 (1.13-1) ... 56% |██████████████████ | 307kB 6.1MB/s eta 0:00:01 Preparing to unpack .../078-libx265-146_2.6-3_amd64.deb ... 15% |█████ | 409kB 5.2MB/s eta 0:00:01 0% [5 Sources store 0 B] [4 InRelease gpgv 74.6 kB] [10 Sources 14.3 kB/9051 kB 0%] [Waiting for headers] Get:39 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxfixes3 amd64 1:5.0.3-1 [10.8 kB]Unpacking libbdplus0:amd64 (0.1.2-2) ... 89% |████████████████████████████▊ | 2.4MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libavutil55:amd64.Selecting previously unselected package python3.6-dev.Unpacking libcc1-0:amd64 (8.2.0-1ubuntu2~18.04) ...Collecting virtualenv==16.1.0 (from -r requirements.txt (line 79))Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/jquery.init.js'0% [1 fonts-dejavu-core 2612 B/1041 kB 0%] Selecting previously unselected package libjpeg-turbo8:amd64.Collecting tzlocal==1.5.1 (from -r requirements.txt (line 77))Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/fontawesome-webfont.woff'Get:125 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-sync1 amd64 1.13-1 [8808 B] Selecting previously unselected package libcc1-0:amd64.Get:10 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libapache2-mod-wsgi-py3 amd64 4.5.17-1 [87.8 kB].1.tar.gz1.0.7.zip (998kB) 0 upgraded, 11 newly installed, 0 to remove and 19 not upgraded.Selecting previously unselected package libsnappy1v5:amd64.Collecting sphinx==1.8.1 (from -r requirements.txt (line 70))83% [Working] 4630 kB/s 2sPreparing to unpack .../105-libopenexr22_2.2.0-11.1ubuntu1_amd64.deb ... 60% |███████████████████▎ | 389kB 5.8MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/bootstrap-theme.min.css'75% [10 Sources store 0 B] Unpacking libgs9:amd64 (9.26~dfsg+0-0ubuntu0.18.04.3) ...Selecting previously unselected package fakeroot. Downloading https://files.pythonhosted.org/packages/89/e6/b5a1de8b0cc4e07ca1b305a4fcc3f9806025c1b651ea302646341222f88b/pexpect-4.6 6% |██▏ | 481kB 5.9MB/s eta 0:00:02 91% [18 Packages store 0 B] Setting up libpaper-utils (1.1.24+nmu5ubuntu1) ... 100% |████████████████████████████████| 92kB 3.7MB/s Downloading https://files.pythonhosted.org/packages/bc/2a/61a8f9719bd6df5b421abd91740cb0595fc3c17b28eaf89fe4f144472ca6/psycopg2-2.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/gl.js'Get:114 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpoppler-cpp0v5 amd64 0.62.0-2ubuntu2.5 [28.0 kB] Stored in directory: /root/.cache/pip/wheels/75/fc/26/357bc139b726977ab08817308ce76d96a26bdbe2329a43b15a27% [13 Packages store 0 B] [10 Sources 2085 kB/9051 kB 23%] [Waiting for headers] Reading package lists... 96% Found existing installation: attrs 17.4.052% [Waiting for headers] 3755 kB/s 8s6% [Working] 2% |▉ | 194kB 6.0MB/s eta 0:00:02 99% |███████████████████████████████▉| 993kB 6.0MB/s eta 0:00:01 Preparing to unpack .../proftpd-basic_1.3.5e-1build1_amd64.deb ...Get:94 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdjvulibre-text all 3.5.27.1-8 [49.1 kB] 86% |███████████████████████████▊ | 1.7MB 5.9MB/s eta 0:00:01 83% |██████████████████████████▋ | 829kB 5.9MB/s eta 0:00:01 0% [2 InRelease gpgv 83.2 kB] Preparing to unpack .../07-gcc-7-base_7.3.0-27ubuntu1~18.04_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/nb.js' 9% |███ | 778kB 3.4MB/s eta 0:00:03 Setting up libtiff5:amd64 (4.0.9-5) ...Selecting previously unselected package hicolor-icon-theme.Preparing to unpack .../019-fonts-noto-mono_20171026-2_all.deb ...Get:95 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdjvulibre21 amd64 3.5.27.1-8 [559 kB] 50% |████████████████▎ | 1.0MB 5.9MB/s eta 0:00:01 Preparing to unpack .../018-poppler-data_0.4.8-2_all.deb ... 93% |██████████████████████████████ | 7.6MB 6.0MB/s eta 0:00:01 Selecting previously unselected package python3-distutils.Unpacking python3-keyring (10.6.0-1) ...47% [Waiting for headers] 4081 kB/s 12sGet:8 http://archive.ubuntu.com/ubuntu bionic/main amd64 libfftw3-double3 amd64 3.3.7-1 [735 kB] 14% |████▋ | 1.2MB 3.9MB/s eta 0:00:02 Setting up python3-secretstorage (2.3.1-2) ...Setting up python3-keyrings.alt (3.0-1) ...Get:131 http://archive.ubuntu.com/ubuntu bionic/main amd64 optipng amd64 0.7.6-1.1 [83.4 kB] 24% |████████ | 2.0MB 5.5MB/s eta 0:00:02 Warning: The home dir /run/proftpd you specified can't be accessed: No such file or directory 40% |█████████████ | 3.3MB 6.0MB/s eta 0:00:01 Resolving deltas: 8% (293/3560) 2% [Waiting for headers] Unpacking optipng (0.7.6-1.1) ...Resolving raw.githubusercontent.com (raw.githubusercontent.com)... Found existing installation: pyocr 0.3.030% [Waiting for headers] Get:141 http://archive.ubuntu.com/ubuntu bionic/main amd64 vdpau-driver-all amd64 1.1.1-3ubuntu1 [4674 B] Selecting previously unselected package libpython3.6-dev:amd64.Get:100 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdrm-radeon1 amd64 2.4.91-2 [21.7 kB] 52% |████████████████▋ | 112kB 6.4MB/s eta 0:00:01 Get:5 http://archive.ubuntu.com/ubuntu bionic/main amd64 libc-dev-bin amd64 2.27-3ubuntu1 [71.8 kB] 98% |███████████████████████████████▌| 61kB 6.3MB/s eta 0:00:01 Running setup.py bdist_wheel for pyocr ... doneGet:24 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 gcc-7 amd64 7.3.0-27ubuntu1~18.04 [7455 kB]Setting up libfftw3-double3:amd64 (3.3.7-1) ...Preparing to unpack .../051-libopus0_1.1.2-1ubuntu1_amd64.deb ...Get:9 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 apache2 amd64 2.4.29-1ubuntu4.5 [95.1 kB]Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/search.svg'28% [Working] 88% |████████████████████████████▍ | 61kB 5.1MB/s eta 0:00:01 0.6.0-py2.py3-none-any.whl31% [Waiting for headers] Setting up libpciaccess0:amd64 (0.14-1) ...56% [Waiting for headers] 3755 kB/s 8sGet:53 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 python3-pip all 9.0.1-2.3~ubuntu1 [114 kB] Preparing to unpack .../06-apache2-utils_2.4.29-1ubuntu4.5_amd64.deb ... Running setup.py bdist_wheel for tzlocal ... done Downloading https://files.pythonhosted.org/packages/36/fa/08e9e6e0e3cbd1d362c3bbee8d01d0aedb2155c4ac112b19ef3cae8eed8d/docutils-0.90% [Waiting for headers] 4611 kB/s 1sCopying '/home/paperless/paperless/src/paperless/static/paperless/img/logo-light.png'Setting up libaacs0:amd64 (0.9.0-1) ... 65% |█████████████████████ | 501kB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/select2.full.js'Setting up build-essential (12.4ubuntu1) ...Enabling conf security.Collecting certifi==2018.10.15 (from -r requirements.txt (line 8))Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/glyphicons-halflings-regular.svg'Get:35 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 imagemagick amd64 8:6.9.7.4+dfsg-16ubuntu6.4 [14.2 kB]Setting up liblua5.2-0:amd64 (5.2.4-1.1build1) ... Downloading https://files.pythonhosted.org/packages/02/75/d041ed00994fbac4c5183e6f4bf6c906506bef8da7a57ef3fc825f171020/pytest-3.9.41% [29 make 4061 B/154 kB 3%] 4081 kB/s 12sCollecting pytest-env==0.6.2 (from -r requirements.txt (line 56))Setting up fonts-droid-fallback (1:6.0.1r16-1.1) ...Collecting ptyprocess==0.6.0 (from -r requirements.txt (line 48))Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/fonts.css'Receiving objects: 18% (1003/5570) Stored in directory: /root/.cache/pip/wheels/a9/c0/1e/32b694059fabeb7a9bcd2c65091ca875cd78ec1f54f47ea03bGet:37 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libva2 amd64 2.1.0-3 [47.6 kB]Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/changelists.css'23% [6 apache2-bin 2611 B/1071 kB 0%] 85% |███████████████████████████▎ | 788kB 5.9MB/s eta 0:00:01 (Reading database ... 33040 files and directories currently installed.)Reading package lists... 56% mesa-vdpau-drivers netpbm optipng poppler-data python3-olefile python3-pil python3-pyocr tesseract-ocr tesseract-ocr-eng 22% |███████ | 1.6MB 5.9MB/s eta 0:00:01 21% [Waiting for headers] Preparing to unpack .../140-vdpau-driver-all_1.1.1-3ubuntu1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/th.js'Preparing to unpack .../108-libnetpbm10_2%3a10.0-15.3build1_amd64.deb ...update-alternatives: using /usr/bin/import-im6.q16 to provide /usr/bin/import (import) in auto mode Downloading https://files.pythonhosted.org/packages/d7/ca/3c74396a9ed8a4cfab5459800edeef9a1269591cb21f5a49bd71a49c5fa2/filelock-3.92% [18 Packages store 0 B] 29% [10 Sources 2531 kB/9051 kB 28%] [Waiting for headers] Extracting templates from packages: 63%HTTP request sent, awaiting response... 2019-01-20 19:50:06 (35.8 MB/s) - ‘lxc-install.sh’ saved [3054/3054]93% [18 Packages store 0 B] [27 Translation-en 0 B/182 kB 0%] 81% |██████████████████████████ | 1.6MB 6.0MB/s eta 0:00:01 44% [83 libavcodec57 4059 B/4592 kB 0%] 3755 kB/s 10sGet:54 http://archive.ubuntu.com/ubuntu bionic/main amd64 libgdk-pixbuf2.0-common all 2.36.11-2 [4536 B]43% [82 libzvbi0 4061 B/235 kB 2%] 3755 kB/s 10s96% [Waiting for headers] 4944 kB/s 0s 51% |████████████████▍ | 4.1MB 6.0MB/s eta 0:00:01 Get:88 http://archive.ubuntu.com/ubuntu bionic/main amd64 libvorbisfile3 amd64 1.3.5-4.2 [16.0 kB] .9.0-py2.py3-none-any.whl (112kB)Setting up gcc (4:7.3.0-3ubuntu2.1) ...Setting up libavformat57:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Unpacking libmpc3:amd64 (1.1.0-1) ...Preparing to unpack .../066-libspeex1_1.2~rc1.2-1ubuntu2_amd64.deb ...Unpacking python3.6-venv (3.6.7-1~18.04) ...Preparing to unpack .../071-libvorbis0a_1.3.5-4.2_amd64.deb ...7% [11 liblcms2-2 2613 B/139 kB 2%] Setting up libjbig2dec0:amd64 (0.13-6) ...Preparing to unpack .../35-libfakeroot_1.22-2ubuntu1_amd64.deb ...bms@pingu:~$ 5% [7 libc6-dev 4059 B/2587 kB 0%] Applying contenttypes.0001_initial... OKEnabling module authn_core.24% [32 gsfonts 1163 B/3120 kB 0%] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/fonts/Roboto-Regular-webfont.woff'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/inlines.min.js'update-alternatives: using /usr/bin/fakeroot-sysv to provide /usr/bin/fakeroot (fakeroot) in auto mode92% [Waiting for headers] 42% [31 dpkg-dev 2613 B/608 kB 0%] 4081 kB/s 12s 100% |████████████████████████████████| 235kB 2.8MB/s Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/es.js'Get:111 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libnss3 amd64 2:3.35-2ubuntu2.1 [1135 kB] Running setup.py bdist_wheel for pytest-sugar ... -4% [Waiting for headers] 81% |██████████████████████████ | 6.6MB 6.0MB/s eta 0:00:01 update-alternatives: using /usr/bin/composite-im6.q16 to provide /usr/bin/composite (composite) in auto modeCollecting pytest==3.9.3 (from -r requirements.txt (line 60))31% [Working] Enabling module mpm_event.Regenerating fonts cache... done. 80% |█████████████████████████▉ | 5.7MB 5.9MB/s eta 0:00:01 Unpacking libgcc-7-dev:amd64 (7.3.0-27ubuntu1~18.04) ...Get:16 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libmagickcore-6.q16-3 amd64 8:6.9.7.4+dfsg-16ubuntu6.4 [1616 kB] 100% |████████████████████████████████| 61kB 4.5MB/s 97% [19 Translation-en store 0 B] 4229 kB/s 0sSetting up mesa-va-drivers:amd64 (18.0.5-0ubuntu0~18.04.1) ...Setting up libjpeg8:amd64 (8c-2ubuntu8) ...Preparing to unpack .../036-libva2_2.1.0-3_amd64.deb ...4% [Working] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/fonts/Roboto-Light-webfont.woff'Get:76 http://archive.ubuntu.com/ubuntu bionic/main amd64 libwebp6 amd64 0.6.1-2 [185 kB] Get:36 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libaacs0 amd64 0.9.0-1 [51.4 kB]Selecting previously unselected package python3-venv. 100% |████████████████████████████████| 768kB 1.2MB/s Preparing to unpack .../050-libopenjp2-7_2.3.0-1_amd64.deb ...52% [91 libavformat57 1165 B/949 kB 0%] 3755 kB/s 8s 96% |██████████████████████████████▉ | 7.8MB 5.9MB/s eta 0:00:01 Preparing to unpack .../002-libfontconfig1_2.12.6-0ubuntu2_amd64.deb ...29% [Waiting for headers] Unpacking libmp3lame0:amd64 (3.100-2) ...Selecting previously unselected package cpp-7.14% [Waiting for headers] Collecting alabaster==0.7.12 (from -r requirements.txt (line 2))Unpacking i965-va-driver:amd64 (2.1.0-0ubuntu1) ...44% [Waiting for headers] 4081 kB/s 12sSelecting previously unselected package build-essential. Running setup.py bdist_wheel for termcolor ... -Receiving objects: 100% (5570/5570), 6.39 MiB | 3.49 MiB/s, done.Selecting previously unselected package libmpc3:amd64.Reading package lists... 97% * Documentation: https://help.ubuntu.comCollecting django-extensions==2.1.3 (from -r requirements.txt (line 16)) 100% |████████████████████████████████| 348kB 2.2MB/s 85% |███████████████████████████▎ | 6.9MB 5.8MB/s eta 0:00:01 Setting up tesseract-ocr-osd (4.00~git24-0e00fe6-1.2) ...Collecting pyparsing==2.3.0 (from -r requirements.txt (line 53))Get:96 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdrm-amdgpu1 amd64 2.4.91-2 [19.0 kB] Preparing to unpack .../proftpd-doc_1.3.5e-1build1_all.deb ...92% [135 tesseract-ocr-eng 2611 B/1588 kB 0%] 4630 kB/s 1s Running setup.py bdist_wheel for termcolor ... doneDone.Setting up libgraphite2-3:amd64 (1.3.11-2) ... 1% |▌ | 122kB 1.1MB/s eta 0:00:08 Selecting previously unselected package libthai-data.Unpacking libavcodec57:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Setting up python3-olefile (0.45.1-1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/js/api.js'Get:1 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-dejavu-core all 2.37-1 [1041 kB]Selecting previously unselected package liblua5.2-0:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ja.js' 12% |████ | 880kB 5.8MB/s eta 0:00:02 .5.1-py2.py3-none-any.whl Not uninstalling certifi at /usr/lib/python3/dist-packages, outside environment /usrSetting up libcupsfilters1:amd64 (1.20.2-0ubuntu3) ...84% [Waiting for headers] 4630 kB/s 2s 92% |█████████████████████████████▋ | 1.8MB 6.0MB/s eta 0:00:01 Applying documents.0018_auto_20170715_1712... OKGet:8 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 apache2-data all 2.4.29-1ubuntu4.5 [160 kB] 58% |██████████████████▉ | 4.8MB 5.8MB/s eta 0:00:01 Selecting previously unselected package python3-lib2to3.89% [Waiting for headers] 4630 kB/s 1sResolving deltas: 35% (1255/3560) 0 upgraded, 141 newly installed, 0 to remove and 19 not upgraded.Selecting previously unselected package python3-olefile. i965-va-driver imagemagick-6-common imagemagick-6.q16 libaacs0 libavahi-client3 libavahi-common-data libavahi-common3Unpacking apache2 (2.4.29-1ubuntu4.5) ...update-alternatives: using /usr/bin/animate-im6.q16 to provide /usr/bin/animate-im6 (animate-im6) in auto modeSelecting previously unselected package libgs9:amd64. 18% |██████ | 1.5MB 4.8MB/s eta 0:00:02 37% [Waiting for headers] Unpacking libva2:amd64 (2.1.0-3) ...Preparing to unpack .../120-libx11-xcb1_2%3a1.6.4-3ubuntu0.1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/default.js'Get:110 http://archive.ubuntu.com/ubuntu bionic/main amd64 libnspr4 amd64 2:4.18-1ubuntu1 [112 kB] 68% [105 libllvm6.0 8630 kB/14.5 MB 59%] 3755 kB/s 5sSelecting previously unselected package libtiff5:amd64.Setting up liblqr-1-0:amd64 (0.4.2-2.1) ... libgomp1 libgraphite2-3 libgs9 libgs9-common libgsm1 libharfbuzz0b libijs-0.35 libilmbase12 libjbig0 libjbig2dec0 libjpeg-turbo8 61% |███████████████████▋ | 5.0MB 5.7MB/s eta 0:00:01 -py2.py3-none-any.whl (506kB).1-py3-none-any.whl (764kB)Setting up librsvg2-common:amd64 (2.40.20-2) ...Selecting previously unselected package libpython3-dev:amd64.Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/glyphicons-halflings-regular.woff2'90% [18 Packages store 0 B] Preparing to unpack .../47-python3.6-dev_3.6.7-1~18.04_amd64.deb ... 60% |███████████████████▍ | 204kB 6.0MB/s eta 0:00:01 9% |███ | 686kB 5.9MB/s eta 0:00:02 92% [18 Packages store 0 B] [26 Packages 2687 B/489 kB 1%] 38% [Waiting for headers] 3755 kB/s 11sSelecting previously unselected package libpixman-1-0:amd64.Unpacking libvpx5:amd64 (1.7.0-3) ...Preparing to unpack .../004-fonts-droid-fallback_1%3a6.0.1r16-1.1_all.deb ...Setting up libavutil55:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Preparing to unpack .../111-libpaper-utils_1.1.24+nmu5ubuntu1_amd64.deb ... """)Unpacking imagemagick-6-common (8:6.9.7.4+dfsg-16ubuntu6.4) ...Unpacking apache2-utils (2.4.29-1ubuntu4.5) ...98% [139 i965-va-driver 2613 B/925 kB 0%] 4630 kB/s 0s.0-py2.py3-none-any.whl (57kB)Get:51 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-keyring all 10.6.0-1 [26.7 kB] Enabling conf other-vhosts-access-log. 5% |█▊ | 389kB 5.8MB/s eta 0:00:02 Collecting docopt==0.6.2 (from -r requirements.txt (line 20))4% [6 linux-libc-dev 2612 B/1010 kB 0%] 87% |████████████████████████████ | 2.7MB 5.8MB/s eta 0:00:01 Selecting previously unselected package libxcb-xfixes0:amd64.96% [18 Packages store 0 B] 76% [106 libopenexr22 2613 B/560 kB 0%] 3755 kB/s 4sSetting up binutils-common:amd64 (2.30-21ubuntu1~18.04) ...11% [Working] Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/glyphicons-halflings-regular.ttf' 84% |███████████████████████████ | 2.6MB 6.0MB/s eta 0:00:01 Applying auth.0007_alter_validators_add_error_messages... OKExtracting templates from packages: 51% exitGet:28 http://archive.ubuntu.com/ubuntu bionic/main amd64 libpaper1 amd64 1.1.24+nmu5ubuntu1 [13.6 kB]Selecting previously unselected package libquadmath0:amd64.52% [90 libssh-gcrypt-4 2613 B/171 kB 2%] 3755 kB/s 8sGet:65 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libshine3 amd64 3.1.1-1 [22.9 kB]Setting up liblcms2-2:amd64 (2.9-1ubuntu0.1) ...57% [43 libpython3.6-dev 9668 kB/44.8 MB 22%] 4081 kB/s 9s Memory usage: 7% IP address for lxdbr0: 10.69.143.1 Applying documents.0010_log... OKCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/base.css'Setting up hicolor-icon-theme (0.17-2) ...39% [27 g++-7 5580 kB/7570 kB 74%] 4081 kB/s 13sGet:17 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libmagickwand-6.q16-3 amd64 8:6.9.7.4+dfsg-16ubuntu6.4 [293 kB]Get:47 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-crypto amd64 2.6.1-8ubuntu2 [244 kB] Get:15 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libatomic1 amd64 8.2.0-1ubuntu2~18.04 [9064 B]util-2.7.5-py2.py3-none-any.whl (225kB)Unpacking libxrender1:amd64 (1:0.9.10-1) ... 15% |████▉ | 1.1MB 5.9MB/s eta 0:00:02 40% |████████████▉ | 307kB 5.8MB/s eta 0:00:01 gcc-7-base libalgorithm-diff-perl libalgorithm-diff-xs-perl libalgorithm-merge-perl libasan4 libatomic1 libbinutils libc-dev-binCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-yes.svg' 95% |██████████████████████████████▌ | 7.7MB 5.9MB/s eta 0:00:01 Preparing to unpack .../03-libaprutil1-ldap_1.6.1-2_amd64.deb ...Processing triggers for ureadahead (0.100.0-20) ... 80% |█████████████████████████▋ | 6.5MB 6.0MB/s eta 0:00:01 1% [Working] 71% [43 libpython3.6-dev 24.8 MB/44.8 MB 55%] 4611 kB/s 5s Running setup.py bdist_wheel for tzlocal ... -8% [Waiting for headers] 53% [Waiting for headers] 3755 kB/s 8sSetting up libtheora0:amd64 (1.1.1+dfsg.1-14) ...Unpacking libbluray2:amd64 (1:1.0.2-3) ...Setting up libavcodec57:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Selecting previously unselected package liblsan0:amd64.Selecting previously unselected package libaacs0:amd64.29% [Waiting for headers] Receiving objects: 76% (4234/5570), 4.67 MiB | 3.10 MiB/s update-alternatives: using /usr/bin/convert-im6.q16 to provide /usr/bin/convert-im6 (convert-im6) in auto modeSelecting previously unselected package libmpg123-0:amd64.bms@pingu:~$ exi 63% |████████████████████▍ | 1.7MB 6.0MB/s eta 0:00:01 Selecting previously unselected package liblept5.mmer-1.2.1-py2.py3-none-any.whl (64kB)Get:97 http://archive.ubuntu.com/ubuntu bionic/main amd64 libpciaccess0 amd64 0.14-1 [17.9 kB] Unpacking libdjvulibre-text (3.5.27.1-8) ...Selecting previously unselected package va-driver-all:amd64.Unpacking libpangoft2-1.0-0:amd64 (1.40.14-1ubuntu0.1) ...39% [10 Sources 5845 kB/9051 kB 65%] Selecting previously unselected package libmpx2:amd64. Downloading https://files.pythonhosted.org/packages/10/e0/27850afcb1683561c42db7c20e897cd5eb75b24843d574d8ec1389da4d49/fuzzywuzzy- 92% |█████████████████████████████▊ | 471kB 5.9MB/s eta 0:00:01 Collecting decorator==4.3.0 (from -r requirements.txt (line 13)) 99% |███████████████████████████████▊| 757kB 6.4MB/s eta 0:00:01 Preparing to unpack .../22-libgcc-7-dev_7.3.0-27ubuntu1~18.04_amd64.deb ...0.6.2.tar.gzGet:30 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libdpkg-perl all 1.19.0.5ubuntu2.1 [211 kB] Email address: e 64% |████████████████████▊ | 5.3MB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/selector-icons.svg'Unpacking libjpeg8:amd64 (8c-2ubuntu8) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/timeparse.js' Applying auth.0002_alter_permission_name_max_length... OKSetting up python3-pil:amd64 (5.1.0-1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ca.js'Collecting pickleshare==0.7.5 (from -r requirements.txt (line 43))22% [Waiting for headers] .1 pytest-xdist-1.24.0 python-dateutil-2.7.5 python-dotenv-0.9.1 python-gnupg-0.4.3 python-levenshtein-0.12.0 pytz-2018.7 regex-2018Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/bootstrap-tweaks.css'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-alert.svg'Fetched 1818 kB in 1s (2310 kB/s) Setting up libshine3:amd64 (3.1.1-1) ...-py2.py3-none-any.whl (8.1MB)Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/xregexp/xregexp.js'Setting up libtwolame0:amd64 (0.3.13-3) ...Preparing to unpack .../43-libpython3-dev_3.6.7-1~18.04_amd64.deb ...Get:137 http://archive.ubuntu.com/ubuntu bionic/universe amd64 tesseract-ocr amd64 4.00~git2288-10f4998a-2 [218 kB] Downloading https://files.pythonhosted.org/packages/6c/9d/c0feec696b815708354a2fd06ae0f51330a15043822a29bc8be2f185d9fe/Django-2.0. 7% |██▍ | 614kB 2.8MB/s eta 0:00:03 39% [Waiting for headers] 3755 kB/s 11s18% [29 libgs9-common 2852 kB/5094 kB 56%] ib_websupport-1.1.0-py2.py3-none-any.whlGet:60 http://archive.ubuntu.com/ubuntu bionic/main amd64 libgraphite2-3 amd64 1.3.11-2 [78.7 kB]Selecting previously unselected package libitm1:amd64.Unpacking apache2-data (2.4.29-1ubuntu4.5) ...Preparing to unpack .../38-libalgorithm-diff-xs-perl_0.04-5_amd64.deb ...py_forms-1.7.2-py2.py3-none-any.whl (105kB) 90% |█████████████████████████████ | 583kB 5.9MB/s eta 0:00:01 Setting up libxcb-render0:amd64 (1.13-1) ...Unpacking libx11-xcb1:amd64 (2:1.6.4-3ubuntu0.1) ... 81% |██████████████████████████ | 2.5MB 6.0MB/s eta 0:00:01 20% [Waiting for headers] Selecting previously unselected package libgomp1:amd64.14% [Waiting for headers] 35% [Working] 54% [93 libcupsfilters1 2613 B/108 kB 2%] 3755 kB/s 8sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/gis/move_vertex_off.svg'Selecting previously unselected package libvorbis0a:amd64.64% [10 Sources store 0 B] [18 Packages 5094 kB/8570 kB 59%]hon-genutils-0.2.0 jedi-0.13.1 langdetect-1.0.7 more-itertools-4.3.0 packaging-18.0 parso-0.3.1 pdftotext-2.1.1 pexpect-4.6.0 picklenshtein-0.12.0.tar.gz (48kB)33% [51 libopenjp2-7 2613 B/145 kB 2%] Setting up libgdk-pixbuf2.0-0:amd64 (2.36.11-2) ...9-py3-none-any.whl (7.1MB)98% [54 python3-setuptools 4061 B/248 kB 2%] 4944 kB/s 0snsions-2.1.3-py2.py3-none-any.whl (216kB)0.15.0-py2.py3-none-any.whl 36% |███████████▌ | 2.6MB 6.0MB/s eta 0:00:01 Setting up libpoppler-dev:amd64 (0.62.0-2ubuntu2.5) ... 86% |███████████████████████████▋ | 7.0MB 6.0MB/s eta 0:00:01 Get:130 http://archive.ubuntu.com/ubuntu bionic/main amd64 netpbm amd64 2:10.0-15.3build1 [1017 kB] 61% |███████████████████▊ | 1.9MB 6.0MB/s eta 0:00:01 Setting up libthai0:amd64 (0.1.27-2) ...Fetched 3273 kB in 1s (3711 kB/s) Copying '/usr/local/lib/python3.6/dist-packages/django_extensions/static/django_extensions/js/jquery.bgiframe.js'78% [Waiting for headers] 3755 kB/s 3s81% [119 libtesseract4 2611 B/1163 kB 0%] 4630 kB/s 2s 91% |█████████████████████████████▍ | 1.8MB 5.9MB/s eta 0:00:01 Adding new user `ftp' (UID 112) with group `nogroup' ...Copying '/home/paperless/paperless/src/documents/static/documents/img/jpg.png'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/id.js' 36% |███████████▊ | 3.0MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libllvm6.0:amd64.Setting up vdpau-driver-all:amd64 (1.1.1-3ubuntu1) ...Setting up libmpx2:amd64 (8.2.0-1ubuntu2~18.04) ... 95% |██████████████████████████████▋ | 204kB 6.0MB/s eta 0:00:01 Selecting previously unselected package python3-pyocr.Unpacking libshine3:amd64 (3.1.1-1) ... 16% |█████▍ | 92kB 5.8MB/s eta 0:00:01 Unpacking libapache2-mod-wsgi-py3 (4.5.17-1) ...Fetched 64.4 MB in 15s (4211 kB/s) Selecting previously unselected package netpbm.90% [18 Packages store 0 B] [20 Packages 4135 B/151 kB 3%] Requirement already satisfied: markupsafe==1.0 in /usr/lib/python3/dist-packages (from -r requirements.txt (line 37))Get:68 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libsoxr0 amd64 0.1.2-3 [65.9 kB]Selecting previously unselected package libdjvulibre21:amd64. 99% |███████████████████████████████▊| 8.0MB 5.8MB/s eta 0:00:01 Get:6 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 linux-libc-dev amd64 4.15.0-43.46 [1010 kB]Setting up libijs-0.35:amd64 (0.35-13) ...Setting up libmagickwand-6.q16-3:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ....11.2 requests-2.20.0 snowballstemmer-1.2.1 sphinx-1.8.1 sphinxcontrib-websupport-1.1.0 termcolor-1.1.0 text-unidecode-1.2 toml-0.10Preparing to unpack .../006-libgomp1_8.2.0-1ubuntu2~18.04_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/popup_response.js' Running setup.py bdist_wheel for regex ... done Downloading https://files.pythonhosted.org/packages/4a/87/76ead690afc4c7710012ede242537cd9807dde9de6299e65d075925c0b02/python_gnupCollecting jedi==0.13.1 (from -r requirements.txt (line 34))Setting up libsoxr0:amd64 (0.1.2-3) ...Setting up libjpeg-turbo8:amd64 (1.5.2-0ubuntu5.18.04.1) ...Get:4 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 binutils amd64 2.30-21ubuntu1~18.04 [3392 B]Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/cs.js'94% [Waiting for headers] 4630 kB/s 0sGet:43 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpython3.6-dev amd64 3.6.7-1~18.04 [44.8 MB] 100% |████████████████████████████████| 153kB 3.3MB/s 97% [18 Packages store 0 B] 1.0.tar.gzSetting up libwebpmux3:amd64 (0.6.1-2) ... 92% |█████████████████████████████▌ | 81kB 6.1MB/s eta 0:00:01 Enabling conf serve-cgi-bin. 74% |████████████████████████ | 481kB 6.0MB/s eta 0:00:01 Running setup.py bdist_wheel for pdftotext ... | 33% |██████████▋ | 2.4MB 6.0MB/s eta 0:00:01 Setting up unpaper (6.1-2) ...Package apache2 is not configured yet. Will defer actions by package libapache2-mod-wsgi-py3. 53% |█████████████████ | 1.4MB 6.0MB/s eta 0:00:01 Setting up tesseract-ocr-eng (4.00~git24-0e00fe6-1.2) ...Get:22 http://archive.ubuntu.com/ubuntu bionic-updates/main Sources [231 kB]-2.4.0-py2.py3-none-any.whl (62kB)update-alternatives: using /usr/bin/mogrify-im6.q16 to provide /usr/bin/mogrify-im6 (mogrify-im6) in auto modeSetting up libpangoft2-1.0-0:amd64 (1.40.14-1ubuntu0.1) ...Get:7 http://archive.ubuntu.com/ubuntu bionic/main amd64 libc6-dev amd64 2.27-3ubuntu1 [2587 kB]2% [3 libfontconfig1 4061 B/137 kB 3%] libx11-xcb1 libx264-152 libx265-146 libxcb-dri2-0 libxcb-dri3-0 libxcb-present0 libxcb-render0 libxcb-shm0 libxcb-sync1Unpacking python3-setuptools (39.0.1-2) ...Selecting previously unselected package libbinutils:amd64.Preparing to unpack .../50-python3-keyring_10.6.0-1_all.deb ...16.1.0-py2.py3-none-any.whl (1.9MB)Selecting previously unselected package libilmbase12:amd64.Get:118 http://archive.ubuntu.com/ubuntu bionic/main amd64 libsensors4 amd64 1:3.4.0-4 [28.8 kB] Copying '/home/paperless/paperless/src/documents/static/documents/img/image.png'Selecting previously unselected package libpoppler-cpp-dev:amd64.Setting up libmpc3:amd64 (1.1.0-1) ...Creating home directory `/home/ftpupload' ...Get:9 http://security.ubuntu.com/ubuntu bionic-security/universe Sources [29.4 kB] 56% [10 Sources store 0 B] [18 Packages 2234 kB/8570 kB 26%] Unpacking dh-python (3.20180325ubuntu2) ... 100% |████████████████████████████████| 1.9MB 510kB/s Running setup.py bdist_wheel for pytest-sugar ... doneSetting up liblept5 (1.75.3-3) ...Receiving objects: 23% (1282/5570), 676.01 KiB | 1.30 MiB/s Get:40 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libva-x11-2 amd64 2.1.0-3 [11.5 kB]Unpacking libdatrie1:amd64 (0.2.10-7) ...Setting up libspeex1:amd64 (1.2~rc1.2-1ubuntu2) ...97% [19 Translation-en store 0 B] 4229 kB/s 0s Get:40 http://archive.ubuntu.com/ubuntu bionic/main amd64 libalgorithm-merge-perl all 0.08-3 [12.0 kB] 30% |█████████▊ | 2.5MB 5.8MB/s eta 0:00:01 72% |███████████████████████▍ | 614kB 6.0MB/s eta 0:00:01 Unpacking manpages-dev (4.15-1) ...After this operation, 247 MB of additional disk space will be used.32% [Waiting for headers] Get:123 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-dri3-0 amd64 1.13-1 [6536 B] Get:112 http://archive.ubuntu.com/ubuntu bionic/main amd64 libpaper-utils amd64 1.1.24+nmu5ubuntu1 [8170 B] 97% |███████████████████████████████▏| 348kB 6.1MB/s eta 0:00:01 Downloading https://files.pythonhosted.org/packages/f8/0e/2365ddc010afb3d79147f1dd544e5ee24bf4ece58ab99b16fbb465ce6dc0/pytz-2018.733% [52 libopus0 2613 B/159 kB 2%] 3% |█▏ | 112kB 6.4MB/s eta 0:00:01 Preparing to unpack .../113-libpoppler-cpp0v5_0.62.0-2ubuntu2.5_amd64.deb ... 79% |█████████████████████████▎ | 604kB 5.9MB/s eta 0:00:01 8% [16 libmagickcore-6.q16-3 2611 B/1616 kB 0%] Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/glyphicons-halflings-regular.woff' 24% |████████ | 1.8MB 6.0MB/s eta 0:00:01 Preparing to unpack .../038-libxfixes3_1%3a5.0.3-1_amd64.deb ...Setting up libxcb-xfixes0:amd64 (1.13-1) ...Setting up python3-venv (3.6.7-1~18.04) ...Setting up python3.6-dev (3.6.7-1~18.04) ...6% [Waiting for headers] Setting up libx11-xcb1:amd64 (2:1.6.4-3ubuntu0.1) ...Get:27 http://archive.ubuntu.com/ubuntu bionic-updates/main Translation-en [182 kB]Get:117 http://archive.ubuntu.com/ubuntu bionic/main amd64 librsvg2-common amd64 2.40.20-2 [5124 B] Unpacking libvorbisenc2:amd64 (1.3.5-4.2) ...Setting up libdrm-intel1:amd64 (2.4.91-2) ...78% [111 libnss3 2611 B/1135 kB 0%] 3755 kB/s 3s Downloading https://files.pythonhosted.org/packages/7c/17/9b7b6cddfd255388b58c61e25b091047f6814183e1d63741c8df8dcd65a2/virtualenv-Collecting inotify-simple==1.1.8 (from -r requirements.txt (line 31)) 9% |███▏ | 81kB 4.8MB/s eta 0:00:01 Unpacking python-pip-whl (9.0.1-2.3~ubuntu1) ...Setting up libchromaprint1:amd64 (1.4.3-1) ...Unpacking libx265-146:amd64 (2.6-3) ...Selecting previously unselected package python3-wheel.Selecting previously unselected package libgraphite2-3:amd64.Not creating home directory `/run/proftpd'. Downloading https://files.pythonhosted.org/packages/9a/41/220f49aaea88bc6fa6cba8d05ecf24676326156c23b991e80b3f2fc24c77/pickleshareCopying '/home/paperless/paperless/src/documents/static/documents/img/gif.png' 5% |█▋ | 419kB 3.1MB/s eta 0:00:03 nvidia-vdpau-driver nvidia-legacy-340xx-vdpau-driver 25% |████████▎ | 696kB 5.9MB/s eta 0:00:01 Unpacking libasan4:amd64 (7.3.0-27ubuntu1~18.04) ...Regenerating fonts cache... Get:50 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-secretstorage all 2.3.1-2 [12.1 kB] Preparing to unpack .../014-imagemagick-6-common_8%3a6.9.7.4+dfsg-16ubuntu6.4_all.deb ...Preparing to unpack .../069-libtheora0_1.1.1+dfsg.1-14_amd64.deb ... * MicroK8s is Kubernetes in a snap. Made by devs for devs.67% [4 proftpd-doc 4059 B/1165 kB 0%] Get:42 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libavutil55 amd64 7:3.4.4-0ubuntu0.18.04.1 [190 kB]Collecting fuzzywuzzy[speedup]==0.15.0 (from -r requirements.txt (line 27))Preparing to unpack .../058-libpango-1.0-0_1.40.14-1ubuntu0.1_amd64.deb ...remote: Compressing objects: 100% (12/12), done. 7% [Waiting for headers] Unpacking python3-pil:amd64 (5.1.0-1) ... Downloading https://files.pythonhosted.org/packages/3e/c7/3da685ef117d42ac8d71af525208759742dd235f8094221fdaafcd3dba8f/py-1.7.0-pyPreparing to unpack .../02-binutils-x86-64-linux-gnu_2.30-21ubuntu1~18.04_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/et.js'Setting up libswresample2:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Get:85 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libchromaprint1 amd64 1.4.3-1 [36.8 kB] _headers-2.4.0-py2.py3-none-any.whlUnpacking libavahi-client3:amd64 (0.7-3.1ubuntu1.1) ...Unpacking libcrystalhd3:amd64 (1:0.0~git20110715.fdd2f19-12) ...Get:78 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libx264-152 amd64 2:0.152.2854+gite9a5903-2 [609 kB] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ro.js' 53% |█████████████████ | 491kB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/prepopulate.js' 100% |████████████████████████████████| 2.7MB 387kB/s Unpacking libisl19:amd64 (0.19-1) ...13% [Waiting for headers] Running setup.py bdist_wheel for regex ... | 72% |███████████████████████▍ | 5.9MB 5.9MB/s eta 0:00:01 Collecting pytz==2018.7 (from -r requirements.txt (line 65)).0 pyocr-0.5.3 pyparsing-2.3.0 pytest-3.9.3 pytest-cov-2.6.0 pytest-django-3.4.3 pytest-env-0.6.2 pytest-forked-0.2 pytest-sugar-0.9 Found existing installation: requests 2.18.4Preparing to unpack .../00-binutils-common_2.30-21ubuntu1~18.04_amd64.deb ... 100% |████████████████████████████████| 71kB 3.5MB/s Get:20 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-noto-mono all 20171026-2 [75.5 kB]16% [5 liblua5.2-0 2613 B/108 kB 2%] Site 000-default disabled.Preparing to unpack .../127-mesa-va-drivers_18.0.5-0ubuntu0~18.04.1_amd64.deb ...Get:139 http://archive.ubuntu.com/ubuntu bionic/universe amd64 i965-va-driver amd64 2.1.0-0ubuntu1 [925 kB] Setting up fakeroot (1.22-2ubuntu1) ...Selecting previously unselected package libbdplus0:amd64.Preparing to unpack .../08-libisl19_0.19-1_amd64.deb ...bms@FortBoyard:~$ ex Found existing installation: idna 2.6 One quick install on a workstation, VM, or appliance.Setting up libltdl7:amd64 (2.4.6-2) ...Receiving objects: 19% (1059/5570) 79% [43 libpython3.6-dev 33.0 MB/44.8 MB 74%] 4611 kB/s 3sCopying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/img/grid.png'After this operation, 271 MB of additional disk space will be used. 26% |████████▋ | 204kB 6.0MB/s eta 0:00:01 72% |███████████████████████▎ | 368kB 5.9MB/s eta 0:00:01 Get:41 http://archive.ubuntu.com/ubuntu bionic/main amd64 libexpat1-dev amd64 2.2.5-3 [122 kB] 100% |████████████████████████████████| 61kB 3.7MB/s Preparing to unpack .../07-apache2-data_2.4.29-1ubuntu4.5_all.deb ...Preparing to unpack .../015-libmagickcore-6.q16-3_8%3a6.9.7.4+dfsg-16ubuntu6.4_amd64.deb ...Unpacking libva-x11-2:amd64 (2.1.0-3) ...8% [Waiting for headers] Setting up libasan4:amd64 (7.3.0-27ubuntu1~18.04) ...Setting up libgif7:amd64 (5.1.4-2) ...Get:28 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 Packages [711 kB]Preparing to unpack .../123-libxcb-present0_1.13-1_amd64.deb ...31% [10 Sources 2968 kB/9051 kB 33%] Get:44 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-render0 amd64 1.13-1 [14.7 kB]Preparing to unpack .../138-i965-va-driver_2.1.0-0ubuntu1_amd64.deb ...Get:93 http://archive.ubuntu.com/ubuntu bionic/main amd64 libcupsfilters1 amd64 1.20.2-0ubuntu3 [108 kB] 14% |████▊ | 112kB 6.5MB/s eta 0:00:01 Selecting previously unselected package libxcb-render0:amd64.Setting up apache2 (2.4.29-1ubuntu4.5) ...Unpacking libitm1:amd64 (8.2.0-1ubuntu2~18.04) ... Downloading https://files.pythonhosted.org/packages/b8/ad/c6f60602d3ee3d92fbed87675b6fb6a6f9a38c223343ababdb44ba201f10/Babel-2.6.092% [18 Packages store 0 B] [25 Sources 2687 B/122 kB 2%] 97% |███████████████████████████████▏| 1.9MB 6.0MB/s eta 0:00:01 97% [18 Packages store 0 B] logoutSetting up libtsan0:amd64 (8.2.0-1ubuntu2~18.04) ... proftpd-mod-geoipGet:72 http://archive.ubuntu.com/ubuntu bionic/main amd64 libvorbis0a amd64 1.3.5-4.2 [86.4 kB] Setting up libgs9:amd64 (9.26~dfsg+0-0ubuntu0.18.04.3) ... systemctl reload apache2Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/README.txt'40% [Working] 3755 kB/s 10s 5% |█▉ | 112kB 6.4MB/s eta 0:00:01 Setting up python3-xdg (0.25-4ubuntu1) ...Selecting previously unselected package binutils.update-alternatives: using /usr/bin/identify-im6.q16 to provide /usr/bin/identify (identify) in auto modeSelecting previously unselected package libdatrie1:amd64. liblsan0-dbg libtsan0-dbg libubsan0-dbg libcilkrts5-dbg libmpx2-dbg libquadmath0-dbg glibc-doc bzr libstdc++-7-doc make-docSetting up libopenjp2-7:amd64 (2.3.0-1) ...Unpacking fontconfig-config (2.12.6-0ubuntu2) ...Unpacking libgdk-pixbuf2.0-common (2.36.11-2) ... 71% |██████████████████████▉ | 1.9MB 5.9MB/s eta 0:00:01 Unpacking fakeroot (1.22-2ubuntu1) ...Unpacking ssl-cert (1.0.39) ...5.1-cp36-cp36m-manylinux1_x86_64.whl (202kB) 26% |████████▌ | 512kB 5.9MB/s eta 0:00:01 Downloading https://files.pythonhosted.org/packages/09/51/9c48a46334be50c13d25a3afe55fa05c445699304c5ad32619de953a2305/parso-0.3.1 68% |█████████████████████▉ | 4.9MB 6.0MB/s eta 0:00:01 65% |█████████████████████ | 1.3MB 6.0MB/s eta 0:00:01 utils-0.2.0-py2.py3-none-any.whl libaprutil1-ldap liblua5.2-0 ssl-certCollecting more-itertools==4.3.0 (from -r requirements.txt (line 38)) 90% |█████████████████████████████ | 2.8MB 6.0MB/s eta 0:00:01 Selecting previously unselected package apache2..7.12-py2.py3-none-any.whl 42% |█████████████▌ | 3.4MB 2.6MB/s eta 0:00:02 38% [Waiting for headers] 31% [Working] Unpacking libavahi-common3:amd64 (0.7-3.1ubuntu1.1) ...Enabling module filter.32% [26 libstdc++-7-dev 4059 B/1463 kB 0%] Selecting previously unselected package libspeex1:amd64.32% [Waiting for headers] Unpacking libilmbase12:amd64 (2.2.0-11ubuntu2) ...Get:18 http://archive.ubuntu.com/ubuntu bionic/universe amd64 Packages [8570 kB]remote: Total 5570 (delta 9), reused 21 (delta 9), pack-reused 5549 Selecting previously unselected package libtsan0:amd64.2.0-py2.py3-none-any.whl (841kB)Unpacking libwebp6:amd64 (0.6.1-2) ... Downloading https://files.pythonhosted.org/packages/3a/e1/5f9023cc983f1a628a8c2fd051ad19e76ff7b142a0faf329336f9a62a514/attrs-18.2.Setting up fonts-noto-mono (20171026-2) ...Extracting templates from packages: 21% Not uninstalling pillow at /usr/lib/python3/dist-packages, outside environment /usrUnpacking python3.6-dev (3.6.7-1~18.04) ...Adding user paperless to group ftpuploadCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/lt.js' Downloading https://files.pythonhosted.org/packages/99/0b/d37a5a96c5d301e23adcabcc2f3fa659fb34e6308590f95ebb50cdbe98a1/djangorestfSelecting previously unselected package libwebp6:amd64. Downloading https://files.pythonhosted.org/packages/f9/6e/31efb8dc1d17052c12f39262223e94038bfcc4cc7a124235630a6d50f166/pytest-env-Unpacking proftpd-basic (1.3.5e-1build1) ...Setting up libnss3:amd64 (2:3.35-2ubuntu2.1) ...Preparing to unpack .../39-libalgorithm-merge-perl_0.08-3_all.deb ...Setting up libxvidcore4:amd64 (2:1.3.5-1) ... 100% |████████████████████████████████| 122kB 3.8MB/s Preparing to unpack .../107-libmagickcore-6.q16-3-extra_8%3a6.9.7.4+dfsg-16ubuntu6.4_amd64.deb ...Unpacking libpoppler-dev:amd64 (0.62.0-2ubuntu2.5) ... 99% |████████████████████████████████| 225kB 6.1MB/s eta 0:00:01 Setting up netpbm (2:10.0-15.3build1) ...2.6.0-py2.py3-none-any.whlSetting up libavahi-client3:amd64 (0.7-3.1ubuntu1.1) ...0-cp36-cp36m-manylinux1_x86_64.whl (2.0MB)Collecting backcall==0.1.0 (from -r requirements.txt (line 7))Adding new user `paperless' (1000) with group `paperless' ...2% [4 fontconfig 2613 B/169 kB 2%] Get:77 http://archive.ubuntu.com/ubuntu bionic/main amd64 libwebpmux3 amd64 0.6.1-2 [19.6 kB] 46% [Waiting for headers] 4081 kB/s 12sEnabling module env. 6% |██ | 204kB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/xregexp/LICENSE-XREGEXP.txt'92% [18 Packages store 0 B] update-alternatives: using /usr/bin/stream-im6.q16 to provide /usr/bin/stream-im6 (stream-im6) in auto mode 88% |████████████████████████████▍ | 7.2MB 5.9MB/s eta 0:00:01 Creating home directory `/srv/ftp' ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/glyphicons-halflings-regular.eot'Setting up libcups2:amd64 (2.2.7-1ubuntu2.3) ...Collecting text-unidecode==1.2 (from -r requirements.txt (line 73)) Applying auth.0009_alter_user_last_name_max_length... OKGet:27 http://archive.ubuntu.com/ubuntu bionic/main amd64 libjbig2dec0 amd64 0.13-6 [55.9 kB]2% [Waiting for headers] Setting up python-pip-whl (9.0.1-2.3~ubuntu1) ...Preparing to unpack .../131-python3-olefile_0.45.1-1_all.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/actions.js' Running setup.py bdist_wheel for pyocr ... \Selecting previously unselected package apache2-bin.t-1.24.0-py2.py3-none-any.whlSelecting previously unselected package libcroco3:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/jquery/jquery.min.js'Selecting previously unselected package libpaper-utils.Preparing to unpack .../005-libjpeg-turbo8_1.5.2-0ubuntu5.18.04.1_amd64.deb ...66% [43 libpython3.6-dev 19.2 MB/44.8 MB 43%] 4611 kB/s 6sCollecting filelock==3.0.10 (from -r requirements.txt (line 25)) Running setup.py bdist_wheel for langdetect ... /Reading package lists... Done 100% |████████████████████████████████| 122kB 3.6MB/s Selecting previously unselected package libdrm-intel1:amd64.Get:52 http://archive.ubuntu.com/ubuntu bionic/main amd64 libopus0 amd64 1.1.2-1ubuntu1 [159 kB]Preparing to unpack .../14-libatomic1_8.2.0-1ubuntu2~18.04_amd64.deb ... 13% |████▏ | 1.1MB 4.1MB/s eta 0:00:02 Get:11 http://archive.ubuntu.com/ubuntu bionic/main amd64 ssl-cert all 1.0.39 [17.0 kB]Setting up liblsan0:amd64 (8.2.0-1ubuntu2~18.04) ...Preparing to unpack .../054-libgdk-pixbuf2.0-0_2.36.11-2_amd64.deb ...Receiving objects: 5% (279/5570) Selecting previously unselected package g++-7.Unpacking libpython3.6-dev:amd64 (3.6.7-1~18.04) ...Preparing to unpack .../10-cpp-7_7.3.0-27ubuntu1~18.04_amd64.deb ... 41% |█████████████▍ | 1.3MB 6.0MB/s eta 0:00:01 Applying documents.0009_auto_20160214_0040... OKSelecting previously unselected package imagemagick-6.q16.Preparing to unpack .../libmemcachedutil2_1.0.18-4.2_amd64.deb ...Unpacking libwavpack1:amd64 (5.1.0-2ubuntu1.2) ... Downloading https://files.pythonhosted.org/packages/6e/fe/6e5b43eac75c617cd9383ce82dd76d08fa198a770b06986951b3086980c9/pytest_djan 28% |█████████▎ | 2.1MB 5.7MB/s eta 0:00:01 Get:10 http://archive.ubuntu.com/ubuntu bionic/universe Sources [9051 kB] Suggested packages: 10% |███▍ | 860kB 3.7MB/s eta 0:00:02 Get:32 http://archive.ubuntu.com/ubuntu bionic/main amd64 gsfonts all 1:8.11+urwcyr1.0.7~pre44-4.4 [3120 kB]Selecting previously unselected package libpangoft2-1.0-0:amd64.81% [Waiting for headers] 4630 kB/s 2s16% [Waiting for headers] 13% |████▍ | 972kB 5.8MB/s eta 0:00:02 33% [Working] Preparing to unpack .../21-libquadmath0_8.2.0-1ubuntu2~18.04_amd64.deb ...Setting up fontconfig (2.12.6-0ubuntu2) ... * Full K8s GPU support is now available!Collecting pygments==2.2.0 (from -r requirements.txt (line 51))Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/vendor/select2/select2.css' 80% |█████████████████████████▋ | 614kB 5.9MB/s eta 0:00:01 Collecting pluggy==0.8.0 (from -r requirements.txt (line 45))Receiving objects: 43% (2396/5570), 4.67 MiB | 3.10 MiB/s Setting up libmemcachedutil2:amd64 (1.0.18-4.2) ...Preparing to unpack .../021-libavahi-common3_0.7-3.1ubuntu1.1_amd64.deb ... 74% |████████████████████████ | 2.0MB 6.0MB/s eta 0:00:01 Preparing to unpack .../08-apache2_2.4.29-1ubuntu4.5_amd64.deb ... 21% |███████ | 215kB 5.2MB/s eta 0:00:01 Get:101 http://archive.ubuntu.com/ubuntu bionic/main amd64 libgdk-pixbuf2.0-bin amd64 2.36.11-2 [7864 B] Get:5 http://archive.ubuntu.com/ubuntu bionic/main amd64 liblua5.2-0 amd64 5.2.4-1.1build1 [108 kB]Unpacking apache2-bin (2.4.29-1ubuntu4.5) ...Receiving objects: 82% (4568/5570), 4.67 MiB | 3.10 MiB/s -py2.py3-none-any.whl79% [18 Packages store 0 B] [19 Translation-en 1119 kB/4941 kB 23%] Downloading https://files.pythonhosted.org/packages/93/d6/abcb22de61d78e2fc3959c964628a5771e47e7cc60d53e9342e21ed6cc9a/traitlets-4Selecting previously unselected package libavahi-client3:amd64.Selecting previously unselected package libvorbisfile3:amd64.Collecting atomicwrites==1.2.1 (from -r requirements.txt (line 4))29% [Waiting for headers] Setting up gsfonts (1:8.11+urwcyr1.0.7~pre44-4.4) ...go-3.4.3-py2.py3-none-any.whl Running setup.py bdist_wheel for langdetect ... -Selecting previously unselected package gcc.(Reading database ... 32033 files and directories currently installed.)Setting up libdpkg-perl (1.19.0.5ubuntu2.1) ... Applying documents.0005_auto_20160123_0313... OK99% [29 Translation-en store 0 B] 4229 kB/s 0supdate-alternatives: using /usr/bin/mogrify-im6.q16 to provide /usr/bin/mogrify (mogrify) in auto modeSetting up libxcb-dri2-0:amd64 (1.13-1) ...Setting up libavahi-common3:amd64 (0.7-3.1ubuntu1.1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/img/grid.png'Setting up libx265-146:amd64 (2.6-3) ... Downloading https://files.pythonhosted.org/packages/62/94/5430ebaa83f91cc7a9f687ff5238e26164a779cca2ef9903232268b0a318/Pillow-5.3.bms@FortBoyard:~$ exit 34% |███████████ | 174kB 5.9MB/s eta 0:00:01 Get:12 http://archive.ubuntu.com/ubuntu bionic/main amd64 liblqr-1-0 amd64 0.4.2-2.1 [27.7 kB]Preparing to unpack .../061-libpangoft2-1.0-0_1.40.14-1ubuntu0.1_amd64.deb ...Get:66 http://archive.ubuntu.com/ubuntu bionic/main amd64 libsnappy1v5 amd64 1.1.7-1 [16.0 kB] libmemcached11 libmemcachedutil2 proftpd-docUnpacking python3-venv (3.6.7-1~18.04) ... Applying documents.0008_document_file_type... OKUnpacking libdrm-radeon1:amd64 (2.4.91-2) ...98% [138 unpaper 2613 B/242 kB 1%] 4630 kB/s 0sGet:4 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [74.6 kB] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/zh-CN.js'Preparing to unpack .../09-libmpc3_1.1.0-1_amd64.deb ...44% [34 python3-distutils 2613 B/141 kB 2%] 4081 kB/s 12sConnecting to raw.githubusercontent.com (raw.githubusercontent.com)|151.101.16.133|:443... connected.Processing triggers for libc-bin (2.27-3ubuntu1) ...Preparing to unpack .../24-gcc_4%3a7.3.0-3ubuntu2.1_amd64.deb ...Get:14 http://archive.ubuntu.com/ubuntu bionic/main amd64 libtiff5 amd64 4.0.9-5 [152 kB]Selecting previously unselected package libtesseract4.update-alternatives: using /usr/bin/montage-im6.q16 to provide /usr/bin/montage (montage) in auto modePreparing to unpack .../090-libavformat57_7%3a3.4.4-0ubuntu0.18.04.1_amd64.deb ...Get:86 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libgme0 amd64 0.6.2-1 [121 kB] Unpacking mesa-vdpau-drivers:amd64 (18.0.5-0ubuntu0~18.04.1) ...21% [Waiting for headers] Selecting previously unselected package python3.6-venv.Selecting previously unselected package libaprutil1-ldap:amd64. Downloading https://files.pythonhosted.org/packages/d1/29/605c2cc68a9992d18dada28206eeada56ea4bd07a239669da41674648b6f/ptyprocess- 10% |███▎ | 204kB 5.9MB/s eta 0:00:01 98% |███████████████████████████████▍| 174kB 6.0MB/s eta 0:00:01 Preparing to unpack .../136-tesseract-ocr_4.00~git2288-10f4998a-2_amd64.deb ...33% [Waiting for headers] Preparing to unpack .../05-linux-libc-dev_4.15.0-43.46_amd64.deb ... 56% |██████████████████ | 4.5MB 5.9MB/s eta 0:00:01 Extracting templates from packages: 100%Setting up libapr1:amd64 (1.6.3-2) ...Successfully installed alabaster-0.7.12 apipkg-1.5 atomicwrites-1.2.1 attrs-18.2.0 babel-2.6.0 backcall-0.1.0 certifi-2018.10.15 cov Downloading https://files.pythonhosted.org/packages/30/0a/1b009b525526cd3cd9f52f52391b426c5a3597447be811a10bcb1f6b05eb/pytest_cov-Preparing to unpack .../008-libjbig0_2.1-3.1build1_amd64.deb ...17% [Waiting for headers] Get:8 http://archive.ubuntu.com/ubuntu bionic/multiverse Sources [181 kB] Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/fontawesome-webfont.svg'Preparing to unpack .../044-libxcb-shm0_1.13-1_amd64.deb ...Welcome to Ubuntu 18.04.1 LTS (GNU/Linux 4.15.0-43-generic x86_64) - https://bit.ly/microk8s.tar.gz Downloading https://files.pythonhosted.org/packages/8c/da/b8dd8deb741bff556db53902d4706774c8e1e67265f69528c14c003644e6/gunicorn-19Get:52 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-keyrings.alt all 3.0-1 [16.6 kB] Get:79 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libx265-146 amd64 2.6-3 [1026 kB] Preparing to unpack .../46-python3-crypto_2.6.1-8ubuntu2_amd64.deb ...Preparing to unpack .../092-libcupsfilters1_1.20.2-0ubuntu3_amd64.deb ...2% [5 fonts-droid-fallback 2611 B/1805 kB 0%] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/xregexp/xregexp.min.js' 49% |████████████████ | 4.0MB 6.0MB/s eta 0:00:01 Copying files from `/etc/skel' ...Selecting previously unselected package libpangocairo-1.0-0:amd64.update-alternatives: using /usr/bin/g++ to provide /usr/bin/c++ (c++) in auto modeUnpacking libbinutils:amd64 (2.30-21ubuntu1~18.04) ...Setting up python3-pyocr (0.3.0-1) ... 58% |██████████████████▉ | 1.8MB 5.9MB/s eta 0:00:01 Get:13 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcc1-0 amd64 8.2.0-1ubuntu2~18.04 [39.5 kB]Preparing to unpack .../115-libpoppler-cpp-dev_0.62.0-2ubuntu2.5_amd64.deb ... 9% |███▏ | 92kB 5.8MB/s eta 0:00:01 Unpacking libzvbi-common (0.2.35-13) ...Selecting previously unselected package libva-drm2:amd64.Unpacking fonts-noto-mono (20171026-2) ...Collecting execnet==1.5.0 (from -r requirements.txt (line 22))13% [11 cpp-7 2873 kB/6738 kB 43%] 87% |████████████████████████████ | 7.1MB 5.8MB/s eta 0:00:01 Downloading https://files.pythonhosted.org/packages/79/42/d717cc2b4520fb09e45b344b1b0b4e81aa672001dd128c180fabc655c341/text_unidec5% [6 libjpeg-turbo8 2613 B/110 kB 2%] libcupsfilters1 libcupsimage2 libdatrie1 libdjvulibre-text libdjvulibre21 libdrm-amdgpu1 libdrm-intel1 libdrm-nouveau237% [Waiting for headers] Preparing to unpack .../080-libzvbi-common_0.2.35-13_all.deb ...93% [18 Packages store 0 B] Get:6 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libjpeg-turbo8 amd64 1.5.2-0ubuntu5.18.04.1 [110 kB]Selecting previously unselected package libbluray2:amd64.Selecting previously unselected package librsvg2-2:amd64.8% [Working] 97% [Working] 4944 kB/s 0sSelecting previously unselected package libapr1:amd64.Selecting previously unselected package python3-pip.py2.py3-none-any.whlCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/eu.js'Get:105 http://archive.ubuntu.com/ubuntu bionic/main amd64 libllvm6.0 amd64 1:6.0-1ubuntu2 [14.5 MB] Selecting previously unselected package liblqr-1-0:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/responsive_rtl.css' 55% |█████████████████▊ | 4.0MB 6.0MB/s eta 0:00:01 Preparing to unpack .../096-libpciaccess0_0.14-1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/img/glyphicons-halflings-white.png' 44% |██████████████▍ | 3.6MB 5.4MB/s eta 0:00:01 libdrm-radeon1 libfftw3-double3 libfontconfig1 libgdk-pixbuf2.0-0 libgdk-pixbuf2.0-bin libgdk-pixbuf2.0-common libgif7 libgme0Get:103 http://archive.ubuntu.com/ubuntu bionic/main amd64 libilmbase12 amd64 2.2.0-11ubuntu2 [71.4 kB] 50% [84 libbluray2 2613 B/141 kB 2%] 3755 kB/s 9sGet:10 http://archive.ubuntu.com/ubuntu bionic/main amd64 libjpeg8 amd64 8c-2ubuntu8 [2194 B] Processes: 393update-alternatives: using /usr/bin/conjure-im6.q16 to provide /usr/bin/conjure (conjure) in auto modeSetting up libgme0:amd64 (0.6.2-1) ...Get:34 http://archive.ubuntu.com/ubuntu bionic-backports/universe Translation-en [1604 B]Preparing to unpack .../112-libpoppler73_0.62.0-2ubuntu2.5_amd64.deb ...Collecting regex==2018.11.2 (from -r requirements.txt (line 66))Processing triggers for man-db (2.8.3-2ubuntu0.1) ...Enabling module authz_host. Applying documents.0003_sender... OK99% [28 Packages store 0 B] 4229 kB/s 0sRunning migrations:Get:80 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libxvidcore4 amd64 2:1.3.5-1 [200 kB] Preparing to unpack .../125-libxcb-xfixes0_1.13-1_amd64.deb ...Unpacking libaprutil1:amd64 (1.6.1-2) ...77% [107 libwmf0.2-7 2613 B/150 kB 2%] 3755 kB/s 3sSelecting previously unselected package tesseract-ocr.Unpacking libogg0:amd64 (1.3.2-1) ...Get:46 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 python-pip-whl all 9.0.1-2.3~ubuntu1 [1652 kB] Unpacking libijs-0.35:amd64 (0.35-13) ...Collecting python-dotenv==0.9.1 (from -r requirements.txt (line 62)) automake libtool flex bison gdb gcc-doc gcc-7-multilib libgcc1-dbg libgomp1-dbg libitm1-dbg libatomic1-dbg libasan4-dbgt, python-dotenv, python-gnupg, snowballstemmer, sphinxcontrib-websupport, sphinx, toml, virtualenv, tox46% [Working] 4081 kB/s 12sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/collapse.js'58% [105 libllvm6.0 1162 B/14.5 MB 0%] 3755 kB/s 7sPreparing to unpack .../37-libalgorithm-diff-perl_1.19.03-1_all.deb ...Get:18 http://archive.ubuntu.com/ubuntu bionic/main amd64 libogg0 amd64 1.3.2-1 [17.2 kB]update-alternatives: using /usr/bin/compare-im6.q16 to provide /usr/bin/compare-im6 (compare-im6) in auto modeSetting up libzvbi0:amd64 (0.2.35-13) ...Setting up imagemagick (8:6.9.7.4+dfsg-16ubuntu6.4) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/gis/move_vertex_on.svg'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/jquery/LICENSE-JQUERY.txt'Get:3 http://archive.ubuntu.com/ubuntu bionic/main amd64 libaprutil1-dbd-sqlite3 amd64 1.6.1-2 [10.6 kB]90% [Waiting for headers] 4630 kB/s 1sUnpacking libubsan0:amd64 (7.3.0-27ubuntu1~18.04) ... 76% |████████████████████████▌ | 1.5MB 12.4MB/s eta 0:00:01 Unpacking va-driver-all:amd64 (2.1.0-3) ...-py2.py3-none-any.whl (766kB)Unpacking g++-7 (7.3.0-27ubuntu1~18.04) ...al python-levenshtein Downloading https://files.pythonhosted.org/packages/89/d1/92e6df2e503a69df9faab187c684585f0136662c12bb1f36901d426f3fab/packaging-1 Downloading https://files.pythonhosted.org/packages/e5/b4/c6102d9dea6a4cbc5a56ebe5843c3123e5013c17a4f2f0f6d490d821766e/regex-2018.Successfully built backcall docopt filemagic inotify-simple langdetect pdftotext pyocr pytest-env pytest-sugar regex termcolor tzlocUnpacking gcc-7 (7.3.0-27ubuntu1~18.04) ... 84% |███████████████████████████▏ | 6.0MB 5.8MB/s eta 0:00:01 31% |██████████▏ | 2.6MB 4.0MB/s eta 0:00:02 92% [Working] 4630 kB/s 1s43% [Waiting for headers] 4081 kB/s 12sEnabling module autoindex. 48% |███████████████▋ | 3.5MB 6.0MB/s eta 0:00:01 95% [48 python3.6-dev 2613 B/508 kB 1%] 4944 kB/s 0s 98% |███████████████████████████████▋| 757kB 6.2MB/s eta 0:00:01 84% [Working] 4630 kB/s 2s44% [Working] 4081 kB/s 12sPreparing to unpack .../024-libcupsimage2_2.2.7-1ubuntu2.3_amd64.deb ...Unpacking liblua5.2-0:amd64 (5.2.4-1.1build1) ...1% [3 binutils-x86-64-linux-gnu 2611 B/1855 kB 0%] Unpacking gcc (4:7.3.0-3ubuntu2.1) ...Copying '/home/paperless/paperless/src/documents/static/js/colours.js'47% [41 libexpat1-dev 4061 B/122 kB 3%] 4081 kB/s 12sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ar.js'Preparing to unpack .../033-imagemagick-6.q16_8%3a6.9.7.4+dfsg-16ubuntu6.4_amd64.deb ...Email address: Selecting previously unselected package libalgorithm-diff-xs-perl. 99% |███████████████████████████████▉| 1.9MB 5.9MB/s eta 0:00:01 Selecting previously unselected package libtheora0:amd64. 100% |████████████████████████████████| 645kB 1.3MB/s Downloading https://files.pythonhosted.org/packages/7e/9f/526a6947247599b084ee5232e4f9190a38f398d7300d866af3ab571a5bfe/wcwidth-0.1Setting up libcroco3:amd64 (0.6.12-2) ...Get:54 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-setuptools all 39.0.1-2 [248 kB] Running setup.py bdist_wheel for backcall ... doneSelecting previously unselected package libcupsfilters1:amd64. www-browser apache2-doc apache2-suexec-pristine | apache2-suexec-custom openssl-blacklist.0 tox-3.5.3 traitlets-4.3.2 tzlocal-1.5.1 urllib3-1.24.1 virtualenv-16.1.0 wcwidth-0.1.7Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/uk.js'Selecting previously unselected package libxcb-sync1:amd64.update-alternatives: using /usr/bin/import-im6.q16 to provide /usr/bin/import-im6 (import-im6) in auto modeSelecting previously unselected package binutils-x86-64-linux-gnu.97% [18 Packages store 0 B] Found existing installation: urllib3 1.228.10.15-py2.py3-none-any.whl (146kB)Preparing to unpack .../067-libsoxr0_0.1.2-3_amd64.deb ...Preparing to unpack .../01-libbinutils_2.30-21ubuntu1~18.04_amd64.deb ... 69% |██████████████████████▏ | 5.6MB 5.9MB/s eta 0:00:01 Preparing to unpack .../027-libpaper1_1.1.24+nmu5ubuntu1_amd64.deb ... Downloading https://files.pythonhosted.org/packages/42/a9/d1785c85ebf9b7dfacd08938dd028209c34a0ea3b1bcdb895208bd40a67d/python-Leve Swap usage: 0% IP address for virbr0: 192.168.122.1Preparing to unpack .../088-libopenmpt0_0.3.6-1_amd64.deb ...Collecting pdftotext==2.1.1 (from -r requirements.txt (line 41))17% [Waiting for headers] Downloading https://files.pythonhosted.org/packages/7a/1a/9bd24a185873b998611c2d8d4fb15cd5e8a879ead36355df7ee53e9111bf/jedi-0.13.1 Stored in directory: /root/.cache/pip/wheels/ae/1c/56/c27dc42b329eaf83222ba4f14c084489427e591a385b2209dc21% [Working] Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/jquery-3.3.1.min.js'74% [43 libpython3.6-dev 27.7 MB/44.8 MB 62%] 4611 kB/s 4s Downloading https://files.pythonhosted.org/packages/cc/7e/83ba784ad2b95317bbbed915f0888d7d1cd8dc3d2e4b8ddec8fbc4c3e800/django_corsSelecting previously unselected package libdrm-amdgpu1:amd64.Enabling module auth_basic.167 static files copied to '/home/paperless/paperless/static'. libsoxr0 libspeex1 libssh-gcrypt-4 libswresample2 libtesseract4 libthai-data libthai0 libtheora0 libtiff5 libtwolame0 libva-drm2 66% |█████████████████████▍ | 4.8MB 5.2MB/s eta 0:00:01 Get:3 http://archive.ubuntu.com/ubuntu bionic/universe amd64 proftpd-basic amd64 1.3.5e-1build1 [2015 kB]Unpacking libmagickwand-6.q16-3:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ...Setting up libllvm6.0:amd64 (1:6.0-1ubuntu2) ...Get:1 http://archive.ubuntu.com/ubuntu bionic/main amd64 libmemcached11 amd64 1.0.18-4.2 [83.3 kB] Applying admin.0002_logentry_remove_auto_add... OKPreparing to unpack .../libmemcached11_1.0.18-4.2_amd64.deb ...Setting up libwebpdemux2:amd64 (0.6.1-2) ...2.py3-none-any.whl (58kB)Get:75 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libwavpack1 amd64 5.1.0-2ubuntu1.2 [76.5 kB] 73% [10 Sources store 0 B] [18 Packages 7883 kB/8570 kB 92%] 35% |███████████▍ | 706kB 5.2MB/s eta 0:00:01 Preparing to unpack .../45-python-pip-whl_9.0.1-2.3~ubuntu1_all.deb ...Selecting previously unselected package imagemagick-6-common.90% [18 Packages store 0 B] Setting up libmp3lame0:amd64 (3.100-2) ...94% [18 Packages store 0 B] Get:19 http://archive.ubuntu.com/ubuntu bionic/universe Translation-en [4941 kB]Preparing to unpack .../128-mesa-vdpau-drivers_18.0.5-0ubuntu0~18.04.1_amd64.deb ... 72% |███████████████████████▎ | 727kB 6.0MB/s eta 0:00:01 Setting up proftpd-basic (1.3.5e-1build1) ...Receiving objects: 29% (1616/5570), 2.15 MiB | 2.14 MiB/s Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/prettify-min.js' 63% |████████████████████▍ | 5.2MB 6.0MB/s eta 0:00:01 er-2.0.0-py3-none-any.whl (69kB)Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/cancel.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sv.js'Selecting previously unselected package gcc-7.90% [45 manpages-dev 4059 B/2217 kB 0%] 4611 kB/s 1s89% [43 libpython3.6-dev 43.9 MB/44.8 MB 98%] 4611 kB/s 1s 100% |████████████████████████████████| 512kB 1.7MB/s 99% |████████████████████████████████| 542kB 6.7MB/s eta 0:00:01 Copying '/home/paperless/paperless/src/documents/static/documents/img/png.png' Running setup.py bdist_wheel for inotify-simple ... - 82% |██████████████████████████▎ | 2.2MB 5.9MB/s eta 0:00:01 14% |████▊ | 112kB 6.4MB/s eta 0:00:01 r-0.9.1.tar.gz14% [29 libgs9-common 2611 B/5094 kB 0%] libxcb-xfixes0 libxfixes3 libxrender1 libxshmfence1 libxvidcore4 libzvbi-common libzvbi0 mesa-va-drivers mesa-vdpau-driversupdate-alternatives: using /usr/bin/display-im6.q16 to provide /usr/bin/display (display) in auto mode Running setup.py bdist_wheel for langdetect ... |Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/default.css'Unpacking libxfixes3:amd64 (1:5.0.3-1) ...91% [Waiting for headers] 4630 kB/s 1s 75% |████████████████████████▏ | 409kB 5.2MB/s eta 0:00:01 15% [11 cpp-7 5431 kB/6738 kB 81%]Preparing to unpack .../081-libzvbi0_0.2.35-13_amd64.deb ... 100% |████████████████████████████████| 71kB 3.6MB/s Selecting previously unselected package libzvbi0:amd64.Selecting previously unselected package libcairo2:amd64.Unpacking libthai-data (0.1.27-2) ...72% [105 libllvm6.0 11.5 MB/14.5 MB 79%] 3755 kB/s 4s 18% |█████▉ | 153kB 5.2MB/s eta 0:00:01 94% [18 Packages store 0 B] [28 Packages 1595 B/711 kB 0%] Preparing to unpack .../137-unpaper_6.1-2_amd64.deb ...Last login: Sun Jan 20 19:46:40 2019 from 192.168.1.136.6.tar.gzSetting up libubsan0:amd64 (7.3.0-27ubuntu1~18.04) ...Get:48 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libcrystalhd3 amd64 1:0.0~git20110715.fdd2f19-12 [45.8 kB] 93% |██████████████████████████████ | 2.9MB 5.7MB/s eta 0:00:01 -py2.py3-none-any.whl (88kB)0% [1 libapr1 2614 B/90.9 kB 3%] 60% |███████████████████▎ | 215kB 5.2MB/s eta 0:00:01 Collecting babel==2.6.0 (from -r requirements.txt (line 6))Get:9 http://archive.ubuntu.com/ubuntu bionic/main amd64 libisl19 amd64 0.19-1 [551 kB] | fonts-ipafont-gothic fonts-arphic-ukai fonts-arphic-uming fonts-nanum python-pil-doc python3-pil-dbg libvdpau-va-gl1Setting up cpp (4:7.3.0-3ubuntu2.1) ...Get:51 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libopenjp2-7 amd64 2.3.0-1 [145 kB]Selecting previously unselected package libmemcachedutil2:amd64. Running setup.py bdist_wheel for regex ... /Get:119 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libtesseract4 amd64 4.00~git2288-10f4998a-2 [1163 kB] 79% [Waiting for headers] 4630 kB/s 2sSelecting previously unselected package libaprutil1-dbd-sqlite3:amd64. 85% |███████████████████████████▌ | 307kB 5.9MB/s eta 0:00:01 Selecting previously unselected package libavahi-common-data:amd64.Get:44 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpython3-dev amd64 3.6.7-1~18.04 [7328 B] Selecting previously unselected package libjbig0:amd64. 27% |████████▊ | 2.2MB 5.2MB/s eta 0:00:02 Selecting previously unselected package libxcb-dri2-0:amd64. Applying reminders.0002_auto_20181007_1420... OK36% [Working] Get:30 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgs9 amd64 9.26~dfsg+0-0ubuntu0.18.04.3 [2263 kB]Unpacking libdjvulibre21:amd64 (3.5.27.1-8) ...34% [Waiting for headers] 65% |█████████████████████ | 5.3MB 5.9MB/s eta 0:00:01 libmagickwand-6.q16-3 libmp3lame0 libmpg123-0 libnetpbm10 libnspr4 libnss3 libogg0 libopenexr22 libopenjp2-7 libopenmpt0Selecting previously unselected package python3-pil:amd64. 22% |███████▎ | 706kB 5.7MB/s eta 0:00:01 25% [12 Translation-en store 0 B] [10 Sources 1717 kB/9051 kB 19%] [Waiting for headers] Running setup.py bdist_wheel for pdftotext ... doneUnpacking libdrm-intel1:amd64 (2.4.91-2) ...Preparing to unpack .../06-libc6-dev_2.27-3ubuntu1_amd64.deb ...Enabling module setenvif.91% [18 Packages store 0 B] 56% [102 libgif7 2615 B/30.6 kB 9%] 3755 kB/s 8sUnpacking libwebpmux3:amd64 (0.6.1-2) ...Receiving objects: 27% (1504/5570), 2.15 MiB | 2.14 MiB/s Not uninstalling idna at /usr/lib/python3/dist-packages, outside environment /usrUnpacking liblept5 (1.75.3-3) ... Stored in directory: /root/.cache/pip/wheels/97/3e/62/04d426143d73ee23cb6bc1cabc52563c452889a43f71d32338Unpacking build-essential (12.4ubuntu1) ...Get:49 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libgsm1 amd64 1.0.13-4build1 [22.4 kB]31% [24 gcc-7 7325 kB/7455 kB 98%]13% [Waiting for headers] Connecting to raw.githubusercontent.com (raw.githubusercontent.com)|151.101.16.133|:443... Running setup.py bdist_wheel for python-levenshtein ... |97% [18 Packages store 0 B] 99% [Waiting for headers] 4944 kB/s 0s 22% |███████▏ | 604kB 6.0MB/s eta 0:00:01 0% [Working] Receiving objects: 24% (1337/5570), 2.15 MiB | 2.14 MiB/s 33% [Waiting for headers] 4081 kB/s 14s 89% |████████████████████████████▌ | 6.3MB 6.0MB/s eta 0:00:01 Setting up libgdk-pixbuf2.0-bin (2.36.11-2) ... 86% |███████████████████████████▋ | 6.1MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libsoxr0:amd64.Preparing to unpack .../000-fonts-dejavu-core_2.37-1_all.deb ...Collecting pycodestyle==2.4.0 (from -r requirements.txt (line 50))Preparing to unpack .../26-g++-7_7.3.0-27ubuntu1~18.04_amd64.deb ... 31% |██████████▎ | 614kB 6.0MB/s eta 0:00:01 Setting up libdjvulibre-text (3.5.27.1-8) ...Processing triggers for systemd (237-3ubuntu10.11) ...Get:49 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 python3-dev amd64 3.6.7-1~18.04 [1288 B] Selecting previously unselected package python3-keyring. Downloading https://files.pythonhosted.org/packages/a2/12/ced7105d2de62fa7c8fb5fce92cc4ce66b57c95fb875e9318dba7f8c5db0/toml-0.10.0Preparing to unpack .../073-libvpx5_1.7.0-3_amd64.deb ...Building wheels for collected packages: backcall, docopt, filemagic, inotify-simple, langdetect, pdftotext, pyocr, pytest-env, pytes7% [Waiting for headers] Unpacking libssh-gcrypt-4:amd64 (0.8.0~20170825.94fa1e38-1ubuntu0.2) ...Unpacking gsfonts (1:8.11+urwcyr1.0.7~pre44-4.4) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/tr.js'Need to get 64.4 MB of archives.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/calendar-icons.svg'Copying '/home/paperless/paperless/src/paperless/static/paperless/img/favicon.ico'Enabling module authn_file. 38% |████████████▍ | 2.8MB 5.9MB/s eta 0:00:01 Preparing to unpack .../15-libasan4_7.3.0-27ubuntu1~18.04_amd64.deb ...Get:27 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 g++-7 amd64 7.3.0-27ubuntu1~18.04 [7570 kB] 33% |██████████▊ | 901kB 5.2MB/s eta 0:00:01 Collecting py==1.7.0 (from -r requirements.txt (line 49))20% [Waiting for headers] 99% |████████████████████████████████| 921kB 6.0MB/s eta 0:00:01 Selecting previously unselected package proftpd-basic.Selecting previously unselected package imagemagick. 4% |█▎ | 286kB 5.9MB/s eta 0:00:02 Downloading https://files.pythonhosted.org/packages/62/00/ee1d7de624db8ba7090d1226aebefab96a2c71cd5cfa7629d6ad3f61b79e/urllib3-1.2 Downloading https://files.pythonhosted.org/packages/ac/9e/1aa87c0c59f9731820bfd20a8b148d97b315530c2c92d1fb300328c8c42f/dateparser-Selecting previously unselected package make.Collecting pexpect==4.6.0 (from -r requirements.txt (line 42)) 16% |█████▎ | 512kB 5.8MB/s eta 0:00:01 31% |██████████▏ | 2.3MB 5.9MB/s eta 0:00:01 Get:32 http://archive.ubuntu.com/ubuntu bionic/main amd64 build-essential amd64 12.4ubuntu1 [4758 B] 42% [30 libdpkg-perl 2613 B/211 kB 1%] 4081 kB/s 12s9.2 filelock-3.0.10 filemagic-1.6 fuzzywuzzy-0.15.0 gunicorn-19.9.0 idna-2.7 imagesize-1.1.0 inotify-simple-1.1.8 ipython-7.1.1 ipyt2.py3-none-any.whl (83kB)Selecting previously unselected package libatomic1:amd64.Preparing to unpack .../087-libvorbisfile3_1.3.5-4.2_amd64.deb ...Selecting previously unselected package optipng. Downloading https://files.pythonhosted.org/packages/f1/ca/10332a30cb25b627192b4ea272c351bce3ca1091e541245cccbace6051d8/requests-2.Collecting traitlets==4.3.2 (from -r requirements.txt (line 76))34% [56 libthai-data 2613 B/133 kB 2%] Installing collected packages: alabaster, apipkg, atomicwrites, attrs, pytz, babel, backcall, certifi, coverage, idna, urllib3, requGet:55 http://archive.ubuntu.com/ubuntu bionic/main amd64 libgdk-pixbuf2.0-0 amd64 2.36.11-2 [165 kB]Unpacking libthai0:amd64 (0.1.27-2) ...Preparing to unpack .../133-python3-pyocr_0.3.0-1_all.deb ...Fetched 85.2 MB in 19s (4415 kB/s) libpoppler-cpp-dev libpoppler-cpp0v5 libpoppler-dev libpoppler73 librsvg2-2 librsvg2-common libsensors4 libshine3 libsnappy1v5Get:23 http://archive.ubuntu.com/ubuntu bionic-updates/multiverse Sources [3820 B]Preparing to unpack .../099-libdrm-radeon1_2.4.91-2_amd64.deb ...Preparing to unpack .../30-dpkg-dev_1.19.0.5ubuntu2.1_all.deb ...Unpacking libalgorithm-merge-perl (0.08-3) ...0% [1 InRelease gpgv 242 kB] [3 InRelease 28.7 kB/88.7 kB 32%] 41% |█████████████▎ | 317kB 5.9MB/s eta 0:00:01 Selecting previously unselected package libnss3:amd64.Selecting previously unselected package ghostscript.Unpacking libspeex1:amd64 (1.2~rc1.2-1ubuntu2) ...Get:5 http://archive.ubuntu.com/ubuntu bionic/main Sources [829 kB]Copying '/home/paperless/paperless/src/documents/static/documents/img/pdf.png'Get:132 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-olefile all 0.45.1-1 [33.3 kB] 97% [22 Sources store 0 B] 4229 kB/s 0sSelecting previously unselected package libmemcached11:amd64.Preparing to unpack .../124-libxcb-sync1_1.13-1_amd64.deb ... libssh-gcrypt-4 libswresample2 libtesseract4 libthai-data libthai0 libtheora0 libtiff5 libtwolame0 libva-drm2 libva-x11-2 libva20 upgraded, 4 newly installed, 0 to remove and 19 not upgraded..7-py2.py3-none-any.whl 0% |▏ | 30kB 6.7MB/s eta 0:00:02 90% [Working] 4611 kB/s 1s Downloading https://files.pythonhosted.org/packages/9a/05/6bad05742d185ec2fabfa4deab05cafde286eb3f383fba24b3674340aca2/django_crisPreparing to unpack .../056-libdatrie1_0.2.10-7_amd64.deb ...Get:25 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcupsimage2 amd64 2.2.7-1ubuntu2.3 [18.6 kB]Preparing to unpack .../070-libtwolame0_0.3.13-3_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-no.svg'Unpacking libcupsimage2:amd64 (2.2.7-1ubuntu2.3) ...10% [11 cpp-7 4059 B/6738 kB 0%] Selecting previously unselected package libwebpmux3:amd64.Preparing to unpack .../10-ssl-cert_1.0.39_all.deb ... 7% |██▌ | 204kB 5.8MB/s eta 0:00:01 libjpeg8 liblcms2-2 liblept5 libllvm6.0 liblqr-1-0 libltdl7 libmagickcore-6.q16-3 libmagickcore-6.q16-3-extra 46% |██████████████▊ | 3.7MB 5.9MB/s eta 0:00:01 Unpacking libjbig0:amd64 (2.1-3.1build1) ...Selecting previously unselected package libogg0:amd64.rvice.Selecting previously unselected package libxshmfence1:amd64. Running setup.py bdist_wheel for filemagic ... -Hit:1 http://archive.ubuntu.com/ubuntu bionic InReleasePassword (again): Get:29 http://archive.ubuntu.com/ubuntu bionic/main amd64 make amd64 4.1-9.1ubuntu1 [154 kB] Get:25 http://archive.ubuntu.com/ubuntu bionic-updates/universe Sources [122 kB]100% [Waiting for headers] 4630 kB/s 0sEnabling module reqtimeout.100% [Waiting for headers] 4944 kB/s 0s 83% |██████████████████████████▊ | 5.9MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libfile-fcntllock-perl.Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/ajax-form.js' 97% |███████████████████████████████▎| 81kB 5.4MB/s eta 0:00:01 Selecting previously unselected package libtwolame0:amd64.Collecting factory-boy==2.11.1 (from -r requirements.txt (line 23))26% [10 Sources 1908 kB/9051 kB 21%] [13 Packages 2687 B/113 kB 2%] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/rtl.css'Preparing to unpack .../012-libltdl7_2.4.6-2_amd64.deb ...98% [27 Translation-en store 0 B] 4229 kB/s 0sSetting up libx264-152:amd64 (2:0.152.2854+gite9a5903-2) ...5% [Working] 97% |███████████████████████████████▎| 3.0MB 6.0MB/s eta 0:00:01 10% [17 libmagickwand-6.q16-3 1165 B/293 kB 0%] Preparing to unpack .../032-hicolor-icon-theme_0.17-2_all.deb ...Get:15 http://security.ubuntu.com/ubuntu bionic-security/multiverse amd64 Packages [1444 B]Selecting previously unselected package libstdc++-7-dev:amd64.14% [Waiting for headers] Unpacking libfakeroot:amd64 (1.22-2ubuntu1) ...Setting up libpixman-1-0:amd64 (0.34.0-2) ... 95% |██████████████████████████████▌ | 112kB 6.4MB/s eta 0:00:01 Collecting pytest-sugar==0.9.1 (from -r requirements.txt (line 58))Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/de.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/core.js'Get:31 http://archive.ubuntu.com/ubuntu bionic-updates/multiverse Translation-en [3356 B] fontconfig fontconfig-config fonts-dejavu-core fonts-droid-fallback fonts-noto-mono ghostscript gsfonts hicolor-icon-themeUnpacking cpp-7 (7.3.0-27ubuntu1~18.04) ...Get:109 http://archive.ubuntu.com/ubuntu bionic/main amd64 libnetpbm10 amd64 2:10.0-15.3build1 [58.0 kB] 81% [Working] 4630 kB/s 2s37% [Waiting for headers] 28% [10 Sources 2366 kB/9051 kB 26%] [14 Translation-en 2689 B/64.2 kB 4%] 26% |████████▍ | 1.9MB 5.8MB/s eta 0:00:01 ests, docopt, coveralls, tzlocal, regex, python-dateutil, dateparser, decorator, django-cors-headers, django-crispy-forms, django-exGet:25 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 gcc amd64 4:7.3.0-3ubuntu2.1 [5184 B] 99% |████████████████████████████████| 2.7MB 5.6MB/s eta 0:00:01 0% [5 Sources store 0 B] [3 InRelease gpgv 88.7 kB] [Waiting for headers] 3% |█▏ | 286kB 1.6MB/s eta 0:00:05 Setting up libapache2-mod-wsgi-py3 (4.5.17-1) ...Selecting previously unselected package libva2:amd64.Get:43 http://archive.ubuntu.com/ubuntu bionic/main amd64 libpixman-1-0 amd64 0.34.0-2 [229 kB]Setting up libalgorithm-merge-perl (0.08-3) ...Preparing to unpack .../031-gsfonts_1%3a8.11+urwcyr1.0.7~pre44-4.4_all.deb ...Selecting previously unselected package binutils-common:amd64.Unpacking libllvm6.0:amd64 (1:6.0-1ubuntu2) ...Get:17 http://archive.ubuntu.com/ubuntu bionic/restricted Sources [5324 B]Setting up libcrystalhd3:amd64 (1:0.0~git20110715.fdd2f19-12) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/font-awesome-4.0.3.css'8.0-py2.py3-none-any.whl 56% |██████████████████▎ | 1.1MB 33.1MB/s eta 0:00:01 Unpacking librsvg2-common:amd64 (2.40.20-2) ...Setting up linux-libc-dev:amd64 (4.15.0-43.46) ...Setting up libalgorithm-diff-perl (1.19.03-1) ...Unpacking python3-lib2to3 (3.6.7-1~18.04) ...Retype new UNIX password: 11.02.tar.gz (644kB) 70% |██████████████████████▋ | 5.7MB 5.8MB/s eta 0:00:01 Setting up libmagickcore-6.q16-3-extra:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ... 42% |█████████████▌ | 389kB 5.9MB/s eta 0:00:01 35% [Working] 92% |█████████████████████████████▋ | 706kB 5.2MB/s eta 0:00:01 2% [Waiting for headers] Unpacking poppler-data (0.4.8-2) ...Receiving objects: 11% (613/5570) 99% [Working] 4944 kB/s 0sUnpacking libxcb-dri2-0:amd64 (1.13-1) ...87% [18 Packages store 0 B] [19 Translation-en 3930 kB/4941 kB 80%]Unpacking libcilkrts5:amd64 (7.3.0-27ubuntu1~18.04) ...36% [64 librsvg2-2 2614 B/98.6 kB 3%] 94% |██████████████████████████████▏ | 942kB 6.0MB/s eta 0:00:01 To activate the new configuration, you need to run:98% [26 Packages store 0 B] 4229 kB/s 0sUnpacking libgomp1:amd64 (8.2.0-1ubuntu2~18.04) ... 40% |████████████▉ | 3.3MB 5.8MB/s eta 0:00:01 Setting up binutils-x86-64-linux-gnu (2.30-21ubuntu1~18.04) ...Preparing to unpack .../109-libnspr4_2%3a4.18-1ubuntu1_amd64.deb ...Get:2 http://security.ubuntu.com/ubuntu bionic-security InRelease [83.2 kB]Unpacking python3-keyrings.alt (3.0-1) ...Get:134 http://archive.ubuntu.com/ubuntu bionic/universe amd64 python3-pyocr all 0.3.0-1 [11.8 kB] librsvg2-bin lm-sensors speex libwmf0.2-7-gtk poppler-utils fonts-japanese-mincho | fonts-ipafont-mincho fonts-japanese-gothic 100% |████████████████████████████████| 358kB 2.0MB/s 77% |████████████████████████▉ | 5.5MB 6.0MB/s eta 0:00:01 Preparing to unpack .../040-libvdpau1_1.1.1-3ubuntu1_amd64.deb ...Selecting previously unselected package python3-dev.Setting up libdrm-amdgpu1:amd64 (2.4.91-2) ...Selecting previously unselected package dh-python. 41% |█████████████▎ | 3.0MB 5.8MB/s eta 0:00:01 100% |████████████████████████████████| 184kB 3.1MB/s Unpacking libpoppler73:amd64 (0.62.0-2ubuntu2.5) ...Get:2 http://archive.ubuntu.com/ubuntu bionic/main amd64 fontconfig-config all 2.12.6-0ubuntu2 [55.8 kB]Get:2 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libbinutils amd64 2.30-21ubuntu1~18.04 [502 kB]Preparing to unpack .../104-libllvm6.0_1%3a6.0-1ubuntu2_amd64.deb ... 1% |▎ | 81kB 2.2MB/s eta 0:00:04 Selecting previously unselected package libfontconfig1:amd64.Get:64 http://archive.ubuntu.com/ubuntu bionic/main amd64 librsvg2-2 amd64 2.40.20-2 [98.6 kB] 69% |██████████████████████▎ | 4.9MB 5.9MB/s eta 0:00:01 Enabling module alias.Selecting previously unselected package libssh-gcrypt-4:amd64.1% [2 libbinutils 2613 B/502 kB 1%] Email address: Unpacking libpangocairo-1.0-0:amd64 (1.40.14-1ubuntu0.1) ... Running setup.py bdist_wheel for python-levenshtein ... - 4% |█▍ | 112kB 6.5MB/s eta 0:00:01 bms@pingu:~$ exit 41% [Waiting for headers] 4081 kB/s 12sSelecting previously unselected package python3-setuptools.Preparing to unpack .../42-libpython3.6-dev_3.6.7-1~18.04_amd64.deb ...31% [Waiting for headers] 36% [27 g++-7 2816 kB/7570 kB 37%] 4081 kB/s 13sSelecting previously unselected package python3-keyrings.alt.Setting up libquadmath0:amd64 (8.2.0-1ubuntu2~18.04) ...Get:32 http://archive.ubuntu.com/ubuntu bionic-backports/universe Sources [2068 B]Unpacking libmemcached11:amd64 (1.0.18-4.2) ...Get:26 http://archive.ubuntu.com/ubuntu bionic/main amd64 libijs-0.35 amd64 0.35-13 [15.5 kB](Reading database ... 15%Get:13 http://security.ubuntu.com/ubuntu bionic-security/universe amd64 Packages [113 kB] 8% |██▉ | 716kB 2.8MB/s eta 0:00:03 Selecting previously unselected package libxcb-dri3-0:amd64.Unpacking libgdk-pixbuf2.0-0:amd64 (2.36.11-2) ...0% [5 Sources store 0 B] [3 InRelease gpgv 88.7 kB] [Waiting for headers] Get:3 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 binutils-x86-64-linux-gnu amd64 2.30-21ubuntu1~18.04 [1855 kB]42% [Waiting for headers] 4081 kB/s 12s Applying documents.0015_add_insensitive_to_match... OKCopying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/js/jquery.json-view.min.js' Applying documents.0019_add_consumer_user... OKPreparing to unpack .../27-g++_4%3a7.3.0-3ubuntu2.1_amd64.deb ...Set ftpupload password: * Management: https://landscape.canonical.comUnpacking mesa-va-drivers:amd64 (18.0.5-0ubuntu0~18.04.1) ...97% [136 tesseract-ocr-osd 2747 kB/2989 kB 92%] 4630 kB/s 0sSetting up python3-pip (9.0.1-2.3~ubuntu1) ... 14% |████▋ | 92kB 5.9MB/s eta 0:00:01 Get:59 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpango-1.0-0 amd64 1.40.14-1ubuntu0.1 [153 kB] Running setup.py bdist_wheel for pyocr ... - libpoppler-cpp0v5 libpoppler-dev libpoppler73 librsvg2-2 librsvg2-common libsensors4 libshine3 libsnappy1v5 libsoxr0 libspeex1 43% |█████████████▊ | 3.1MB 6.0MB/s eta 0:00:01 Setting up libbinutils:amd64 (2.30-21ubuntu1~18.04) ... 34% |███████████ | 2.8MB 5.9MB/s eta 0:00:01 26% [24 gcc-7 2540 kB/7455 kB 34%] 32% [Working] 93% [46 python-pip-whl 2611 B/1652 kB 0%] 4611 kB/s 0s 29% |█████████▌ | 798kB 5.9MB/s eta 0:00:01 Setting up libisl19:amd64 (0.19-1) ...Collecting termcolor==1.1.0 (from -r requirements.txt (line 72))Selecting previously unselected package libmagickwand-6.q16-3:amd64.(Reading database ... 28583 files and directories currently installed.) Stored in directory: /root/.cache/pip/wheels/ec/0c/a9/1647275e7ef5014e7b83ff30105180e332867d65e7617ddafe Applying reminders.0001_initial... OK Not uninstalling requests at /usr/lib/python3/dist-packages, outside environment /usrPreparing to unpack .../118-libtesseract4_4.00~git2288-10f4998a-2_amd64.deb ...5% [8 libfftw3-double3 4061 B/735 kB 1%] 40% |█████████████ | 798kB 5.8MB/s eta 0:00:01 Collecting wcwidth==0.1.7 (from -r requirements.txt (line 80)) Stored in directory: /root/.cache/pip/wheels/ff/94/8e/dccadc6bce17c41a9dbb0c7ccd44acdb9dcc0edd9efa42eaf6 Stored in directory: /root/.cache/pip/wheels/11/5d/7e/f325d21ffec71263368df56a2af6ab3c802e0e869abd4b3c03 6% |██▏ | 552kB 3.0MB/s eta 0:00:03 9% [Waiting for headers] Unpacking linux-libc-dev:amd64 (4.15.0-43.46) ... 100% |████████████████████████████████| 81kB 3.9MB/s Preparing to unpack .../44-manpages-dev_4.15-1_all.deb ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/js/highlight.pack.js' Applying admin.0001_initial... OKUnpacking libvorbisfile3:amd64 (1.3.5-4.2) ...Selecting previously unselected package ssl-cert.Get:23 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgcc-7-dev amd64 7.3.0-27ubuntu1~18.04 [2380 kB]55% [Working] 3755 kB/s 8sSetting up libvorbisenc2:amd64 (1.3.5-4.2) ... System information as of Sun Jan 20 19:49:47 GMT 2019Get:106 http://archive.ubuntu.com/ubuntu bionic/main amd64 libopenexr22 amd64 2.2.0-11.1ubuntu1 [560 kB] 16% |█████▎ | 1.2MB 5.9MB/s eta 0:00:02 Preparing to unpack .../135-tesseract-ocr-osd_4.00~git24-0e00fe6-1.2_all.deb ... 19% |██████▏ | 1.4MB 5.8MB/s eta 0:00:01 0% [1 InRelease gpgv 242 kB] [Waiting for headers] 98% [Waiting for headers] 4944 kB/s 0s Downloading https://files.pythonhosted.org/packages/71/e8/6777f6624681c8b9701a8a0a5654f3eb56919a01a78e12bf3c73f5a3c714/pyparsing-291% [18 Packages store 0 B] 3-py2.py3-none-any.whl (214kB)Copying '/home/paperless/paperless/src/paperless/static/paperless/img/logo-dark.png' Downloading https://files.pythonhosted.org/packages/67/08/4815a09603fc800209431bec5b8bd2acf2f95abdfb558a44a42507fb94da/apipkg-1.5-update-alternatives: using /usr/bin/composite-im6.q16 to provide /usr/bin/composite-im6 (composite-im6) in auto modeGet:24 http://archive.ubuntu.com/ubuntu bionic-updates/restricted Sources [2064 B]remote: Counting objects: 100% (21/21), done. Receiving objects: 8% (446/5570) Apply all migrations: admin, auth, contenttypes, documents, reminders, sessionsPreparing to unpack .../089-libssh-gcrypt-4_0.8.0~20170825.94fa1e38-1ubuntu0.2_amd64.deb ... grads graphviz hp2xx html2ps libwmf-bin mplayer povray radiance sane-utils texlive-base-bin transfig ufraw-batch xdg-utilsPreparing to unpack .../052-libcroco3_0.6.12-2_amd64.deb ... 9% |███▏ | 307kB 5.8MB/s eta 0:00:01 7% [Waiting for headers] 38% |████████████▍ | 1.2MB 5.8MB/s eta 0:00:01 28% |█████████ | 2.3MB 6.0MB/s eta 0:00:01 Setting up libfakeroot:amd64 (1.22-2ubuntu1) ...56% [104 liblept5 4061 B/929 kB 0%] 3755 kB/s 8s 42% |█████████████▌ | 419kB 5.9MB/s eta 0:00:01 91% [18 Packages store 0 B] [22 Sources 2687 B/231 kB 1%] Processing triggers for mime-support (3.60ubuntu1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/km.js'Preparing to unpack .../41-libfile-fcntllock-perl_0.22-3build2_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-unknown-alt.svg' 62% |████████████████████▏ | 92kB 5.5MB/s eta 0:00:01 kit-2.0.7-py3-none-any.whl (338kB)Preparing to unpack .../13-libitm1_8.2.0-1ubuntu2~18.04_amd64.deb ...Note, selecting 'proftpd-basic' instead of 'proftpd'87% [129 mesa-vdpau-drivers 4059 B/1902 kB 0%] 4630 kB/s 2sbms@pingu:~$ lxc launch ubuntu: paperless Get:90 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libssh-gcrypt-4 amd64 0.8.0~20170825.94fa1e38-1ubuntu0.2 [171 kB]Selecting previously unselected package libpaper1:amd64.Collecting pillow==5.3.0 (from -r requirements.txt (line 44)) Downloading https://files.pythonhosted.org/packages/24/3d/977140bd94bfb160f98a5c02fdfbb72325130f12a325cf993182956e9d0e/python_doteSelecting previously unselected package liblcms2-2:amd64. 47% |███████████████▏ | 3.8MB 5.8MB/s eta 0:00:01 Preparing to unpack .../48-python3-dev_3.6.7-1~18.04_amd64.deb ... 30% |█████████▋ | 194kB 5.9MB/s eta 0:00:01 61% |███████████████████▋ | 4.4MB 5.9MB/s eta 0:00:01 Get:127 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxshmfence1 amd64 1.3-1 [5028 B] Applying auth.0006_require_contenttypes_0002... OK 4% |█▍ | 358kB 2.9MB/s eta 0:00:03 Setting up libva-drm2:amd64 (2.1.0-3) ...Building dependency tree 0 updates are security updates. 54% |█████████████████▌ | 419kB 5.8MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pt-BR.js'Selecting previously unselected package libopus0:amd64.Preparing to unpack .../063-librsvg2-2_2.40.20-2_amd64.deb ... 49% |███████████████▉ | 1.3MB 5.8MB/s eta 0:00:01 Selecting previously unselected package libgif7:amd64. Downloading https://files.pythonhosted.org/packages/37/54/2d169a102a3727f3ebe535da9263babb88a5862516ae9a798a7e458399a6/pyocr-0.5.3Get:33 http://archive.ubuntu.com/ubuntu bionic-backports/universe amd64 Packages [3472 B]remote: Enumerating objects: 21, done. Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/fonts/Roboto-Bold-webfont.woff'Unpacking libgif7:amd64 (5.1.4-2) ... 35% |███████████▎ | 2.9MB 5.9MB/s eta 0:00:01 99% |████████████████████████████████| 7.1MB 39.8MB/s eta 0:00:01 5% |█▉ | 112kB 6.5MB/s eta 0:00:01 Collecting python-dateutil==2.7.5 (from -r requirements.txt (line 61))Preparing to unpack .../33-python3-distutils_3.6.7-1~18.04_all.deb ... Applying documents.0007_auto_20160126_2114... OKUnpacking libc6-dev:amd64 (2.27-3ubuntu1) ...Get:70 http://archive.ubuntu.com/ubuntu bionic/main amd64 libtheora0 amd64 1.1.1+dfsg.1-14 [170 kB] 2% |▊ | 174kB 771kB/s eta 0:00:11 Selecting previously unselected package gsfonts.19% [Waiting for headers] Unpacking libopenjp2-7:amd64 (2.3.0-1) ...29% [Waiting for headers] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/prepopulate.min.js'Setting up apache2-utils (2.4.29-1ubuntu4.5) ...Selecting previously unselected package libcrystalhd3:amd64. 99% |████████████████████████████████| 8.1MB 6.0MB/s eta 0:00:01 Running setup.py bdist_wheel for filemagic ... doneGet:30 http://archive.ubuntu.com/ubuntu bionic-updates/multiverse amd64 Packages [6376 B] 60% |███████████████████▍ | 1.2MB 5.1MB/s eta 0:00:01 Get:16 http://security.ubuntu.com/ubuntu bionic-security/multiverse Translation-en [996 B] 100% |████████████████████████████████| 92kB 3.8MB/s 96% |██████████████████████████████▉ | 890kB 5.2MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/admin/DateTimeShortcuts.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-unknown.svg'Selecting previously unselected package librsvg2-common:amd64.Collecting idna==2.7 (from -r requirements.txt (line 29)) 100% |████████████████████████████████| 71kB 4.2MB/s .3.0-py2.py3-none-any.whlSetting up libogg0:amd64 (1.3.2-1) ... 37% |████████████ | 317kB 6.7MB/s eta 0:00:01 Unpacking libwmf0.2-7:amd64 (0.2.8.4-12) ...Get:87 http://archive.ubuntu.com/ubuntu bionic/main amd64 libmpg123-0 amd64 1.25.10-1 [125 kB] Unpacking binutils-common:amd64 (2.30-21ubuntu1~18.04) ...Starting paperlessUnpacking libavformat57:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Setting up libva2:amd64 (2.1.0-3) ...Selecting previously unselected package libdrm-nouveau2:amd64.Collecting django-crispy-forms==1.7.2 (from -r requirements.txt (line 15))Selecting previously unselected package libvdpau1:amd64. 53% |█████████████████▎ | 3.8MB 6.0MB/s eta 0:00:01 .3.2-py2.py3-none-any.whl (74kB)Setting up binutils (2.30-21ubuntu1~18.04) ...31% [43 libpixman-1-0 2613 B/229 kB 1%] Downloading https://files.pythonhosted.org/packages/35/e0/e9e83b244eaa382ba21896dda6172617e47aff0be225eb72782cca105d3c/Sphinx-1.8.Get:39 http://archive.ubuntu.com/ubuntu bionic/main amd64 libalgorithm-diff-xs-perl amd64 0.04-5 [11.1 kB] 33% [27 g++-7 2611 B/7570 kB 0%] 4081 kB/s 14s0-py2.py3-none-any.whlPreparing to unpack .../022-libavahi-client3_0.7-3.1ubuntu1.1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-changelink.svg'Selecting previously unselected package libpciaccess0:amd64.35% [Waiting for headers] Collecting parso==0.3.1 (from -r requirements.txt (line 40))Unpacking libaprutil1-ldap:amd64 (1.6.1-2) ...Preparing to unpack .../56-python3-wheel_0.30.0-0.2_all.deb ... Applying documents.0014_document_checksum... OKGet:69 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libswresample2 amd64 7:3.4.4-0ubuntu0.18.04.1 [55.2 kB].3.0-py2.py3-none-any.whl (59kB)Enter new UNIX password: Setting up apache2-bin (2.4.29-1ubuntu4.5) ... libxcb-sync1 libxcb-xfixes0 libxfixes3 libxrender1 libxshmfence1 libxvidcore4 libzvbi-common libzvbi0 mesa-va-driversSetting up libc6-dev:amd64 (2.27-3ubuntu1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/prettify.css' 79% |█████████████████████████▎ | 6.4MB 5.8MB/s eta 0:00:01 90% |█████████████████████████████ | 307kB 5.8MB/s eta 0:00:01 10% [Waiting for headers] 92% |█████████████████████████████▌ | 71kB 5.9MB/s eta 0:00:01 .1.1.tar.gz (112kB)Unpacking libswresample2:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...36% [Waiting for headers] Applying documents.0001_initial... OK 35% |███████████▌ | 194kB 5.9MB/s eta 0:00:01 Unpacking gcc-7-base:amd64 (7.3.0-27ubuntu1~18.04) ... 29% |█████████▍ | 2.4MB 5.0MB/s eta 0:00:02 Selecting previously unselected package libvpx5:amd64.Collecting langdetect==1.0.7 (from -r requirements.txt (line 36))Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pt.js'Get:45 http://archive.ubuntu.com/ubuntu bionic/main amd64 manpages-dev all 4.15-1 [2217 kB] Unpacking libavutil55:amd64 (7:3.4.4-0ubuntu0.18.04.1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/is.js'Get:22 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libquadmath0 amd64 8.2.0-1ubuntu2~18.04 [133 kB]Setting up libvpx5:amd64 (1.7.0-3) ...Receiving objects: 22% (1226/5570), 676.01 KiB | 1.30 MiB/s Setting up libitm1:amd64 (8.2.0-1ubuntu2~18.04) ...84% [43 libpython3.6-dev 38.4 MB/44.8 MB 86%] 4611 kB/s 2s18% [16 libasan4 2613 B/358 kB 1%] Setting up libstdc++-7-dev:amd64 (7.3.0-27ubuntu1~18.04) ...Get:108 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libmagickcore-6.q16-3-extra amd64 8:6.9.7.4+dfsg-16ubuntu6.4 [62.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/tooltag-arrowright.svg'95% [Waiting for headers] 4611 kB/s 0sGet:57 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdatrie1 amd64 0.2.10-7 [17.8 kB]Get:115 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpoppler-dev amd64 0.62.0-2ubuntu2.5 [4616 B] Unpacking libfftw3-double3:amd64 (3.3.7-1) ...Adding user `ftpupload' ...Setting up libnetpbm10 (2:10.0-15.3build1) ...ode-1.2-py2.py3-none-any.whl (77kB)Preparing to unpack .../34-dh-python_3.20180325ubuntu2_all.deb ...Setting up python3-setuptools (39.0.1-2) ...Setting up libcilkrts5:amd64 (7.3.0-27ubuntu1~18.04) ...psycopg/docs/install.html#binary-install-from-pypi>.Selecting previously unselected package libwebpdemux2:amd64.(Reading database ... 35% 17% |█████▊ | 1.3MB 6.0MB/s eta 0:00:01 Setting up libgsm1:amd64 (1.0.13-4build1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/calendar.js'Get:33 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 python3-lib2to3 all 3.6.7-1~18.04 [76.5 kB] i965-va-driver imagemagick imagemagick-6-common imagemagick-6.q16 libaacs0 libavahi-client3 libavahi-common-data 58% |██████████████████▊ | 4.2MB 5.8MB/s eta 0:00:01 1% |▍ | 81kB 5.1MB/s eta 0:00:02 t-sugar, regex, termcolor, tzlocal, python-levenshteinGet:28 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 g++ amd64 4:7.3.0-3ubuntu2.1 [1572 B] 6% [Waiting for headers] 12% |████ | 1.0MB 3.5MB/s eta 0:00:03 Downloading https://files.pythonhosted.org/packages/74/68/d87d9b36af36f44254a8d512cbfc48369103a3b9e474be9bdfe536abfc45/python_date 45% |██████████████▋ | 3.3MB 5.9MB/s eta 0:00:01 81% [43 libpython3.6-dev 35.6 MB/44.8 MB 79%] 4611 kB/s 3s0.7.0-py2.py3-none-any.whl (357kB)Selecting previously unselected package libwmf0.2-7:amd64.Get:4 http://archive.ubuntu.com/ubuntu bionic/main amd64 libaprutil1-ldap amd64 1.6.1-2 [8764 B] 97% |███████████████████████████████ | 2.6MB 5.9MB/s eta 0:00:01 Setting up cpp-7 (7.3.0-27ubuntu1~18.04) ... 100% |████████████████████████████████| 3.1MB 338kB/s 12% [Working] Downloading https://files.pythonhosted.org/packages/fa/bc/9bd3b5c2b4774d5f33b2d544f1460be9df7df2fe42f352135381c347c69a/ipython_genCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/autocomplete.js'Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/csrf.js'Unpacking libpython3-dev:amd64 (3.6.7-1~18.04) ...30% [Waiting for headers] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/SelectBox.js'Setting up libxcb-dri3-0:amd64 (1.13-1) ...Unpacking cpp (4:7.3.0-3ubuntu2.1) ... 59% |███████████████████ | 4.2MB 6.0MB/s eta 0:00:01 Get:6 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 apache2-bin amd64 2.4.29-1ubuntu4.5 [1071 kB]0% [1 libmemcached11 2614 B/83.3 kB 3%] 40% [Waiting for headers] 3755 kB/s 10s Get:16 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libasan4 amd64 7.3.0-27ubuntu1~18.04 [358 kB]Collecting attrs==18.2.0 (from -r requirements.txt (line 5))Preparing to unpack .../068-libswresample2_7%3a3.4.4-0ubuntu0.18.04.1_amd64.deb ... Running setup.py bdist_wheel for pdftotext ... -77% [110 libnspr4 1165 B/112 kB 1%] 3755 kB/s 3s61% [43 libpython3.6-dev 14.5 MB/44.8 MB 32%] 4081 kB/s 8s 21% |██████▊ | 194kB 6.0MB/s eta 0:00:01 Running setup.py bdist_wheel for python-levenshtein ... /Unpacking hicolor-icon-theme (0.17-2) ... 95% |██████████████████████████████▊ | 194kB 5.9MB/s eta 0:00:01 37% |████████████ | 3.1MB 5.9MB/s eta 0:00:01 Preparing to unpack .../139-va-driver-all_2.1.0-3_amd64.deb ... Downloading https://files.pythonhosted.org/packages/55/80/4bbd33f6d6b305c509a90b37c1cf7255000344f513b36827ec2c17af5ad5/inotify_simupdate-alternatives: using /usr/bin/montage-im6.q16 to provide /usr/bin/montage-im6 (montage-im6) in auto modeSetting up dpkg-dev (1.19.0.5ubuntu2.1) ...3% [Waiting for headers] Found existing installation: Pillow 5.1.0Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/tooltag-add.svg'Selecting previously unselected package fontconfig-config.Setting up libmpg123-0:amd64 (1.25.10-1) ...Preparing to unpack .../134-tesseract-ocr-eng_4.00~git24-0e00fe6-1.2_all.deb ...0% [1 InRelease gpgv 242 kB] Unpacking imagemagick-6.q16 (8:6.9.7.4+dfsg-16ubuntu6.4) ...psycopg2, py, pycodestyle, pyocr, pytest, pytest-cov, pytest-django, pytest-env, pytest-forked, termcolor, pytest-sugar, pytest-xdisSelecting previously unselected package libfftw3-double3:amd64.Collecting python-gnupg==0.4.3 (from -r requirements.txt (line 63))Setting up libvdpau1:amd64 (1.1.1-3ubuntu1) ...Setting up python3-keyring (10.6.0-1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sr.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/forms.css'Preparing to unpack .../028-libgs9-common_9.26~dfsg+0-0ubuntu0.18.04.3_all.deb ...Setting up libvorbis0a:amd64 (1.3.5-4.2) ...Preparing to unpack .../026-libjbig2dec0_0.13-6_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ru.js'17% [Waiting for headers] Selecting previously unselected package libgdk-pixbuf2.0-0:amd64.Selecting previously unselected package libgdk-pixbuf2.0-bin.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/inline-delete.svg'Setting up libbluray2:amd64 (1:1.0.2-3) ...8% [7 libc6-dev 2563 kB/2587 kB 99%] 37% |████████████ | 1.0MB 6.0MB/s eta 0:00:01 74% |███████████████████████▉ | 2.3MB 5.8MB/s eta 0:00:01 17% |█████▌ | 1.4MB 5.1MB/s eta 0:00:02 51% |████████████████▋ | 1.6MB 5.8MB/s eta 0:00:01 Selecting previously unselected package libvorbisenc2:amd64.Unpacking python3-secretstorage (2.3.1-2) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/az.js'bms@FortBoyard:~$ ssh pingu.lan Setting up libcairo2:amd64 (1.15.10-2) ... 92% |█████████████████████████████▋ | 501kB 5.8MB/s eta 0:00:01 Preparing to unpack .../007-libfftw3-double3_3.3.7-1_amd64.deb ...))Unpacking python3-pip (9.0.1-2.3~ubuntu1) ...Reading package lists... 83%35% [Waiting for headers] Unpacking libtiff5:amd64 (4.0.9-5) ...77% [Waiting for headers] 3755 kB/s 3sPreparing to unpack .../077-libx264-152_2%3a0.152.2854+gite9a5903-2_amd64.deb ... 31% |██████████ | 112kB 6.4MB/s eta 0:00:01 Setting up libxcb-shm0:amd64 (1.13-1) ...Get:62 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpangoft2-1.0-0 amd64 1.40.14-1ubuntu0.1 [33.2 kB]Unpacking libopenexr22:amd64 (2.2.0-11.1ubuntu1) ...update-alternatives: using /usr/bin/animate-im6.q16 to provide /usr/bin/animate (animate) in auto modeSelecting previously unselected package libmagickcore-6.q16-3-extra:amd64.Setting up libopenmpt0:amd64 (0.3.6-1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/coreapi-0.1.1.js'Selecting previously unselected package libswresample2:amd64.Get:121 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libx11-xcb1 amd64 2:1.6.4-3ubuntu0.1 [9560 B] Unpacking libtsan0:amd64 (8.2.0-1ubuntu2~18.04) ...Preparing to unpack .../086-libmpg123-0_1.25.10-1_amd64.deb ...Get:57 http://archive.ubuntu.com/ubuntu bionic/universe amd64 python3-wheel all 0.30.0-0.2 [36.5 kB] 97% [18 Packages store 0 B] Running setup.py bdist_wheel for docopt ... doneCollecting gunicorn==19.9.0 (from -r requirements.txt (line 28)) Running setup.py bdist_wheel for regex ... - 22% |███████▎ | 1.8MB 5.6MB/s eta 0:00:02 41% [Working] 4081 kB/s 12sbms@FortBoyard:~$ Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/css/base.css'bms@FortBoyard:~$ e bms@pingu:~$ lxc exec paperless -- sh -c "wget https://raw.githubusercontent.com/bmsleight/paperless/master/scripts/lxc/lxc-install.21% [8 Sources store 0 B] [10 Sources 686 kB/9051 kB 8%] [11 Packages 134 kB/242 kB 56%] 50% [Waiting for headers] 3755 kB/s 9s 75% |████████████████████████▏ | 6.1MB 5.8MB/s eta 0:00:01 Get:140 http://archive.ubuntu.com/ubuntu bionic/universe amd64 va-driver-all amd64 2.1.0-3 [4376 B] 50% [86 libgme0 1165 B/121 kB 1%] 3755 kB/s 8s37% [Waiting for headers] 56% |██████████████████ | 1.5MB 6.0MB/s eta 0:00:01 Requirement already satisfied: setuptools>=18.5 in /usr/lib/python3/dist-packages (from ipython==7.1.1->-r requirements.txt (line 33ed-0.2-py2.py3-none-any.whl18% [Waiting for headers] Enabling conf charset.Get:31 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 dpkg-dev all 1.19.0.5ubuntu2.1 [608 kB] 36% [Waiting for headers] Retype new UNIX password: 9% [9 libisl19 2613 B/551 kB 0%] openbsd-inetd | inet-superserver proftpd-mod-ldap proftpd-mod-mysql proftpd-mod-odbc proftpd-mod-pgsql proftpd-mod-sqlitePreparing to unpack .../52-python3-pip_9.0.1-2.3~ubuntu1_all.deb ...Password (again): 0% [5 Sources store 0 B] [3 InRelease gpgv 88.7 kB] [8 Sources 2687 B/181 kB 1%] gnupg is already the newest version (2.2.4-1ubuntu1.2).Get:21 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libmpx2 amd64 8.2.0-1ubuntu2~18.04 [11.7 kB]Unpacking libgdk-pixbuf2.0-bin (2.36.11-2) ... libmemcached11 libmemcachedutil2 proftpd-basic proftpd-docSelecting previously unselected package libgme0:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/change_form.js'.0-py2.py3-none-any.whlSetting up libthai-data (0.1.27-2) ...Setting up libdrm-nouveau2:amd64 (2.4.91-2) ...Setting up imagemagick-6.q16 (8:6.9.7.4+dfsg-16ubuntu6.4) ... 55% |█████████████████▊ | 1.7MB 6.0MB/s eta 0:00:01 Get:138 http://archive.ubuntu.com/ubuntu bionic/universe amd64 unpaper amd64 6.1-2 [242 kB] Cloning into 'paperless'...Selecting previously unselected package libavformat57:amd64.Setting up libwavpack1:amd64 (5.1.0-2ubuntu1.2) ...Unpacking libnspr4:amd64 (2:4.18-1ubuntu1) ...bms@pingu:~$ # Run the install script48% [43 libpython3.6-dev 4057 B/44.8 MB 0%] 4081 kB/s 12sg-0.4.3-py2.py3-none-any.whlReceiving objects: 4% (223/5570) 20% |██████▋ | 399kB 5.9MB/s eta 0:00:01 Usage of /: 2.9% of 2.68TB IP address for br0: 192.168.1.22744% [Waiting for headers] 3755 kB/s 10sSelecting previously unselected package libc-dev-bin. 63% |████████████████████▍ | 4.5MB 6.0MB/s eta 0:00:01 Processing triggers for libgdk-pixbuf2.0-0:amd64 (2.36.11-2) ... 27% |████████▉ | 2.0MB 6.0MB/s eta 0:00:01 Preparing to unpack .../11-cpp_4%3a7.3.0-3ubuntu2.1_amd64.deb ...Preparing to unpack .../074-libwavpack1_5.1.0-2ubuntu1.2_amd64.deb ...33% [Waiting for headers] Get:5 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-droid-fallback all 1:6.0.1r16-1.1 [1805 kB]0 upgraded, 58 newly installed, 0 to remove and 19 not upgraded.Unpacking libpixman-1-0:amd64 (0.34.0-2) ...Get:24 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcups2 amd64 2.2.7-1ubuntu2.3 [211 kB] Applying documents.0013_auto_20160325_2111... OK Downloading https://files.pythonhosted.org/packages/ef/7a/212184e2e1e7f2e003b0b109c737f69518830d9c4e8d6cd9a33d17ec48f6/django_exte65% [105 libllvm6.0 5753 kB/14.5 MB 40%] 3755 kB/s 6sSelecting previously unselected package libshine3:amd64. Applying auth.0004_alter_user_username_opts... OK-2.11.1-py2.py3-none-any.whl51% [89 libopenmpt0 2613 B/561 kB 0%] 3755 kB/s 8sUnpacking netpbm (2:10.0-15.3build1) ...Collecting pytest-xdist==1.24.0 (from -r requirements.txt (line 59))Get:4 http://archive.ubuntu.com/ubuntu bionic/main amd64 fontconfig amd64 2.12.6-0ubuntu2 [169 kB]Unpacking libtwolame0:amd64 (0.3.13-3) ... 86% |███████████████████████████▊ | 51kB 5.5MB/s eta 0:00:01 Selecting previously unselected package gcc-7-base:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/widgets.css'Setting up g++-7 (7.3.0-27ubuntu1~18.04) ... 100% |████████████████████████████████| 8.1MB 130kB/s 49% [10 Sources store 0 B] [Waiting for headers] 55% |█████████████████▊ | 1.1MB 6.0MB/s eta 0:00:01 13% [Waiting for headers] Unpacking libavahi-common-data:amd64 (0.7-3.1ubuntu1.1) ... Running setup.py bdist_wheel for inotify-simple ... done9% [Waiting for headers] 33% |██████████▋ | 112kB 6.4MB/s eta 0:00:01 Unpacking libcairo2:amd64 (1.15.10-2) ... 62% |████████████████████ | 4.5MB 6.0MB/s eta 0:00:01 100% |████████████████████████████████| 931kB 1.0MB/s 71% |███████████████████████ | 5.8MB 5.9MB/s eta 0:00:01 Get:56 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 python3-venv amd64 3.6.7-1~18.04 [1208 B] 53% |█████████████████▏ | 409kB 5.2MB/s eta 0:00:01 Setting up dh-python (3.20180325ubuntu2) ... 15% |█████▏ | 307kB 5.9MB/s eta 0:00:01 Unpacking libgs9-common (9.26~dfsg+0-0ubuntu0.18.04.3) ... 44% |██████████████▍ | 1.4MB 5.9MB/s eta 0:00:01 Running setup.py bdist_wheel for regex ... \ Applying contenttypes.0002_remove_content_type_name... OKUnpacking python3-olefile (0.45.1-1) ...Copying '/usr/local/lib/python3.6/dist-packages/django_extensions/static/django_extensions/js/jquery.autocomplete.js'56% [103 libilmbase12 2614 B/71.4 kB 4%] 3755 kB/s 8sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/lv.js'Unpacking libapr1:amd64 (1.6.3-2) ... 21% |██████▉ | 1.7MB 4.1MB/s eta 0:00:02 90% |████████████████████████████▉ | 7.3MB 5.9MB/s eta 0:00:01 Get:61 http://archive.ubuntu.com/ubuntu bionic/main amd64 libharfbuzz0b amd64 1.7.2-1ubuntu1 [232 kB] 100% |████████████████████████████████| 51kB 3.4MB/s Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/mk.js'Superuser created successfully.28% [Working] apache2 apache2-bin apache2-data apache2-utils libapache2-mod-wsgi-py3 libapr1 libaprutil1 libaprutil1-dbd-sqlite3Fetched 26.6 MB in 8s (3350 kB/s) 13% [Waiting for headers] tensions, django, django-filter, djangorestframework, docutils, execnet, text-unidecode, faker, factory-boy, filelock, filemagic, pyGet:41 http://archive.ubuntu.com/ubuntu bionic/main amd64 libvdpau1 amd64 1.1.1-3ubuntu1 [25.5 kB] 45% |██████████████▋ | 1.2MB 6.0MB/s eta 0:00:01 Setting up va-driver-all:amd64 (2.1.0-3) ...94% [136 tesseract-ocr-osd 2611 B/2989 kB 0%] 4630 kB/s 0sUnpacking libpaper-utils (1.1.24+nmu5ubuntu1) ...Preparing to unpack .../04-libc-dev-bin_2.27-3ubuntu1_amd64.deb ...Get:58 http://archive.ubuntu.com/ubuntu bionic/main amd64 libthai0 amd64 0.1.27-2 [18.0 kB]Get:136 http://archive.ubuntu.com/ubuntu bionic/universe amd64 tesseract-ocr-osd all 4.00~git24-0e00fe6-1.2 [2989 kB] Preparing to unpack .../060-libharfbuzz0b_1.7.2-1ubuntu1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/js/bootstrap.min.js'Preconfiguring packages ...14-py3-none-any.whl (543kB)Enabling module authz_user.41% [79 libx265-146 2612 B/1026 kB 0%] 3755 kB/s 10supdate-alternatives: using /usr/bin/compare-im6.q16 to provide /usr/bin/compare (compare) in auto mode86% [43 libpython3.6-dev 41.1 MB/44.8 MB 92%] 4611 kB/s 1sGet:48 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 python3.6-dev amd64 3.6.7-1~18.04 [508 kB] 79% [113 libpoppler73 2613 B/800 kB 0%] 4630 kB/s 2sUnpacking libxshmfence1:amd64 (1.3-1) ...61% [105 libllvm6.0 2877 kB/14.5 MB 20%] 3755 kB/s 7s 29% |█████████▍ | 911kB 5.2MB/s eta 0:00:01 35% |███████████▎ | 1.1MB 6.0MB/s eta 0:00:01 Collecting dateparser==0.7.0 (from -r requirements.txt (line 12))Requirement already satisfied: chardet==3.0.4 in /usr/lib/python3/dist-packages (from -r requirements.txt (line 9))Enabling module wsgi.sh && /bin/bash lxc-install.sh"Preparing to unpack .../025-libijs-0.35_0.35-13_amd64.deb ...Get:2 http://archive.ubuntu.com/ubuntu bionic/main amd64 libmemcachedutil2 amd64 1.0.18-4.2 [9528 B]Unpacking libmagickcore-6.q16-3:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ...Reading package lists... 0%ols-4.3.0-py3-none-any.whl (48kB) 90% |████████████████████████████▉ | 6.4MB 5.9MB/s eta 0:00:01 bms@pingu:~$ exitGet:1 http://archive.ubuntu.com/ubuntu bionic/main amd64 libapr1 amd64 1.6.3-2 [90.9 kB]Setting up libfontconfig1:amd64 (2.12.6-0ubuntu2) ...Selecting previously unselected package proftpd-doc.94% [46 python-pip-whl 1587 kB/1652 kB 96%] 4611 kB/s 0sCollecting imagesize==1.1.0 (from -r requirements.txt (line 30))Enabling conf localized-error-pages.Selecting previously unselected package libgdk-pixbuf2.0-common.Selecting previously unselected package tesseract-ocr-osd.Setting up libilmbase12:amd64 (2.2.0-11ubuntu2) ...Receiving objects: 23% (1288/5570), 2.15 MiB | 2.14 MiB/s Preparing to unpack .../034-imagemagick_8%3a6.9.7.4+dfsg-16ubuntu6.4_amd64.deb ...Preparing to unpack .../114-libpoppler-dev_0.62.0-2ubuntu2.5_amd64.deb ...Selecting previously unselected package libx11-xcb1:amd64.Resolving deltas: 100% (3560/3560), done.Preparing to unpack .../029-libgs9_9.26~dfsg+0-0ubuntu0.18.04.3_amd64.deb ...Selecting previously unselected package tesseract-ocr-eng.0% [5 Sources store 0 B] [4 InRelease gpgv 74.6 kB] [10 Sources 126 kB/9051 kB 1%] [11 Packages 1239 B/242 kB 1%] Enter new UNIX password: Receiving objects: 64% (3565/5570), 4.67 MiB | 3.10 MiB/s 38% [Working] 3755 kB/s 11sCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/vendor/select2/select2.min.css'Setting up libva-x11-2:amd64 (2.1.0-3) ...Preparing to unpack .../101-libgif7_5.1.4-2_amd64.deb ...Selecting previously unselected package libfakeroot:amd64.84% [128 mesa-va-drivers 2611 B/1778 kB 0%] 4630 kB/s 2s Downloading https://files.pythonhosted.org/packages/fc/b6/aef66b4c52a6ad6ac18cf6ebc5731ed06d8c9ae4d3b2d9951f261150be67/imagesize-1Preparing to unpack .../55-python3-venv_3.6.7-1~18.04_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/urlify.js'Preparing to unpack .../12-libcc1-0_8.2.0-1ubuntu2~18.04_amd64.deb ...Setting up g++ (4:7.3.0-3ubuntu2.1) ...Copying '/usr/local/lib/python3.6/dist-packages/django_extensions/static/django_extensions/img/indicator.gif'Length: 3054 (3.0K) [text/plain]21% [Waiting for headers] Setting up libpango-1.0-0:amd64 (1.40.14-1ubuntu0.1) ...Unpacking libmpg123-0:amd64 (1.25.10-1) ... - Reduce system reboots and improve kernel security. Activate at: Downloading https://files.pythonhosted.org/packages/f9/76/3343e69a2a1602052f587898934e5fea395d22310d39c07955596597227c/execnet-1.5Collecting django==2.0.9 (from -r requirements.txt (line 18))Enabling module negotiation.1% [Working] Preparing to unpack .../20-libmpx2_8.2.0-1ubuntu2~18.04_amd64.deb ...Setting up libalgorithm-diff-xs-perl (0.04-5) ...1% [Waiting for headers] Unpacking libvdpau1:amd64 (1.1.1-3ubuntu1) ...Selecting previously unselected package libc6-dev:amd64.Requirement already satisfied: six==1.11.0 in /usr/lib/python3/dist-packages (from -r requirements.txt (line 68))Setting up python3.6-venv (3.6.7-1~18.04) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/nl.js'Preparing to unpack .../041-libavutil55_7%3a3.4.4-0ubuntu0.18.04.1_amd64.deb ...ramework-3.9.0-py2.py3-none-any.whl (924kB)Adding system user `proftpd' (UID 111) ...Get:2 http://archive.ubuntu.com/ubuntu bionic/main amd64 libaprutil1 amd64 1.6.1-2 [84.4 kB]41% [78 libx264-152 2613 B/609 kB 0%] 3755 kB/s 10sGet:98 http://archive.ubuntu.com/ubuntu bionic/main amd64 libdrm-intel1 amd64 2.4.91-2 [59.8 kB] Unpacking libnetpbm10 (2:10.0-15.3build1) ...Selecting previously unselected package libharfbuzz0b:amd64.Collecting toml==0.10.0 (from -r requirements.txt (line 74))Preparing to unpack .../23-gcc-7_7.3.0-27ubuntu1~18.04_amd64.deb ... 100% |████████████████████████████████| 51kB 3.2MB/s 0% [2 InRelease gpgv 83.2 kB] [5 Sources 2687 B/829 kB 0%] Unpacking libexpat1-dev:amd64 (2.2.5-3) ...Enabling site 000-default.Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/css/bootstrap.min.css'Unpacking libxcb-sync1:amd64 (1.13-1) ...Setting up fonts-dejavu-core (2.37-1) ...Unpacking proftpd-doc (1.3.5e-1build1) ... Downloading https://files.pythonhosted.org/packages/10/ad/00b090d23a222943eb0eda509720a404f531a439e803f6538f35136cae9e/alabaster-0 44% |██████████████▎ | 286kB 5.9MB/s eta 0:00:01 74% |███████████████████████▊ | 686kB 6.0MB/s eta 0:00:01 53% |█████████████████▏ | 4.3MB 5.9MB/s eta 0:00:01 Unpacking dpkg-dev (1.19.0.5ubuntu2.1) ... Downloading https://files.pythonhosted.org/packages/3d/a0/b12090c40e0b8196b973962ec71c1c541a6c04af58ba5ad85683b3de251a/coverage-4.Preparing to unpack .../098-libdrm-nouveau2_2.4.91-2_amd64.deb ...Preparing to unpack .../103-liblept5_1.75.3-3_amd64.deb ... 63% |████████████████████▎ | 112kB 6.4MB/s eta 0:00:01 Setting up libpython3.6-dev:amd64 (3.6.7-1~18.04) ... 74% |████████████████████████ | 5.3MB 5.8MB/s eta 0:00:01 Preparing to unpack .../100-libgdk-pixbuf2.0-bin_2.36.11-2_amd64.deb ... 37% |████████████ | 2.7MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libasan4:amd64.Setting up libmemcached11:amd64 (1.0.18-4.2) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/responsive.css'30% [10 Sources 2699 kB/9051 kB 30%] [Waiting for headers] Adding new user `proftpd' (UID 111) with group `nogroup' ...Get:124 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-present0 amd64 1.13-1 [5540 B] 40% [76 libwebp6 2613 B/185 kB 1%] 3755 kB/s 10sEnabling module dir.Get:3 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB] Selecting previously unselected package mesa-va-drivers:amd64.Need to get 85.2 MB of archives.Get:63 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpangocairo-1.0-0 amd64 1.40.14-1ubuntu0.1 [20.8 kB]Unpacking libalgorithm-diff-perl (1.19.03-1) ...0% [1 InRelease gpgv 242 kB] [3 InRelease 2602 B/88.7 kB 3%] [2 InRelease 17.1 kB/83.2 kB 21%] 30% [Working] apache2-bin apache2-data apache2-utils libapr1 libaprutil1 libaprutil1-dbd-sqlite3 libaprutil1-ldap liblua5.2-0 ssl-certPreparing to unpack .../062-libpangocairo-1.0-0_1.40.14-1ubuntu0.1_amd64.deb ...Setting up optipng (0.7.6-1.1) ...4.1-py2.py3-none-any.whl (118kB)Unpacking libalgorithm-diff-xs-perl (0.04-5) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sr-Cyrl.js'update-alternatives: using /usr/bin/convert-im6.q16 to provide /usr/bin/convert (convert) in auto mode49% [10 Sources store 0 B] 96% [Working] 4944 kB/s 0sSetting up libcc1-0:amd64 (8.2.0-1ubuntu2~18.04) ... Running setup.py bdist_wheel for langdetect ... \ 77% |████████████████████████▉ | 2.4MB 6.0MB/s eta 0:00:01 Creating paperlessPreparing to unpack .../011-liblqr-1-0_0.4.2-2.1_amd64.deb ...Get:89 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libopenmpt0 amd64 0.3.6-1 [561 kB] Unpacking libcroco3:amd64 (0.6.12-2) ...75% [10 Sources store 0 B] [19 Translation-en 2685 B/4941 kB 0%] Preparing to unpack .../049-libmp3lame0_3.100-2_amd64.deb ...Setting up ghostscript (9.26~dfsg+0-0ubuntu0.18.04.3) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/da.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fr.js'Setting up proftpd-doc (1.3.5e-1build1) ... 68% |█████████████████████▊ | 1.8MB 6.0MB/s eta 0:00:01 Get:91 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libavformat57 amd64 7:3.4.4-0ubuntu0.18.04.1 [949 kB] Unpacking libopenmpt0:amd64 (0.3.6-1) ...Preparing to unpack .../001-fontconfig-config_2.12.6-0ubuntu2_all.deb ...Selecting previously unselected package libchromaprint1:amd64.Get:11 http://security.ubuntu.com/ubuntu bionic-security/main amd64 Packages [242 kB] Unpacking libdpkg-perl (1.19.0.5ubuntu2.1) ...Need to get 3273 kB of archives.Preparing to unpack .../039-libva-x11-2_2.1.0-3_amd64.deb ...Selecting previously unselected package libavcodec57:amd64.Preparing to unpack .../51-python3-keyrings.alt_3.0-1_all.deb ...Selecting previously unselected package libopenmpt0:amd64.ice.28% [34 imagemagick-6.q16 2613 B/423 kB 1%] Preparing to unpack .../04-liblua5.2-0_5.2.4-1.1build1_amd64.deb ...Get:46 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxrender1 amd64 1:0.9.10-1 [18.7 kB] 74% |███████████████████████▊ | 6.0MB 5.8MB/s eta 0:00:01 Setting up libssh-gcrypt-4:amd64 (0.8.0~20170825.94fa1e38-1ubuntu0.2) ...Get:7 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgomp1 amd64 8.2.0-1ubuntu2~18.04 [76.4 kB]After this operation, 7262 kB of additional disk space will be used.Unpacking unpaper (6.1-2) ...13% [24 libcups2 2613 B/211 kB 1%] Collecting coverage==4.5.1 (from -r requirements.txt (line 10)) Applying auth.0008_alter_user_username_max_length... OKGet:55 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 python3.6-venv amd64 3.6.7-1~18.04 [6184 B] Get:34 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 imagemagick-6.q16 amd64 8:6.9.7.4+dfsg-16ubuntu6.4 [423 kB](Reading database ... 0% [3 InRelease gpgv 88.7 kB] [5 Sources 598 kB/829 kB 72%] Not uninstalling attrs at /usr/lib/python3/dist-packages, outside environment /usr 78% |█████████████████████████▏ | 2.1MB 5.8MB/s eta 0:00:01 21% [6 Sources store 0 B] [10 Sources 625 kB/9051 kB 7%] [11 Packages 119 kB/242 kB 49%] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-deletelink.svg'Setting up libaprutil1-ldap:amd64 (1.6.1-2) ... 71% |██████████████████████▉ | 2.2MB 6.0MB/s eta 0:00:01 Get:12 http://security.ubuntu.com/ubuntu bionic-security/main Translation-en [91.6 kB] 8% |██▋ | 583kB 5.9MB/s eta 0:00:02 49% |████████████████ | 419kB 5.8MB/s eta 0:00:01 5% |█▉ | 450kB 2.2MB/s eta 0:00:04 Get:31 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 ghostscript amd64 9.26~dfsg+0-0ubuntu0.18.04.3 [51.8 kB]Get:92 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libbdplus0 amd64 0.1.2-2 [46.6 kB] 76% [43 libpython3.6-dev 30.5 MB/44.8 MB 68%] 4611 kB/s 4s Downloading https://files.pythonhosted.org/packages/8a/48/a76be51647d0eb9f10e2a4511bf3ffb8cc1e6b14e9e4fab46173aa79f981/termcolor-1 Found existing installation: certifi 2018.1.18Unpacking libopus0:amd64 (1.1.2-1ubuntu1) ...sh && /bin/bash lxc-install.sh" 38% |████████████▌ | 3.2MB 5.9MB/s eta 0:00:01 Receiving objects: 32% (1783/5570), 4.67 MiB | 3.10 MiB/s Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/actions.min.js'31% [47 libcairo2 2613 B/580 kB 0%] bms@pingu:~$ lxc launch ubuntu: paperlessSelecting previously unselected package libgs9-common. Downloading https://files.pythonhosted.org/packages/1b/e2/ffb8c1b574f972cf4183b0aac8f16b57f1e3bbe876b31555b107ea3fd009/ipython-7.1Get:38 http://archive.ubuntu.com/ubuntu bionic/main amd64 libalgorithm-diff-perl all 1.19.03-1 [47.6 kB] Downloading https://files.pythonhosted.org/packages/79/b1/eace304ef66bd7d3d8b2f78cc374b73ca03bc53664d78151e9df3b3996cc/more_itertoCollecting packaging==18.0 (from -r requirements.txt (line 39))Setting up libvorbisfile3:amd64 (1.3.5-4.2) ....1.0.tar.gzCopying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/css/highlight.css'Unpacking libpaper1:amd64 (1.1.24+nmu5ubuntu1) ...Collecting python-levenshtein>=0.12; extra == "speedup" (from fuzzywuzzy[speedup]==0.15.0->-r requirements.txt (line 27))Get:8 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 gcc-7-base amd64 7.3.0-27ubuntu1~18.04 [18.9 kB]34% [Waiting for headers] Get:7 http://security.ubuntu.com/ubuntu bionic-security/multiverse Sources [1336 B]The following additional packages will be installed:Password: Copying '/usr/local/lib/python3.6/dist-packages/django_extensions/static/django_extensions/css/jquery.autocomplete.css'19% [17 liblsan0 2613 B/132 kB 2%] Collecting pyocr==0.5.3 (from -r requirements.txt (line 52))Preparing to unpack .../093-libdjvulibre-text_3.5.27.1-8_all.deb ...Get:84 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libbluray2 amd64 1:1.0.2-3 [141 kB] 20% [19 libubsan0 2613 B/126 kB 2%] 36% [61 libharfbuzz0b 2613 B/232 kB 1%] 52% |████████████████▉ | 3.7MB 5.9MB/s eta 0:00:01 Selecting previously unselected package libnspr4:amd64.Unpacking ghostscript (9.26~dfsg+0-0ubuntu0.18.04.3) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/SelectFilter2.js'Selecting previously unselected package fonts-noto-mono.Setting up libgomp1:amd64 (8.2.0-1ubuntu2~18.04) ...Setting up fontconfig-config (2.12.6-0ubuntu2) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/icon-clock.svg'21% [23 libgcc-7-dev 2611 B/2380 kB 0%] Unpacking binutils (2.30-21ubuntu1~18.04) ...Unpacking imagemagick (8:6.9.7.4+dfsg-16ubuntu6.4) ...Unpacking python3-dev (3.6.7-1~18.04) ...Setting up gcc-7 (7.3.0-27ubuntu1~18.04) ... 100% |████████████████████████████████| 849kB 1.1MB/s 11% [19 poppler-data 2611 B/1479 kB 0%] 82% |██████████████████████████▌ | 6.7MB 5.9MB/s eta 0:00:01 python3-secretstorage python3-setuptools python3-wheel python3-xdg python3.6-dev python3.6-venvCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/zh-TW.js' 98% |███████████████████████████████▌| 1.9MB 6.0MB/s eta 0:00:01 Unpacking libjbig2dec0:amd64 (0.13-6) ...43% [Waiting for headers] 3755 kB/s 10s Downloading https://files.pythonhosted.org/packages/8f/67/a1aedccc143597eea90e79134d14c7364e90174d31443e14674919716d87/filemagic-187 packages can be updated.share-0.7.5 pillow-5.3.0 pluggy-0.8.0 prompt-toolkit-2.0.7 psycopg2-2.7.6.1 ptyprocess-0.6.0 py-1.7.0 pycodestyle-2.4.0 pygments-2.2Selecting previously unselected package libnetpbm10.Unpacking libcupsfilters1:amd64 (1.20.2-0ubuntu3) ... 77% |████████████████████████▉ | 6.3MB 5.9MB/s eta 0:00:01 Unpacking python3-wheel (0.30.0-0.2) ...95% [Waiting for headers] 4944 kB/s 0sGet:82 http://archive.ubuntu.com/ubuntu bionic/universe amd64 libzvbi0 amd64 0.2.35-13 [235 kB] Setting up libxshmfence1:amd64 (1.3-1) ...Reading package lists... 46%Selecting previously unselected package libapache2-mod-wsgi-py3.98% [Working] 4630 kB/s 0s97% [21 Translation-en store 0 B] 4229 kB/s 0s5% [Waiting for headers] Setting up libpangocairo-1.0-0:amd64 (1.40.14-1ubuntu0.1) ...Setting up libxfixes3:amd64 (1:5.0.3-1) ...7.6.1-cp36-cp36m-manylinux1_x86_64.whl (2.7MB) 32% |██████████▎ | 296kB 5.6MB/s eta 0:00:01 5% [Waiting for headers] Applying documents.0004_auto_20160114_1844... OKConnection to pingu.lan closed. Downloading https://files.pythonhosted.org/packages/e5/c6/ce130213489969aa58610042dff1d908c25c731c9575af6935c2dfad03aa/pycodestyle * Canonical Livepatch is available for installation.Setting up libpython3-dev:amd64 (3.6.7-1~18.04) ... => There is 1 zombie process.Unpacking libzvbi0:amd64 (0.2.35-13) ...Selecting previously unselected package libpoppler-dev:amd64.Enabling site paperless.Get:122 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-dri2-0 amd64 1.13-1 [6928 B] Setting up libtesseract4 (4.00~git2288-10f4998a-2) ...Collecting filemagic==1.6 (from -r requirements.txt (line 26)) 31% |██████████▏ | 317kB 5.9MB/s eta 0:00:01 Applying documents.0002_auto_20151226_1316... OK7% [14 libtiff5 2613 B/152 kB 2%] 14% |████▌ | 71kB 4.7MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/en.js'Get:11 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 cpp-7 amd64 7.3.0-27ubuntu1~18.04 [6738 kB]Created symlink /etc/systemd/system/multi-user.target.wants/apache-htcacheclean.service → /lib/systemd/system/apache-htcacheclean.se Downloading https://files.pythonhosted.org/packages/52/69/3c2fbdc3702358c5b34ee25e387b24838597ef099761fc9a42c166796e8f/sphinxcontr34% [55 libgdk-pixbuf2.0-0 4061 B/165 kB 2%] Setting up apache2-data (2.4.29-1ubuntu4.5) ...93% [Waiting for headers] 4611 kB/s 0sCollecting django-cors-headers==2.4.0 (from -r requirements.txt (line 14))Preparing to unpack .../05-apache2-bin_2.4.29-1ubuntu4.5_amd64.deb ...51% [Waiting for headers] 3755 kB/s 8sGet:1 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 binutils-common amd64 2.30-21ubuntu1~18.04 [193 kB]Get:7 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 apache2-utils amd64 2.4.29-1ubuntu4.5 [83.3 kB] Downloading https://files.pythonhosted.org/packages/d9/eb/6d13451769976f79c9043db562da22302a2c3d96e5d6427e8517fec9d2e5/Faker-0.9.2 99% |███████████████████████████████▊| 501kB 5.8MB/s eta 0:00:01 Unpacking binutils-x86-64-linux-gnu (2.30-21ubuntu1~18.04) ... Downloading https://files.pythonhosted.org/packages/02/ee/b6e02dc6529e82b75bb06823ff7d005b141037cb1416b10c6f00fc419dca/Pygments-2.Get:102 http://archive.ubuntu.com/ubuntu bionic/main amd64 libgif7 amd64 5.1.4-2 [30.6 kB] Unpacking python3-xdg (0.25-4ubuntu1) ...Selecting previously unselected package libavahi-common3:amd64.Selecting previously unselected package libopenexr22:amd64.Setting up libaprutil1:amd64 (1.6.1-2) ...Unpacking libdrm-amdgpu1:amd64 (2.4.91-2) ...Selecting previously unselected package libx264-152:amd64. * Support: https://ubuntu.com/advantage 10% |███▌ | 778kB 6.0MB/s eta 0:00:02 tesseract-ocr-osd unpaper va-driver-all vdpau-driver-allSetting up libopenexr22:amd64 (2.2.0-11.1ubuntu1) ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/fonts/LICENSE.txt'Selecting previously unselected package libthai0:amd64.Selecting previously unselected package fonts-dejavu-core. 26% |████████▌ | 204kB 5.9MB/s eta 0:00:01 Unpacking libquadmath0:amd64 (8.2.0-1ubuntu2~18.04) ... 100% |████████████████████████████████| 225kB 2.8MB/s Collecting snowballstemmer==1.2.1 (from -r requirements.txt (line 69))54% [95 libdjvulibre21 4061 B/559 kB 1%] 3755 kB/s 8s95% [47 python3-crypto 2613 B/244 kB 1%] 4611 kB/s 0s Applying documents.0012_auto_20160305_0040... OK https://ubuntu.com/livepatchGet:42 http://archive.ubuntu.com/ubuntu bionic/main amd64 libfile-fcntllock-perl amd64 0.22-3build2 [33.2 kB] Get:14 http://security.ubuntu.com/ubuntu bionic-security/universe Translation-en [64.2 kB]Unpacking libatomic1:amd64 (8.2.0-1ubuntu2~18.04) ... 34% |███████████ | 2.5MB 5.8MB/s eta 0:00:01 Preparing to unpack .../132-python3-pil_5.1.0-1_amd64.deb ... Downloading https://files.pythonhosted.org/packages/91/4f/f52682bfaa960445af93143df5ea0a98854f1a7829ff3e377932426bf48c/coveralls-1Get:36 http://archive.ubuntu.com/ubuntu bionic/main amd64 libfakeroot amd64 1.22-2ubuntu1 [25.9 kB] 77% [8 apache2-data 2613 B/160 kB 2%] Preparing to unpack .../072-libvorbisenc2_1.3.5-4.2_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/docs/css/jquery.json-view.min.css' Running setup.py bdist_wheel for python-levenshtein ... \68% [43 libpython3.6-dev 21.9 MB/44.8 MB 49%] 4611 kB/s 6s Running setup.py bdist_wheel for tzlocal ... \Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pl.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ms.js' 26% |████████▍ | 808kB 6.0MB/s eta 0:00:01 24% [Waiting for headers] 98% [53 python3-pip 4061 B/114 kB 4%] 4944 kB/s 0sSetting up manpages-dev (4.15-1) ... 32% |██████████▍ | 1.0MB 5.8MB/s eta 0:00:01 Copying '/home/paperless/paperless/src/documents/static/paperless.css'Preparing to unpack .../106-libwmf0.2-7_0.2.8.4-12_amd64.deb ...18% [Working] Preparing to unpack .../54-python3.6-venv_3.6.7-1~18.04_amd64.deb ... 73% |███████████████████████▌ | 5.2MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libijs-0.35:amd64.Preparing to unpack .../29-libdpkg-perl_1.19.0.5ubuntu2.1_all.deb ...Setting up python3-dev (3.6.7-1~18.04) ...Unpacking fonts-droid-fallback (1:6.0.1r16-1.1) ...Collecting coveralls==1.5.1 (from -r requirements.txt (line 11))Unpacking libmemcachedutil2:amd64 (1.0.18-4.2) ...Get:67 http://archive.ubuntu.com/ubuntu bionic/main amd64 libspeex1 amd64 1.2~rc1.2-1ubuntu2 [52.1 kB]Preparing to unpack .../085-libgme0_0.6.2-1_amd64.deb ... Downloading https://files.pythonhosted.org/packages/a2/55/8f8cab2afd404cf578136ef2cc5dfb50baa1761b68c9da1fb1e4eed343c9/docopt-0.6. 44% |██████████████▏ | 3.2MB 6.0MB/s eta 0:00:01 Reading package lists... 8%Get:13 http://archive.ubuntu.com/ubuntu bionic/main amd64 libltdl7 amd64 2.4.6-2 [38.8 kB] Downloading https://files.pythonhosted.org/packages/1c/e7/017c262070af41fe251401cb0d0e1b7c38f656da634cd0c15604f1f30864/pluggy-0.8.Selecting previously unselected package libubsan0:amd64.Receiving objects: 54% (3008/5570), 4.67 MiB | 3.10 MiB/s bms@FortBoyard:~$ exit 97% |███████████████████████████████▎| 7.9MB 6.0MB/s eta 0:00:01 Preparing to unpack .../03-binutils_2.30-21ubuntu1~18.04_amd64.deb ...Get:133 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-pil amd64 5.1.0-1 [328 kB] Get:23 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libavahi-client3 amd64 0.7-3.1ubuntu1.1 [25.3 kB]Setting up mesa-vdpau-drivers:amd64 (18.0.5-0ubuntu0~18.04.1) ...1-py2.py3-none-any.whl (3.1MB)Preparing to unpack .../053-libgdk-pixbuf2.0-common_2.36.11-2_all.deb ...Get:37 http://archive.ubuntu.com/ubuntu bionic/main amd64 fakeroot amd64 1.22-2ubuntu1 [62.3 kB] 51% |████████████████▍ | 3.6MB 6.0MB/s eta 0:00:01 96% |███████████████████████████████ | 102kB 6.9MB/s eta 0:00:01 100% |████████████████████████████████| 552kB 1.5MB/s 95% |██████████████████████████████▋ | 61kB 5.2MB/s eta 0:00:01 59% |███████████████████▏ | 4.9MB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/fonts/README.txt' Applying documents.0020_document_added... OK 100% |████████████████████████████████| 7.1MB 158kB/s 76% [105 libllvm6.0 14.4 MB/14.5 MB 99%] 3755 kB/s 4sUnpacking libwebpdemux2:amd64 (0.6.1-2) ...Unpacking libstdc++-7-dev:amd64 (7.3.0-27ubuntu1~18.04) ...Setting up libbdplus0:amd64 (0.1.2-2) ...Preparing to unpack .../055-libthai-data_0.1.27-2_all.deb ...Unpacking libx264-152:amd64 (2:0.152.2854+gite9a5903-2) ...Unpacking libaprutil1-dbd-sqlite3:amd64 (1.6.1-2) ...Selecting previously unselected package unpaper.HTTP request sent, awaiting response... 200 OKGet:135 http://archive.ubuntu.com/ubuntu bionic/universe amd64 tesseract-ocr-eng all 4.00~git24-0e00fe6-1.2 [1588 kB] Applying documents.0011_auto_20160303_1929... OKPreparing to unpack .../043-libxcb-render0_1.13-1_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hr.js'51% [Working] 3755 kB/s 8sSetting up libxrender1:amd64 (1:0.9.10-1) ...Preparing to unpack .../094-libdjvulibre21_3.5.27.1-8_amd64.deb ...Enabling module deflate.47% [83 libavcodec57 2878 kB/4592 kB 63%] 3755 kB/s 9sReading state information... DoneUnpacking libxvidcore4:amd64 (2:1.3.5-1) ...Setting up libcupsimage2:amd64 (2.2.7-1ubuntu2.3) ... 57% |██████████████████▍ | 4.7MB 6.0MB/s eta 0:00:01 100% |████████████████████████████████| 81kB 3.5MB/s Preparing to unpack .../00-libapr1_1.6.3-2_amd64.deb ...Preparing to unpack .../075-libwebp6_0.6.1-2_amd64.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/bg.js'Setting up python3-distutils (3.6.7-1~18.04) ...14% [Working] 5% [Waiting for headers] Running setup.py bdist_wheel for backcall ... -Unpacking libtheora0:amd64 (1.1.1+dfsg.1-14) ...Get:116 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libpoppler-cpp-dev amd64 0.62.0-2ubuntu2.5 [8680 B] Preparing to unpack .../010-liblcms2-2_2.9-1ubuntu0.1_amd64.deb ... 99% |███████████████████████████████▉| 215kB 5.8MB/s eta 0:00:01 70% |██████████████████████▋ | 5.0MB 6.0MB/s eta 0:00:01 25% |████████▏ | 501kB 5.9MB/s eta 0:00:01 68% |█████████████████████▊ | 5.5MB 5.9MB/s eta 0:00:01 60% |███████████████████▎ | 1.6MB 5.8MB/s eta 0:00:01 Preparing to unpack .../18-libubsan0_7.3.0-27ubuntu1~18.04_amd64.deb ...Unpacking fontconfig (2.12.6-0ubuntu2) ... 68% |█████████████████████▉ | 522kB 6.0MB/s eta 0:00:01 libc6-dev libcc1-0 libcilkrts5 libdpkg-perl libexpat1-dev libfakeroot libfile-fcntllock-perl libgcc-7-dev libisl19 libitm1Unpacking libdrm-nouveau2:amd64 (2.4.91-2) ... Running setup.py bdist_wheel for docopt ... -Copying '/usr/local/lib/python3.6/dist-packages/django_extensions/static/django_extensions/js/jquery.ajaxQueue.js'Get:50 http://archive.ubuntu.com/ubuntu bionic/main amd64 libmp3lame0 amd64 3.100-2 [136 kB]Selecting previously unselected package libcups2:amd64.54% [Waiting for headers] 3755 kB/s 8sGet:29 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgs9-common all 9.26~dfsg+0-0ubuntu0.18.04.3 [5094 kB]Preparing to unpack .../030-ghostscript_9.26~dfsg+0-0ubuntu0.18.04.3_amd64.deb ... Running setup.py bdist_wheel for pytest-env ... - Stored in directory: /root/.cache/pip/wheels/2e/0e/8e/c4625de9d6f723017996dd718d5fabe1c7bb1fbce7389d3bf6Get:120 http://archive.ubuntu.com/ubuntu bionic/main amd64 libwebpdemux2 amd64 0.6.1-2 [9472 B] libbluray-bdj firmware-crystalhd cups-common libfftw3-bin libfftw3-dev liblcms2-utils inkscape libjxr-tools opus-tools 55% |█████████████████▊ | 112kB 6.5MB/s eta 0:00:01 Preparing to unpack .../084-libchromaprint1_1.4.3-1_amd64.deb ...Selecting previously unselected package apache2-utils.89% [130 netpbm 2612 B/1017 kB 0%] 4630 kB/s 1sResolving raw.githubusercontent.com (raw.githubusercontent.com)... 151.101.16.133 Applying documents.0016_auto_20170325_1558... OK 13% |████▏ | 409kB 5.5MB/s eta 0:00:01 Stored in directory: /root/.cache/pip/wheels/9b/04/dd/7daf4150b6d9b12949298737de9431a324d4b797ffd63f526ePreparing to unpack .../53-python3-setuptools_39.0.1-2_all.deb ...Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/LICENSE-SELECT2.md' Downloading https://files.pythonhosted.org/packages/4b/2a/0276479a4b3caeb8a8c1af2f8e4355746a97fab05a372e4a2c6a6b876165/idna-2.7-pySelecting previously unselected package i965-va-driver:amd64.Get:58 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-xdg all 0.25-4ubuntu1 [31.4 kB] Preparing to unpack .../064-libshine3_3.1.1-1_amd64.deb ...Enabling module status.67% [Waiting for headers] Downloading https://files.pythonhosted.org/packages/56/9d/1d02dd80bc4cd955f98980f28c5ee2200e1209292d5f9e9cc8d030d18655/certifi-201Unpacking libjpeg-turbo8:amd64 (1.5.2-0ubuntu5.18.04.1) ...Unpacking vdpau-driver-all:amd64 (1.1.1-3ubuntu1) ...98% [Waiting for headers] 4630 kB/s 0sSelecting previously unselected package poppler-data. 93% |██████████████████████████████ | 716kB 5.9MB/s eta 0:00:01 21% [22 libquadmath0 2613 B/133 kB 2%] Selecting previously unselected package libaprutil1:amd64.Get:21 http://archive.ubuntu.com/ubuntu bionic/multiverse Translation-en [108 kB] 82% |██████████████████████████▎ | 5.8MB 5.9MB/s eta 0:00:01 56% |██████████████████▎ | 4.1MB 6.0MB/s eta 0:00:01 Operations to perform:Get:129 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 mesa-vdpau-drivers amd64 18.0.5-0ubuntu0~18.04.1 [1902 kB] Get:71 http://archive.ubuntu.com/ubuntu bionic/main amd64 libtwolame0 amd64 0.3.13-3 [46.7 kB] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/vendor/select2/LICENSE-SELECT2.md'Selecting previously unselected package libjbig2dec0:amd64.Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fa.js'Unpacking libharfbuzz0b:amd64 (1.7.2-1ubuntu1) ...Get:53 http://archive.ubuntu.com/ubuntu bionic/main amd64 libcroco3 amd64 0.6.12-2 [81.3 kB]erage-4.5.1 coveralls-1.5.1 dateparser-0.7.0 decorator-4.3.0 django-2.0.9 django-cors-headers-2.4.0 django-crispy-forms-1.7.2 django 100% |████████████████████████████████| 2.0MB 515kB/s Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/prepopulate_init.js'Get:126 http://archive.ubuntu.com/ubuntu bionic/main amd64 libxcb-xfixes0 amd64 1.13-1 [9340 B] Preparing to unpack .../49-python3-secretstorage_2.3.1-2_all.deb ...Receiving objects: 1% (56/5570) Setting up libdrm-radeon1:amd64 (2.4.91-2) ...98% [25 Sources store 0 B] 4229 kB/s 0s30% [Waiting for headers] Get:12 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 cpp amd64 4:7.3.0-3ubuntu2.1 [27.6 kB] 81% |██████████████████████████▏ | 1.6MB 5.8MB/s eta 0:00:01 Get:128 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 mesa-va-drivers amd64 18.0.5-0ubuntu0~18.04.1 [1778 kB] libva-x11-2 libva2 libvdpau1 libvorbis0a libvorbisenc2 libvorbisfile3 libvpx5 libwavpack1 libwebp6 libwebpdemux2 libwebpmux3Receiving objects: 21% (1170/5570), 676.01 KiB | 1.30 MiB/s libopus0 libpango-1.0-0 libpangocairo-1.0-0 libpangoft2-1.0-0 libpaper-utils libpaper1 libpciaccess0 libpixman-1-0Preparing to unpack .../40-libexpat1-dev_2.2.5-3_amd64.deb ...Selecting previously unselected package libisl19:amd64.Setting up libzvbi-common (0.2.35-13) ... 30% |█████████▊ | 2.2MB 5.9MB/s eta 0:00:01 Preparing to unpack .../122-libxcb-dri3-0_1.13-1_amd64.deb ...Preparing to unpack .../042-libpixman-1-0_0.34.0-2_amd64.deb ...Collecting pytest-django==3.4.3 (from -r requirements.txt (line 55)) libavahi-common3 libavcodec57 libavformat57 libavutil55 libbdplus0 libbluray2 libcairo2 libchromaprint1 libcroco3 libcrystalhd3Get:19 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libubsan0 amd64 7.3.0-27ubuntu1~18.04 [126 kB]Preparing to unpack .../119-libwebpdemux2_0.6.1-2_amd64.deb ...Get:74 http://archive.ubuntu.com/ubuntu bionic/main amd64 libvpx5 amd64 1.7.0-3 [798 kB] Downloading https://files.pythonhosted.org/packages/d4/6c/8a935e2c7b54a37714656d753e4187ee0631988184ed50c0cf6476858566/snowballste 19% |██████▏ | 1.6MB 4.6MB/s eta 0:00:02 Receiving objects: 20% (1114/5570) 43% [Working] 3755 kB/s 10s0.10-py3-none-any.whlAdding user `paperless' ...ple-1.1.8.tar.gzPreparing to unpack .../110-libnss3_2%3a3.35-2ubuntu2.1_amd64.deb ...Unpacking make (4.1-9.1ubuntu1) ... 97% |███████████████████████████████▍| 143kB 5.9MB/s eta 0:00:01 Setting up libwebp6:amd64 (0.6.1-2) ...37% [Waiting for headers] Collecting pytest-forked==0.2 (from -r requirements.txt (line 57))Unpacking libgsm1:amd64 (1.0.13-4build1) ...7% [Waiting for headers] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hu.js'Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/admin/RelatedObjectLookups.js'Unpacking liblsan0:amd64 (8.2.0-1ubuntu2~18.04) ...Get:73 http://archive.ubuntu.com/ubuntu bionic/main amd64 libvorbisenc2 amd64 1.3.5-4.2 [70.7 kB] Adding new group `ftpupload' (1001) ...Setting up ssl-cert (1.0.39) ...Setting up imagemagick-6-common (8:6.9.7.4+dfsg-16ubuntu6.4) ... 54% |█████████████████▋ | 4.4MB 5.3MB/s eta 0:00:01 Unpacking g++ (4:7.3.0-3ubuntu2.1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/fontawesome-webfont.ttf' 23% |███████▌ | 1.7MB 6.0MB/s eta 0:00:01 --2019-01-20 19:50:05-- https://raw.githubusercontent.com/bmsleight/paperless/master/scripts/lxc/lxc-install.shUnpacking libsensors4:amd64 (1:3.4.0-4) ...45% [Working] 4081 kB/s 12sReceiving objects: 31% (1727/5570), 2.15 MiB | 2.14 MiB/s 100% |████████████████████████████████| 1.0MB 946kB/s 49% |████████████████ | 3.6MB 6.0MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/css/autocomplete.css'28% [32 gsfonts 2875 kB/3120 kB 92%] 95% |██████████████████████████████▊ | 71kB 5.0MB/s eta 0:00:01 Downloading https://files.pythonhosted.org/packages/6a/8b/8517167a0adc45ce94d0873efb9487dd4cdeff7e10f96e837ad3d58f5837/django_filtPreparing to unpack .../045-libxrender1_1%3a0.9.10-1_amd64.deb ...Setting up libgdk-pixbuf2.0-common (2.36.11-2) ...Unpacking fonts-dejavu-core (2.37-1) ... Downloading https://files.pythonhosted.org/packages/59/59/4bc44158a767a6d66de18c4136c8aa90491d56cc951c10b74dd1e13213c9/langdetect-Preparing to unpack .../059-libgraphite2-3_1.3.11-2_amd64.deb ... 8% |██▋ | 655kB 2.3MB/s eta 0:00:04 Creating config file /etc/papersize with new versionGet:14 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libitm1 amd64 8.2.0-1ubuntu2~18.04 [28.1 kB]Selecting previously unselected package libxvidcore4:amd64.Selecting previously unselected package libzvbi-common.Unpacking tesseract-ocr (4.00~git2288-10f4998a-2) ... 100% |████████████████████████████████| 61kB 5.0MB/s Unpacking libfile-fcntllock-perl (0.22-3build2) ...Preparing to unpack .../121-libxcb-dri2-0_1.13-1_amd64.deb ...Selecting previously unselected package libdrm-radeon1:amd64.Setting up libsensors4:amd64 (1:3.4.0-4) ... Running setup.py bdist_wheel for langdetect ... donePreparing to unpack .../017-libogg0_1.3.2-1_amd64.deb ...s-1.2.1-py2.py3-none-any.whl50% [87 libmpg123-0 2613 B/125 kB 2%] 3755 kB/s 8s Installing from a newer Wheel-Version (1.1)Setting up libexpat1-dev:amd64 (2.2.5-3) ...Unpacking python3-distutils (3.6.7-1~18.04) ...Unpacking libpoppler-cpp0v5:amd64 (0.62.0-2ubuntu2.5) ...Selecting previously unselected package libx265-146:amd64.Selecting previously unselected package libmp3lame0:amd64.14% [Waiting for headers] Preparing to unpack .../116-librsvg2-common_2.40.20-2_amd64.deb ...Selecting previously unselected package manpages-dev.Selecting previously unselected package libpango-1.0-0:amd64. libwmf0.2-7 libx11-xcb1 libx264-152 libx265-146 libxcb-dri2-0 libxcb-dri3-0 libxcb-present0 libxcb-render0 libxcb-shm0 100% |████████████████████████████████| 112kB 4.1MB/s 99% |████████████████████████████████| 337kB 6.1MB/s eta 0:00:01 86% [Waiting for headers] Created symlink /etc/systemd/system/multi-user.target.wants/apache2.service → /lib/systemd/system/apache2.service. 43% |██████████████ | 3.5MB 6.0MB/s eta 0:00:01 Selecting previously unselected package libopenjp2-7:amd64./usr/local/lib/python3.6/dist-packages/psycopg2/__init__.py:144: UserWarning: The psycopg2 wheel package will be renamed from releas71% [Working] Selecting previously unselected package libwavpack1:amd64.Preparing to unpack .../01-libaprutil1_1.6.1-2_amd64.deb ...The following NEW packages will be installed:Selecting previously unselected package linux-libc-dev:amd64.update-alternatives: using /usr/bin/display-im6.q16 to provide /usr/bin/display-im6 (display-im6) in auto mode31% [Waiting for headers] 99% |████████████████████████████████| 2.0MB 6.2MB/s eta 0:00:01 Get:20 http://archive.ubuntu.com/ubuntu bionic/multiverse amd64 Packages [151 kB] libavcodec57 libavformat57 libavutil55 libbdplus0 libbluray2 libcairo2 libchromaprint1 libcroco3 libcrystalhd3 libcups297% [Waiting for headers] update-alternatives: using /usr/bin/conjure-im6.q16 to provide /usr/bin/conjure-im6 (conjure-im6) in auto mode98% [137 tesseract-ocr 2613 B/218 kB 1%] 4630 kB/s 0sCreated symlink /etc/systemd/system/multi-user.target.wants/paperless-consumer.service → /etc/systemd/system/paperless-consumer.servAfter this operation, 8347 kB of additional disk space will be used.thon-levenshtein, fuzzywuzzy, gunicorn, imagesize, inotify-simple, ipython-genutils, pickleshare, ptyprocess, pexpect, parso, jedi, 28% [14 Translation-en store 0 B] [10 Sources 2419 kB/9051 kB 27%] [Waiting for headers] Collecting django-filter==2.0.0 (from -r requirements.txt (line 17))Selecting previously unselected package libltdl7:amd64.Preparing to unpack .../047-libcrystalhd3_1%3a0.0~git20110715.fdd2f19-12_amd64.deb ...Collecting psycopg2==2.7.6.1 (from -r requirements.txt (line 46))Selecting previously unselected package python3-secretstorage. 15% |█████ | 307kB 5.9MB/s eta 0:00:01 Setting up libxcb-sync1:amd64 (1.13-1) ...35% [59 libpango-1.0-0 2613 B/153 kB 2%] Preparing to unpack .../009-libjpeg8_8c-2ubuntu8_amd64.deb ...83% [Waiting for headers] 4630 kB/s 2sSelecting previously unselected package mesa-vdpau-drivers:amd64.43% [80 libxvidcore4 2613 B/200 kB 1%] 3755 kB/s 10s77% [Waiting for headers] Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/select2.full.min.js' 86% |███████████████████████████▌ | 2.3MB 5.9MB/s eta 0:00:01 Setting up libc-dev-bin (2.27-3ubuntu1) ...87% [Waiting for headers] 4630 kB/s 2s-0.7.5-py2.py3-none-any.whlCopying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/fonts/fontawesome-webfont.eot'Collecting apipkg==1.5 (from -r requirements.txt (line 3)) Applying auth.0005_alter_user_last_login_null... OK libvdpau1 libvorbis0a libvorbisenc2 libvorbisfile3 libvpx5 libwavpack1 libwebp6 libwebpdemux2 libwebpmux3 libwmf0.2-797% [20 Packages store 0 B] 4229 kB/s 0sGet:20 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcilkrts5 amd64 7.3.0-27ubuntu1~18.04 [42.5 kB]Setting up libmagickcore-6.q16-3:amd64 (8:6.9.7.4+dfsg-16ubuntu6.4) ...36% [Waiting for headers] Adding new user `ftpupload' (1001) with group `ftpupload' ...Selecting previously unselected package libxcb-present0:amd64.98% [Working] 4944 kB/s 0sUnpacking libc-dev-bin (2.27-3ubuntu1) ... 76% |████████████████████████▌ | 6.2MB 6.0MB/s eta 0:00:01 96% [18 Packages store 0 B] [29 Translation-en 4135 B/175 kB 2%] 99% |████████████████████████████████| 112kB 6.5MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/el.js' 6% |██ | 501kB 2.7MB/s eta 0:00:03 Unpacking libgme0:amd64 (0.6.2-1) ...Copying '/usr/local/lib/python3.6/dist-packages/rest_framework/static/rest_framework/img/glyphicons-halflings.png'Selecting previously unselected package libmagickcore-6.q16-3:amd64.-py2.py3-none-any.whl (177kB)Resolving deltas: 75% (2688/3560) Preparing to unpack .../097-libdrm-intel1_2.4.91-2_amd64.deb ...Preparing to unpack .../082-libavcodec57_7%3a3.4.4-0ubuntu0.18.04.1_amd64.deb ...11% [Waiting for headers] Get:35 http://archive.ubuntu.com/ubuntu bionic/main amd64 dh-python all 3.20180325ubuntu2 [89.2 kB] Setting up libgcc-7-dev:amd64 (7.3.0-27ubuntu1~18.04) ... liblsan0 libmpc3 libmpx2 libpython3-dev libpython3.6-dev libquadmath0 libstdc++-7-dev libtsan0 libubsan0 linux-libc-dev makeCopying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/js/collapse.min.js'.1.0-py2.py3-none-any.whl 26% |████████▍ | 2.1MB 5.1MB/s eta 0:00:02 0% [1 binutils-common 2613 B/193 kB 1%] Collecting prompt-toolkit==2.0.7 (from -r requirements.txt (line 47))Setting up libharfbuzz0b:amd64 (1.7.2-1ubuntu1) ... 70% |██████████████████████▊ | 1.4MB 5.9MB/s eta 0:00:01 11% |███▊ | 307kB 5.8MB/s eta 0:00:01 Unpacking libvorbis0a:amd64 (1.3.5-4.2) ...Unpacking libchromaprint1:amd64 (1.4.3-1) ...Unpacking python3-crypto (2.6.1-8ubuntu2) ... Downloading https://files.pythonhosted.org/packages/bc/bb/a24838832ba35baf52f32ab1a49b906b5f82fb7c76b2f6a7e35e140bac30/decorator-430% [Working] 92% |█████████████████████████████▊ | 7.5MB 5.8MB/s eta 0:00:01 Selecting previously unselected package cpp.38% [70 libtheora0 2613 B/170 kB 2%] Unpacking libpoppler-cpp-dev:amd64 (0.62.0-2ubuntu2.5) ... 15% |█████ | 1.3MB 3.3MB/s eta 0:00:03 91% [133 python3-pil 2613 B/328 kB 1%] 4630 kB/s 1s Stored in directory: /root/.cache/pip/wheels/de/c2/93/660fd5f7559049268ad2dc6d81c4e39e9e36518766eaf7e342 Running setup.py bdist_wheel for pytest-env ... done 20% |██████▋ | 1.5MB 5.9MB/s eta 0:00:01 Copying '/usr/local/lib/python3.6/dist-packages/django/contrib/admin/static/admin/img/LICENSE' 100% |████████████████████████████████| 204kB 2.8MB/s Get:4 http://archive.ubuntu.com/ubuntu bionic/universe amd64 proftpd-doc all 1.3.5e-1build1 [1165 kB] 65% |█████████████████████ | 4.6MB 5.9MB/s eta 0:00:01 Saving to: ‘lxc-install.sh’Get:47 http://archive.ubuntu.com/ubuntu bionic/main amd64 libcairo2 amd64 1.15.10-2 [580 kB] System load: 0.0 Users logged in: 1 + \ No newline at end of file diff --git a/docs/examples/lxc/lxc-install.sh b/docs/examples/lxc/lxc-install.sh new file mode 100644 index 000000000..b53858e3a --- /dev/null +++ b/docs/examples/lxc/lxc-install.sh @@ -0,0 +1,158 @@ +#!/usr/bin/env bash + +# Bash script to install paperless in lxc containter +# paperless.lan +# +# Will set-up paperless, apache2 and proftpd +# +# lxc launch ubuntu: paperless +# lxc exec paperless -- sh -c "sudo apt-get update && sudo apt-get install -y wget" +# lxc exec paperless -- sh -c "wget https://raw.githubusercontent.com/the-paperless-project/paperless/master/docs/examples/lxc/lxc-install.sh && /bin/bash lxc-install.sh --email " +# +# +set +e +PASSWORD=$(< /dev/urandom tr -dc _A-Z-a-z-0-9+@%^{} | head -c20;echo;) +EMAIL= + +function displayHelp() { + echo "available parameters: + -e | --email + -p | --password + " +} + +POSITIONAL=() +while [[ $# -gt 0 ]] +do +key="$1" +i=$key + +case $i in + -e|--email) + EMAIL="${2}" + shift + shift + ;; + -p|--password) + PASSWORD="${2}" + shift + shift + ;; + --default|-h|--help) + shift + displayHelp + exit 0 + ;; + *) + echo "argument: $i not recognized" + exit 2 + ;; +esac +done +set -- "${POSITIONAL[@]}" # restore positional parameters + +if [ -z $EMAIL ]; then + echo "missing email, try running with -h " + exit 3 +fi +if [[ $(/usr/bin/id -u) -ne 0 ]]; then + echo "Not running as root" + exit +fi + +if [ $(grep -c paperless /etc/passwd) -eq 0 ]; then + # Add paperless user with no password + adduser --disabled-password --gecos "" paperless +fi + +if [ $(grep -c ftpupload /etc/passwd) -eq 0 ]; then + # Add ftpupload + adduser --disabled-password --gecos "" ftpupload + echo "Set ftpupload password: " + #passwd ftpupload + #TODO: generate some password and allow parameter + echo "ftpupload:ftpuploadpassword" | chpasswd +fi + +if [ $(id -nG paperless | grep -Fcw ftpupload) -eq 0 ]; then + # Allow paperless group to access + adduser paperless ftpupload + chmod g+w /home/ftpupload +fi + +# Get apt up to date +apt-get update + +# Needed for plain Paperless +apt-get -y install unpaper gnupg libpoppler-cpp-dev python3-pyocr tesseract-ocr imagemagick optipng git + +# Needed for Apache +apt-get -y install apache2 libapache2-mod-wsgi-py3 + +if [ ! -f /etc/proftpd/proftpd.conf ]; then + # Install ftp server and make sure all uplaoded files are owned by paperless + apt-get -y install proftpd +fi +if [ $(grep -c paperless /etc/proftpd/proftpd.conf) -eq 0 ]; then + cat <> /etc/proftpd/proftpd.conf + + UserOwner paperless + GroupOwner paperless + +EOF + systemctl restart proftpd +fi + +#Get Paperless from git +su -c "cd /home/paperless ; git clone https://github.com/the-paperless-project/paperless" paperless + +# Install Pip Requirements +apt-get -y install python3-pip python3-venv +cd /home/paperless/paperless +pip3 install -r requirements.txt + +# Take paperless.conf.example and set consumuption dir (ftp dir) +sed -e '/PAPERLESS_CONSUMPTION_DIR=/s/=.*/=\"\/home\/ftpupload\/\"/' \ + /home/paperless/paperless/paperless.conf.example >/etc/paperless.conf + +# Update /etc/paperless.conf with PAPERLESS_SECRET_KEY +SECRET=$(strings /dev/urandom | grep -o '[[:alnum:]]' | head -n 30 | tr -d '\n'; echo) +sed -i "s/#PAPERLESS_SECRET_KEY.*/PAPERLESS_SECRET_KEY=$SECRET/" /etc/paperless.conf + +#Initialise the SQLite database +su -c "cd /home/paperless/paperless/src/ ; ./manage.py migrate" paperless +echo "if superuser doesn't exists, create one with login: paperless and password: ${PASSWORD}" +#Create a user for your Paperless instance +su -c "cd /home/paperless/paperless/src/ ; echo ./manage.py create_superuser_with_password --username paperless --email ${EMAIL} --password ${PASSWORD} --preserve" paperless +su -c "cd /home/paperless/paperless/src/ ; ./manage.py create_superuser_with_password --username paperless --email ${EMAIL} --password ${PASSWORD} --preserve" paperless + +if [ ! -d /home/paperless/paperless/static ]; then + # 167 static files copied to '/home/paperless/paperless/static'. + su -c "cd /home/paperless/paperless/src/ ; ./manage.py collectstatic" paperless +fi + +if [ ! -f /etc/apache2/sites-available/paperless.conf ]; then + # Set-up apache + cp /home/paperless/paperless/docs/examples/lxc/paperless.conf /etc/apache2/sites-available/ + a2dissite 000-default.conf + a2ensite paperless.conf + systemctl reload apache2 +fi + +sed -e "s:home/paperless/project/virtualenv/bin/python:usr/bin/python3:" \ + /home/paperless/paperless/scripts/paperless-consumer.service \ + >/etc/systemd/system/paperless-consumer.service + +sed -i "s:/home/paperless/project/src/manage.py:/home/paperless/paperless/src/manage.py:" \ + /etc/systemd/system/paperless-consumer.service + + +systemctl enable paperless-consumer +systemctl start paperless-consumer + +# convert-im6.q16: not authorized +# Security risk ? +# https://stackoverflow.com/questions/42928765/convertnot-authorized-aaaa-error-constitute-c-readimage-453 +if [ -f /etc/ImageMagick-6/policy.xml ]; then + mv /etc/ImageMagick-6/policy.xml /etc/ImageMagick-6/policy.xmlout +fi diff --git a/docs/examples/lxc/paperless.conf b/docs/examples/lxc/paperless.conf new file mode 100644 index 000000000..7a6978a65 --- /dev/null +++ b/docs/examples/lxc/paperless.conf @@ -0,0 +1,18 @@ + + ServerName paperless.lan + + Alias /static/ /home/paperless/paperless/static/ + + Require all granted + + + WSGIScriptAlias / /home/paperless/paperless/src/paperless/wsgi.py + WSGIDaemonProcess paperless.lan user=paperless group=paperless threads=5 python-path=/home/paperless/paperless/src + WSGIProcessGroup paperless.lan + + + + Require all granted + + + diff --git a/docs/guesswork.rst b/docs/guesswork.rst index 0e728d7af..c12ecd0c4 100644 --- a/docs/guesswork.rst +++ b/docs/guesswork.rst @@ -54,6 +54,34 @@ filename as described above. .. _dateparser: https://github.com/scrapinghub/dateparser/blob/v0.7.0/docs/usage.rst#settings +Transforming filenames for parsing +---------------------------------- +Some devices can't produce filenames that can be parsed by the default +parser. By configuring the option ``PAPERLESS_FILENAME_PARSE_TRANSFORMS`` in +``paperless.conf`` one can add transformations that are applied to the filename +before it's parsed. + +The option contains a list of dictionaries of regular expressions (key: +``pattern``) and replacements (key: ``repl``) in JSON format, which are +applied in order by passing them to ``re.subn``. Transformation stops +after the first match, so at most one transformation is applied. The general +syntax is + +.. code:: python + + [{"pattern":"pattern1", "repl":"repl1"}, {"pattern":"pattern2", "repl":"repl2"}, ..., {"pattern":"patternN", "repl":"replN"}] + +The example below is for a Brother ADS-2400N, a scanner that allows +different names to different hardware buttons (useful for handling +multiple entities in one instance), but insists on adding ``_`` +to the filename. + +.. code:: python + + # Brother profile configuration, support "Name_Date_Count" (the default + # setting) and "Name_Count" (use "Name" as tag and "Count" as title). + PAPERLESS_FILENAME_PARSE_TRANSFORMS=[{"pattern":"^([a-z]+)_(\\d{8})_(\\d{6})_([0-9]+)\\.", "repl":"\\2\\3Z - \\4 - \\1."}, {"pattern":"^([a-z]+)_([0-9]+)\\.", "repl":" - \\2 - \\1."}] + .. _guesswork-content: Reading the Document Contents diff --git a/docs/migrating.rst b/docs/migrating.rst index 2c9e91897..c3e702bd5 100644 --- a/docs/migrating.rst +++ b/docs/migrating.rst @@ -92,7 +92,7 @@ files, the ``migrate`` step may not update anything. This is totally normal. Additionally, as new features are added, the ability to control those features is typically added by way of an environment variable set in ``paperless.conf``. You may want to take a look at the ``paperless.conf.example`` file to see if -there's anything new in there compared to what you've got int ``/etc``. +there's anything new in there compared to what you've got in ``/etc``. If you are :ref:`using Docker ` the update process is similar: diff --git a/docs/requirements.rst b/docs/requirements.rst index e528fdae7..54f0d9216 100644 --- a/docs/requirements.rst +++ b/docs/requirements.rst @@ -18,7 +18,7 @@ should work) that has the following software installed: .. _GNU Privacy Guard: https://gnupg.org .. _Tesseract: https://github.com/tesseract-ocr .. _Imagemagick: http://imagemagick.org/ -.. _unpaper: https://www.flameeyes.eu/projects/unpaper +.. _unpaper: https://github.com/unpaper/unpaper .. _libpoppler-cpp-dev: https://poppler.freedesktop.org/ .. _optipng: http://optipng.sourceforge.net/ diff --git a/docs/scanners.rst b/docs/scanners.rst index 8f57a5a7a..9815637b1 100644 --- a/docs/scanners.rst +++ b/docs/scanners.rst @@ -19,15 +19,20 @@ that works right for you based on recommentations from other Paperless users. +---------+----------------+-----+-----+-----+----------------+ | Brother | `MFC-J5910DW`_ | yes | | | `bmsleight`_ | +---------+----------------+-----+-----+-----+----------------+ +| Brother | `MFC-9142CDN`_ | yes | | yes | `REOLDEV`_ | ++---------+----------------+-----+-----+-----+----------------+ | Fujitsu | `ix500`_ | yes | | yes | `eonist`_ | +---------+----------------+-----+-----+-----+----------------+ .. _ADS-1500W: https://www.brother.ca/en/p/ads1500w .. _MFC-J6930DW: https://www.brother.ca/en/p/MFCJ6930DW .. _MFC-J5910DW: https://www.brother.co.uk/printers/inkjet-printers/mfcj5910dw +.. _MFC-9142CDN: https://www.brother.co.uk/printers/laser-printers/mfc9140cdn .. _ix500: http://www.fujitsu.com/us/products/computing/peripheral/scanners/scansnap/ix500/ .. _danielquinn: https://github.com/danielquinn .. _ayounggun: https://github.com/ayounggun .. _bmsleight: https://github.com/bmsleight .. _eonist: https://github.com/eonist +.. _REOLDEV: https://github.com/REOLDEV + diff --git a/docs/setup.rst b/docs/setup.rst index 9c665a607..59f408015 100644 --- a/docs/setup.rst +++ b/docs/setup.rst @@ -43,6 +43,7 @@ You can go multiple routes with setting up and running Paperless: * The `bare metal route`_ * The `docker route`_ + * A suggested `linux containers route`_ The `docker route`_ is quick & easy. @@ -50,10 +51,14 @@ The `docker route`_ is quick & easy. The `bare metal route`_ is a bit more complicated to setup but makes it easier should you want to contribute some code back. +The `linux containers route`_ is quick, but makes alot of assumptions on the +set-up, on the other hand the script could be used to install on a base +debian or ubuntu server. + .. _docker route: setup-installation-docker_ .. _bare metal route: setup-installation-bare-metal_ .. _Docker Machine: https://docs.docker.com/machine/ - +.. _linux containers route: setup-installation-linux-containers_ .. _setup-installation-bare-metal: @@ -82,21 +87,22 @@ Standard (Bare Metal) this is the default. 4. Initialise the SQLite database with ``./manage.py migrate``. -5. Create a user for your Paperless instance with +5. Collect the static files for the webserver with ``./manage.py collectstatic``. +6. Create a user for your Paperless instance with ``./manage.py createsuperuser``. Follow the prompts to create your user. -6. Start the webserver with ``./manage.py runserver :``. +7. Start the webserver with ``./manage.py runserver :``. If no specific IP or port is given, the default is ``127.0.0.1:8000`` also known as http://localhost:8000/. You should now be able to visit your (empty) installation at `Paperless webserver`_ or whatever you chose before. You can login with the user/pass you created in #5. -7. In a separate window, change to the ``src`` directory in this repo again, +8. In a separate window, change to the ``src`` directory in this repo again, but this time, you should start the consumer script with ``./manage.py document_consumer``. -8. Scan something or put a file into the ``CONSUMPTION_DIR``. -9. Wait a few minutes -10. Visit the document list on your webserver, and it should be there, indexed +9. Scan something or put a file into the ``CONSUMPTION_DIR``. +10. Wait a few minutes +11. Visit the document list on your webserver, and it should be there, indexed and downloadable. .. caution:: @@ -126,8 +132,8 @@ Docker Method .. caution:: If you want to use the included ``docker-compose.yml.example`` file, you - need to have at least Docker version **1.10.0** and docker-compose - version **1.6.0**. + need to have at least Docker version **1.12.0** and docker-compose + version **1.9.0**. See the `Docker installation guide`_ on how to install the current version of Docker for your operating system or Linux distribution of @@ -153,7 +159,7 @@ Docker Method If you are using NFS mounts for the consume directory you also need to change the command to turn off inotify as it doesn't work with NFS - `command: ["document_consumer", "--no-inotify"]` + ``command: ["document_consumer", "--no-inotify"]`` 5. Modify ``docker-compose.env`` and adapt the following environment variables: @@ -187,6 +193,13 @@ Docker Method container and thus the one of the consumption directory. Furthermore, you can change the id of the default user as well using ``USERMAP_UID``. + ``PAPERLESS_USE_SSL`` + If you want Paperless to use SSL for the user interface, set this variable + to ``true``. You also need to copy your certificate and key to the ``data`` + directory, named ``ssl.cert`` and ``ssl.key``. + This is not an ideal solution and, if possible, a reverse proxy with nginx + is preferred. + 6. Run ``docker-compose up -d``. This will create and start the necessary containers. 7. To be able to login, you will need a super user. To create it, execute the @@ -200,7 +213,8 @@ Docker Method e-mail address and finally a password. 8. The default ``docker-compose.yml`` exports the webserver on your local port 8000. If you haven't adapted this, you should now be able to visit your - `Paperless webserver`_ at ``http://127.0.0.1:8000``. You can login with the + `Paperless webserver`_ at ``http://127.0.0.1:8000`` (or + ``https://127.0.0.1:8000`` if you enabled SSL). You can login with the user and password you just created. 9. Add files to consumption directory the way you prefer to. Following are two possible options: @@ -326,7 +340,7 @@ and mod_wsgi, with a Paperless installation in ``/home/paperless/``: WSGIScriptAlias / /home/paperless/paperless/src/paperless/wsgi.py - WSGIDaemonProcess example.com user=paperless group=paperless threads=5 python-path=/home/paperless/paperless/src:/home/paperless/.env/lib/python3.4/site-packages + WSGIDaemonProcess example.com user=paperless group=paperless threads=5 python-path=/home/paperless/paperless/src:/home/paperless/.env/lib/python3.6/site-packages WSGIProcessGroup example.com @@ -484,3 +498,45 @@ If you're using Docker, you can set a restart-policy_ in the Docker daemon. .. _restart-policy: https://docs.docker.com/engine/reference/commandline/run/#restart-policies-restart + + +.. _setup-installation-linux-containers: + +Suggested way for Linux Container Method +++++++++++++++++++++++++++++++++++++++++ + +This method uses some rigid assumptions, for the best set-up:- + + * Ubuntu lts as the container + * Apache as the webserver + * proftpd as ftp server + * ftpupload as the ftp user + * paperless as the main user for website + * http://paperless.lan is the desired lan url + * LXC set to give ip addresses on your lan + +This could also be used as an install on a base debain/ubuntu server, +if the above assumptions are acceptable. + +1. Install lxc + + +2. Lanch paperless container + +.. code:: bash + + $ lxc launch ubuntu: paperless + +3. Run install script within container + +.. code:: bash + + $ lxc exec paperless -- sh -c "wget https://raw.githubusercontent.com/the-paperless-project/paperless/master/docs/examples/lxc/lxc-install.sh && /bin/bash lxc-install.sh --email" + +The script will ask you for an ftpupload password. +As well as the super-user for paperless web front-end. +After around 10 mins, http://paperless.lan is ready and +ftp://paperless.lan with user: ftpupload + +See the `Installation recording <_static/lxc-install.svg>`_. + diff --git a/docs/troubleshooting.rst b/docs/troubleshooting.rst index 7c5d87ca5..944977f1d 100644 --- a/docs/troubleshooting.rst +++ b/docs/troubleshooting.rst @@ -72,4 +72,4 @@ with a DPI of 300, then merging the images into the single PDF with For more information on this and situations like it, you should take a look at `Issue #118`_ as that's where this tip originated. -.. _Issue #118: https://github.com/the-paperless-project/paperless/issues/118 +.. _Issue #118: https://github.com/the-paperless-project/paperless/issues/118 \ No newline at end of file diff --git a/docs/utilities.rst b/docs/utilities.rst index e95ef4725..3c7e8d542 100644 --- a/docs/utilities.rst +++ b/docs/utilities.rst @@ -193,18 +193,19 @@ instructions above to do the import. .. _utilities-retagger: -The Re-tagger -------------- +Re-running your tagging and correspondent matchers +-------------------------------------------------- -Say you've imported a few hundred documents and now want to introduce a tag -and apply its matching to all of the currently-imported docs. This problem is -common enough that there's a tool for it. +Say you've imported a few hundred documents and now want to introduce +a tag or set up a new correspondent, and apply its matching to all of +the currently-imported docs. This problem is common enough that +there are tools for it. .. _utilities-retagger-howto: -How to Use It -............. +How to Do It +............ This too is done via the ``manage.py`` script: @@ -212,10 +213,16 @@ This too is done via the ``manage.py`` script: $ /path/to/paperless/src/manage.py document_retagger -That's it. It'll loop over all of the documents in your database and attempt -to match all of your tags to them. If one matches, it'll be applied. And -don't worry, you can run this as often as you like, it won't double-tag -a document. +Run this after changing or adding tagging rules. It'll loop over all +of the documents in your database and attempt to match all of your +tags to them. If one matches, it'll be applied. And don't worry, you +can run this as often as you like, it won't double-tag a document. + +.. code:: bash + + $ /path/to/paperless/src/manage.py document_correspondents + +This is the similar command to run after adding or changing a correspondent. .. _utilities-encyption: @@ -232,10 +239,10 @@ Basic Syntax Again we'll use the ``manage.py`` script, passing ``change_storage_type``: -.. code:: bash +.. code:: console $ /path/to/paperless/src/manage.py change_storage_type --help - usage: manage.py change_storage_type [-h] [--version] [-v {0,1,2,3}] + usage: manage.py change_storage_type [-h] [--version] [-v {0,1,2,3}] [--settings SETTINGS] [--pythonpath PYTHONPATH] [--traceback] [--no-color] [--passphrase PASSPHRASE] diff --git a/management/commands/create_superuser_with_password.py b/management/commands/create_superuser_with_password.py new file mode 100644 index 000000000..830c1e167 --- /dev/null +++ b/management/commands/create_superuser_with_password.py @@ -0,0 +1,38 @@ +from django.contrib.auth.management.commands import createsuperuser +from django.core.management import CommandError + + +class Command(createsuperuser.Command): + help = 'Crate a superuser, and allow password to be provided' + + def add_arguments(self, parser): + super(Command, self).add_arguments(parser) + parser.add_argument( + '--password', dest='password', default=None, + help='Specifies the password for the superuser.', + ) + parser.add_argument( + '--preserve', dest='preserve', default=False, action='store_true', + help='Exit normally if the user already exists.', + ) + + def handle(self, *args, **options): + password = options.get('password') + username = options.get('username') + database = options.get('database') + + if password and not username: + raise CommandError("--username is required if specifying --password") + + if username and options.get('preserve'): + exists = self.UserModel._default_manager.db_manager(database).filter(username=username).exists() + if exists: + self.stdout.write("User exists, exiting normally due to --preserve") + return + + super(Command, self).handle(*args, **options) + + if password: + user = self.UserModel._default_manager.db_manager(database).get(username=username) + user.set_password(password) + user.save() diff --git a/paperless.conf.example b/paperless.conf.example index aeb0bbace..208e6cce0 100644 --- a/paperless.conf.example +++ b/paperless.conf.example @@ -71,6 +71,17 @@ PAPERLESS_CONSUME_MAIL_PASS="" # ignored. PAPERLESS_EMAIL_SECRET="" +# Specify a filename format for the document (directories are supported) +# Use the following placeholders: +# * {correspondent} +# * {title} +# * {created} +# * {added} +# * {tags[KEY]} If your tags conform to key_value or key-value +# * {tags[INDEX]} If your tags are strings, select the tag by index +# Uniqueness of filenames is ensured, as an incrementing counter is attached +# to each filename. +#PAPERLESS_FILENAME_FORMAT="" ############################################################################### #### Security #### @@ -152,6 +163,23 @@ PAPERLESS_EMAIL_SECRET="" # as normal. #PAPERLESS_FILENAME_DATE_ORDER="YMD" +# Sometimes devices won't create filenames which can be parsed properly +# by the filename parser (see +# https://paperless.readthedocs.io/en/latest/guesswork.html). +# +# This setting allows to specify a list of transformations +# in regular expression syntax, which are passed in order to re.sub. +# Transformation stops after the first match, so at most one transformation +# is applied. +# +# Syntax is a JSON array of dictionaries containing "pattern" and "repl" +# as keys. +# +# The example below transforms filenames created by a Brother ADS-2400N +# document scanner in its standard configuration `Name_Date_Count', so that +# count is used as title, name as tag and date can be parsed by paperless. +#PAPERLESS_FILENAME_PARSE_TRANSFORMS=[{"pattern":"^([a-z]+)_(\\d{8})_(\\d{6})_([0-9]+)\\.", "repl":"\\2\\3Z - \\4 - \\1."}] + # # The following values use sensible defaults for modern systems, but if you're # running Paperless on a low-resource device (like a Raspberry Pi), modifying diff --git a/requirements.txt b/requirements.txt old mode 100755 new mode 100644 index 818b33a48..64201f9d7 --- a/requirements.txt +++ b/requirements.txt @@ -1,12 +1,13 @@ -i https://pypi.python.org/simple alabaster==0.7.12 apipkg==1.5 -atomicwrites==1.2.1 -attrs==18.2.0 -babel==2.6.0 -certifi==2018.11.29 +atomicwrites==1.3.0 +attrs==19.1.0 +babel==2.7.0 +brotli==1.0.7 +certifi==2019.6.16 chardet==3.0.4 -coverage==4.5.2 +coverage==4.5.4 coveralls==1.5.1 dateparser==0.7.0 django-cors-headers==2.4.0 @@ -17,37 +18,38 @@ django==2.0.10 djangoql==0.12.3 djangorestframework==3.9.1 docopt==0.6.2 -docutils==0.14 -execnet==1.5.0 +docutils==0.15.2 +execnet==1.6.1 factory-boy==2.11.1 -faker==1.0.2 -filelock==3.0.10 +faker==2.0.0 +filelock==3.0.12 filemagic==1.6 fuzzywuzzy[speedup]==0.15.0 -gunicorn==19.9.0 +gunicorn==20.0.4 idna==2.8 imagesize==1.1.0 +importlib-metadata==0.19 inotify-simple==1.1.8; sys_platform == 'linux' -jinja2==2.10 +jinja2==2.10.1 langdetect==1.0.7 +markupsafe==1.1.1 +more-itertools==7.2.0 numpy==1.15.1 -markupsafe==1.1.0 -more-itertools==5.0.0 -packaging==19.0 +packaging==19.1 pdftotext==2.1.1 pillow==5.4.1 -pluggy==0.8.1 +pluggy==0.12.0 ply==3.11 -psycopg2==2.7.7 -py==1.7.0 +psycopg2==2.8.4 +py==1.8.0 pycodestyle==2.4.0 -pygments==2.3.1 +pygments==2.4.2 pyocr==0.5.3 -pyparsing==2.3.1 +pyparsing==2.4.2 pytest-cov==2.6.1 pytest-django==3.4.5 pytest-env==0.6.2 -pytest-forked==1.0.1 +pytest-forked==1.0.2 pytest-sugar==0.9.2 pytest-xdist==1.26.0 pytest==4.1.1 @@ -58,16 +60,24 @@ python-dotenv==0.10.1 python-gnupg==0.4.4 python-levenshtein==0.12.0 pytz==2018.9 -regex==2019.1.24 -requests==2.21.0 +regex==2019.6.8 +requests==2.22.0 six==1.12.0 -snowballstemmer==1.2.1 +snowballstemmer==1.9.0 sphinx==1.8.3 -sphinxcontrib-websupport==1.1.0 +sphinxcontrib-applehelp==1.0.1 +sphinxcontrib-devhelp==1.0.1 +sphinxcontrib-htmlhelp==1.0.2 +sphinxcontrib-jsmath==1.0.1 +sphinxcontrib-qthelp==1.0.2 +sphinxcontrib-serializinghtml==1.1.3 termcolor==1.1.0 text-unidecode==1.2 toml==0.10.0 tox==3.7.0 -tzlocal==1.5.1 -urllib3==1.24.1 -virtualenv==16.3.0 +tzlocal==2.0.0 +urllib3==1.25.3 +virtualenv==16.7.2 +wcwidth==0.1.7 +whitenoise==4.1.3 +zipp==0.5.2 diff --git a/scripts/docker-entrypoint.sh b/scripts/docker-entrypoint.sh index 5cfcd4023..2028413d1 100644 --- a/scripts/docker-entrypoint.sh +++ b/scripts/docker-entrypoint.sh @@ -10,7 +10,7 @@ map_uidgid() { if [[ ${USERMAP_NEW_UID} != "${USERMAP_ORIG_UID}" || ${USERMAP_NEW_GID} != "${USERMAP_ORIG_GID}" ]]; then echo "Mapping UID and GID for paperless:paperless to $USERMAP_NEW_UID:$USERMAP_NEW_GID" usermod -u "${USERMAP_NEW_UID}" paperless - groupmod -g "${USERMAP_NEW_GID}" paperless + groupmod -o -g "${USERMAP_NEW_GID}" paperless fi } @@ -99,7 +99,23 @@ if [[ "$1" != "/"* ]]; then install_languages "$PAPERLESS_OCR_LANGUAGES" fi - exec sudo -HEu paperless "/usr/src/paperless/src/manage.py" "$@" + if [[ "$1" = "gunicorn" ]]; then + shift + EXTRA_PARAMS="" + SSL_KEY_PATH="/usr/src/paperless/data/ssl.key" + SSL_CERT_PATH="/usr/src/paperless/data/ssl.cert" + if [ "${PAPERLESS_USE_SSL}" = "true" ]; then + if [ -f "${SSL_KEY_PATH}" ] && [ -f "${SSL_CERT_PATH}" ]; then + EXTRA_PARAMS="--certfile=${SSL_CERT_PATH} --keyfile=${SSL_KEY_PATH}" + else + echo "Error: Could not find certfile in ${SSL_CERT_PATH} or keyfile in ${SSL_KEY_PATH}, but \$PAPERLESS_USE_SSL is true. Starting without SSL enabled." + fi + fi + cd /usr/src/paperless/src/ && \ + exec sudo -HEu paperless /usr/bin/gunicorn -c /usr/src/paperless/gunicorn.conf ${EXTRA_PARAMS} "$@" paperless.wsgi + else + exec sudo -HEu paperless "/usr/src/paperless/src/manage.py" "$@" + fi fi exec "$@" diff --git a/scripts/gunicorn.conf b/scripts/gunicorn.conf index 8d2dcc6ad..a2f456079 100644 --- a/scripts/gunicorn.conf +++ b/scripts/gunicorn.conf @@ -1,6 +1,6 @@ bind = '127.0.0.1:8000' backlog = 2048 -workers = 1 +workers = 3 worker_class = 'sync' worker_connections = 1000 timeout = 20 diff --git a/scripts/paperless-webserver.service b/scripts/paperless-webserver.service index 771b8301f..8ff746be2 100644 --- a/scripts/paperless-webserver.service +++ b/scripts/paperless-webserver.service @@ -1,5 +1,7 @@ [Unit] Description=Paperless webserver +After=network.target +Wants=network.target [Service] User=paperless diff --git a/src/documents/consumer.py b/src/documents/consumer.py index 5e95421cc..54979156a 100755 --- a/src/documents/consumer.py +++ b/src/documents/consumer.py @@ -94,6 +94,11 @@ class Consumer: ignored_files.append(file) else: files.append(file) + else: + self.logger.warning( + "Skipping %s as it is not a file", + entry.path + ) if not files: return @@ -234,6 +239,9 @@ class Consumer: self._write(document, doc, document.source_path) self._write(document, thumbnail, document.thumbnail_path) + document.set_filename(document.source_filename) + document.save() + self.log("info", "Completed") return document diff --git a/src/documents/management/commands/document_consumer.py b/src/documents/management/commands/document_consumer.py index 6f731372f..8a6ccfcdd 100644 --- a/src/documents/management/commands/document_consumer.py +++ b/src/documents/management/commands/document_consumer.py @@ -26,6 +26,7 @@ class Command(BaseCommand): def __init__(self, *args, **kwargs): self.verbosity = 0 + self.logger = logging.getLogger(__name__) self.file_consumer = None self.mail_fetcher = None @@ -138,6 +139,11 @@ class Command(BaseCommand): file = os.path.join(directory, event.name) if os.path.isfile(file): self.file_consumer.try_consume_file(file) + else: + self.logger.warning( + "Skipping %s as it is not a file", + file + ) else: break diff --git a/src/documents/management/commands/document_renamer.py b/src/documents/management/commands/document_renamer.py new file mode 100644 index 000000000..d7d77a111 --- /dev/null +++ b/src/documents/management/commands/document_renamer.py @@ -0,0 +1,24 @@ +from django.core.management.base import BaseCommand + +from documents.models import Document, Tag + +from ...mixins import Renderable + + +class Command(Renderable, BaseCommand): + + help = """ + This will rename all documents to match the latest filename format. + """.replace(" ", "") + + def __init__(self, *args, **kwargs): + self.verbosity = 0 + BaseCommand.__init__(self, *args, **kwargs) + + def handle(self, *args, **options): + + self.verbosity = options["verbosity"] + + for document in Document.objects.all(): + # Saving the document again will generate a new filename and rename + document.save() diff --git a/src/documents/migrations/0023_document_current_filename.py b/src/documents/migrations/0023_document_current_filename.py new file mode 100644 index 000000000..be78ea863 --- /dev/null +++ b/src/documents/migrations/0023_document_current_filename.py @@ -0,0 +1,37 @@ +# Generated by Django 2.0.10 on 2019-04-26 18:57 + +from django.db import migrations, models + + +def set_filename(apps, schema_editor): + Document = apps.get_model("documents", "Document") + for doc in Document.objects.all(): + file_name = "{:07}.{}".format(doc.pk, doc.file_type) + if doc.storage_type == "gpg": + file_name += ".gpg" + + # Set filename + doc.filename = file_name + + # Save document + doc.save() + + +class Migration(migrations.Migration): + + dependencies = [ + ('documents', '0022_auto_20181007_1420'), + ] + + operations = [ + migrations.AddField( + model_name='document', + name='filename', + field=models.FilePathField(default=None, + null=True, + editable=False, + help_text='Current filename in storage', + max_length=256), + ), + migrations.RunPython(set_filename) + ] diff --git a/src/documents/models.py b/src/documents/models.py index bd5cf161b..f14f8bd20 100755 --- a/src/documents/models.py +++ b/src/documents/models.py @@ -7,12 +7,14 @@ import uuid from collections import OrderedDict import dateutil.parser +from django.dispatch import receiver from django.conf import settings from django.db import models from django.template.defaultfilters import slugify from django.utils import timezone from django.utils.text import slugify from fuzzywuzzy import fuzz +from collections import defaultdict from .managers import LogManager @@ -167,6 +169,14 @@ class Document(models.Model): added = models.DateTimeField( default=timezone.now, editable=False, db_index=True) + filename = models.FilePathField( + max_length=256, + editable=False, + default=None, + null=True, + help_text="Current filename in storage" + ) + archive_serial_number = models.IntegerField( blank=True, null=True, @@ -188,18 +198,125 @@ class Document(models.Model): return "{}: {}".format(created, self.correspondent or self.title) return str(created) + def find_renamed_document(self, subdirectory=""): + suffix = "%07i.%s" % (self.pk, self.file_type) + + # Append .gpg for encrypted files + if self.storage_type == self.STORAGE_TYPE_GPG: + suffix += ".gpg" + + # Go up in the directory hierarchy and try to delete all directories + root = os.path.normpath(Document.filename_to_path(subdirectory)) + + for filename in os.listdir(root): + if filename.endswith(suffix): + return os.path.join(subdirectory, filename) + + fullname = os.path.join(subdirectory, filename) + if os.path.isdir(Document.filename_to_path(fullname)): + return self.find_renamed_document(fullname) + + return None + + @property + def source_filename(self): + # Initial filename generation (for new documents) + if self.filename is None: + self.filename = self.generate_source_filename() + + # Check if document is still available under filename + elif not os.path.isfile(Document.filename_to_path(self.filename)): + recovered_filename = self.find_renamed_document() + + # If we have found the file so update the filename + if recovered_filename is not None: + logger = logging.getLogger(__name__) + logger.warning("Filename of document " + str(self.id) + + " has changed and was successfully updated") + self.filename = recovered_filename + + # Remove all empty subdirectories from MEDIA_ROOT + Document.delete_all_empty_subdirectories( + Document.filename_to_path("")) + else: + logger = logging.getLogger(__name__) + logger.error("File of document " + str(self.id) + " has " + + "gone and could not be recovered") + + return self.filename + + @staticmethod + def many_to_dictionary(field): + # Converts ManyToManyField to dictionary by assuming, that field + # entries contain an _ or - which will be used as a delimiter + mydictionary = dict() + + for index, t in enumerate(field.all()): + # Populate tag names by index + mydictionary[index] = slugify(t.name) + + # Find delimiter + delimiter = t.name.find('_') + + if delimiter == -1: + delimiter = t.name.find('-') + + if delimiter == -1: + continue + + key = t.name[:delimiter] + value = t.name[delimiter+1:] + + mydictionary[slugify(key)] = slugify(value) + + return mydictionary + + def generate_source_filename(self): + # Create filename based on configured format + if settings.PAPERLESS_FILENAME_FORMAT is not None: + tags = defaultdict(lambda: slugify(None), + self.many_to_dictionary(self.tags)) + path = settings.PAPERLESS_FILENAME_FORMAT.format( + correspondent=slugify(self.correspondent), + title=slugify(self.title), + created=slugify(self.created), + added=slugify(self.added), + tags=tags) + else: + path = "" + + # Always append the primary key to guarantee uniqueness of filename + if len(path) > 0: + filename = "%s-%07i.%s" % (path, self.pk, self.file_type) + else: + filename = "%07i.%s" % (self.pk, self.file_type) + + # Append .gpg for encrypted files + if self.storage_type == self.STORAGE_TYPE_GPG: + filename += ".gpg" + + return filename + + def create_source_directory(self): + new_filename = self.generate_source_filename() + + # Determine the full "target" path + dir_new = Document.filename_to_path(os.path.dirname(new_filename)) + + # Create new path + os.makedirs(dir_new, exist_ok=True) + @property def source_path(self): + return Document.filename_to_path(self.source_filename) - file_name = "{:07}.{}".format(self.pk, self.file_type) - if self.storage_type == self.STORAGE_TYPE_GPG: - file_name += ".gpg" - + @staticmethod + def filename_to_path(filename): return os.path.join( settings.MEDIA_ROOT, "documents", "originals", - file_name + filename ) @property @@ -236,6 +353,125 @@ class Document(models.Model): def thumbnail_url(self): return reverse("fetch", kwargs={"kind": "thumb", "pk": self.pk}) + def set_filename(self, filename): + if os.path.isfile(Document.filename_to_path(filename)): + self.filename = filename + + @staticmethod + def try_delete_empty_directories(directory): + # Go up in the directory hierarchy and try to delete all directories + directory = os.path.normpath(directory) + root = os.path.normpath(Document.filename_to_path("")) + + while directory != root: + # Try to delete the current directory + try: + os.rmdir(directory) + except os.error: + # Directory not empty, no need to go further up + return + + # Cut off actual directory and go one level up + directory, _ = os.path.split(directory) + directory = os.path.normpath(directory) + + @staticmethod + def delete_all_empty_subdirectories(directory): + # Go through all folders and try to delete all directories + root = os.path.normpath(Document.filename_to_path(directory)) + + for filename in os.listdir(root): + fullname = os.path.join(directory, filename) + + if not os.path.isdir(Document.filename_to_path(fullname)): + continue + + # Go into subdirectory to see, if there is more to delete + Document.delete_all_empty_subdirectories( + os.path.join(directory, filename)) + + # Try to delete the directory + try: + os.rmdir(Document.filename_to_path(fullname)) + continue + except os.error: + # Directory not empty, no need to go further up + continue + + +@receiver(models.signals.m2m_changed, sender=Document.tags.through) +@receiver(models.signals.post_save, sender=Document) +def update_filename(sender, instance, **kwargs): + # Skip if document has not been saved yet + if instance.filename is None: + return + + # Check is file exists and update filename otherwise + if not os.path.isfile(Document.filename_to_path(instance.filename)): + instance.filename = instance.source_filename + + # Build the new filename + new_filename = instance.generate_source_filename() + + # If the filename is the same, then nothing needs to be done + if instance.filename == new_filename: + return + + # Determine the full "target" path + path_new = instance.filename_to_path(new_filename) + dir_new = instance.filename_to_path(os.path.dirname(new_filename)) + + # Create new path + instance.create_source_directory() + + # Determine the full "current" path + path_current = instance.filename_to_path(instance.source_filename) + + # Move file + try: + os.rename(path_current, path_new) + except PermissionError: + # Do not update filename in object + return + except FileNotFoundError: + logger = logging.getLogger(__name__) + logger.error("Renaming of document " + str(instance.id) + " failed " + + "as file " + instance.filename + " was no longer present") + return + + # Delete empty directory + old_dir = os.path.dirname(instance.filename) + old_path = instance.filename_to_path(old_dir) + Document.try_delete_empty_directories(old_path) + + instance.filename = new_filename + + # Save instance + # This will not cause a cascade of post_save signals, as next time + # nothing needs to be renamed + instance.save() + + +@receiver(models.signals.post_delete, sender=Document) +def delete_files(sender, instance, **kwargs): + if instance.filename is None: + return + + # Remove the document + old_file = instance.filename_to_path(instance.filename) + + try: + os.remove(old_file) + except FileNotFoundError: + logger = logging.getLogger(__name__) + logger.warning("Deleted document " + str(instance.id) + " but file " + + old_file + " was no longer present") + + # And remove the directory (if applicable) + old_dir = os.path.dirname(instance.filename) + old_path = instance.filename_to_path(old_dir) + Document.try_delete_empty_directories(old_path) + class Log(models.Model): @@ -405,8 +641,18 @@ class FileInfo: ".<suffix>" """ + filename = os.path.basename(path) + + # Mutate filename in-place before parsing its components + # by applying at most one of the configured transformations. + for (pattern, repl) in settings.FILENAME_PARSE_TRANSFORMS: + (filename, count) = pattern.subn(repl, filename) + if count: + break + + # Parse filename components. for regex in cls.REGEXES.values(): - m = regex.match(os.path.basename(path)) + m = regex.match(filename) if m: properties = m.groupdict() cls._mangle_property(properties, "created") diff --git a/src/documents/parsers.py b/src/documents/parsers.py index 142ebba68..c0a80a55d 100644 --- a/src/documents/parsers.py +++ b/src/documents/parsers.py @@ -108,7 +108,7 @@ class DocumentParser: try: date = __parser(date_string, self.FILENAME_DATE_ORDER) - except TypeError: + except (TypeError, ValueError): # Skip all matches that do not parse to a proper date continue @@ -134,7 +134,7 @@ class DocumentParser: try: date = __parser(date_string, self.DATE_ORDER) - except TypeError: + except (TypeError, ValueError): # Skip all matches that do not parse to a proper date continue diff --git a/src/documents/templates/admin/documents/document/change_form.html b/src/documents/templates/admin/documents/document/change_form.html index a255006eb..80595a0e2 100644 --- a/src/documents/templates/admin/documents/document/change_form.html +++ b/src/documents/templates/admin/documents/document/change_form.html @@ -12,6 +12,10 @@ {% block content %} {{ block.super }} +<div class="side-preview"> + <h2>Preview</h2> + <object data="/fetch/preview/{{object_id}}"></object> +</div> {% if file_type in "pdf jpg png" %} @@ -47,6 +51,37 @@ {% endblock content %} +{% block extrastyle %} +{{ block.super }} +<style> +.side-preview { + width: 100%; + height: 800px; + clear: both; +} + +.side-preview object { + height: 100%; + width: 100%; +} + +@media screen and (min-width: 1500px) { + #content-main { + width: 50%; + } + #footer { + padding: 0; + } + .side-preview { + float: right; + width: 40%; + height: 80vh; + clear: none; + } +} +</style> +{% endblock %} + {% block footer %} {{ block.super }} diff --git a/src/documents/tests/test_consumer.py b/src/documents/tests/test_consumer.py index 3f5c69774..512447741 100644 --- a/src/documents/tests/test_consumer.py +++ b/src/documents/tests/test_consumer.py @@ -1,3 +1,5 @@ +import re + from django.test import TestCase from unittest import mock from tempfile import TemporaryDirectory @@ -372,3 +374,79 @@ class TestFieldPermutations(TestCase): info = FileInfo.from_path("/path/to/06112017Z - title.pdf") self.assertEqual(info.title, "title") self.assertIsNone(info.created) + + def test_filename_parse_transforms(self): + + path = "/some/path/to/tag1,tag2_20190908_180610_0001.pdf" + all_patt = re.compile("^.*$") + none_patt = re.compile("$a") + exact_patt = re.compile("^([a-z0-9,]+)_(\\d{8})_(\\d{6})_([0-9]+)\\.") + repl1 = " - \\4 - \\1." # (empty) corrspondent, title and tags + repl2 = "\\2Z - " + repl1 # creation date + repl1 + + # No transformations configured (= default) + info = FileInfo.from_path(path) + self.assertEqual(info.title, "tag1,tag2_20190908_180610_0001") + self.assertEqual(info.extension, "pdf") + self.assertEqual(info.tags, ()) + self.assertIsNone(info.created) + + # Pattern doesn't match (filename unaltered) + with self.settings( + FILENAME_PARSE_TRANSFORMS=[(none_patt, "none.gif")]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "tag1,tag2_20190908_180610_0001") + self.assertEqual(info.extension, "pdf") + + # Simple transformation (match all) + with self.settings( + FILENAME_PARSE_TRANSFORMS=[(all_patt, "all.gif")]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "all") + self.assertEqual(info.extension, "gif") + + # Multiple transformations configured (first pattern matches) + with self.settings( + FILENAME_PARSE_TRANSFORMS=[ + (all_patt, "all.gif"), + (all_patt, "anotherall.gif")]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "all") + self.assertEqual(info.extension, "gif") + + # Multiple transformations configured (second pattern matches) + with self.settings( + FILENAME_PARSE_TRANSFORMS=[ + (none_patt, "none.gif"), + (all_patt, "anotherall.gif")]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "anotherall") + self.assertEqual(info.extension, "gif") + + # Complex transformation without date in replacement string + with self.settings( + FILENAME_PARSE_TRANSFORMS=[(exact_patt, repl1)]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "0001") + self.assertEqual(info.extension, "pdf") + self.assertEqual(len(info.tags), 2) + self.assertEqual(info.tags[0].slug, "tag1") + self.assertEqual(info.tags[1].slug, "tag2") + self.assertIsNone(info.created) + + # Complex transformation with date in replacement string + with self.settings( + FILENAME_PARSE_TRANSFORMS=[ + (none_patt, "none.gif"), + (exact_patt, repl2), # <-- matches + (exact_patt, repl1), + (all_patt, "all.gif")]): + info = FileInfo.from_path(path) + self.assertEqual(info.title, "0001") + self.assertEqual(info.extension, "pdf") + self.assertEqual(len(info.tags), 2) + self.assertEqual(info.tags[0].slug, "tag1") + self.assertEqual(info.tags[1].slug, "tag2") + self.assertEqual(info.created.year, 2019) + self.assertEqual(info.created.month, 9) + self.assertEqual(info.created.day, 8) diff --git a/src/documents/tests/test_file_handling.py b/src/documents/tests/test_file_handling.py new file mode 100644 index 000000000..d55a50cd2 --- /dev/null +++ b/src/documents/tests/test_file_handling.py @@ -0,0 +1,559 @@ +import datetime +import os +import shutil +from unittest import mock +from uuid import uuid4 +from pathlib import Path +from shutil import rmtree + +from dateutil import tz +from django.test import TestCase, override_settings + +from django.utils.text import slugify +from ..models import Tag, Document, Correspondent +from django.conf import settings + + +class TestDate(TestCase): + deletion_list = [] + + def add_to_deletion_list(self, dirname): + self.deletion_list.append(dirname) + + def setUp(self): + folder = "/tmp/paperless-tests-{}".format(str(uuid4())[:8]) + os.makedirs(folder + "/documents/originals") + storage_override = override_settings(MEDIA_ROOT=folder) + storage_override.enable() + self.add_to_deletion_list(folder) + + def tearDown(self): + for dirname in self.deletion_list: + shutil.rmtree(dirname, ignore_errors=True) + + @override_settings(PAPERLESS_FILENAME_FORMAT="") + def test_source_filename(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + self.assertEqual(document.source_filename, "0000001.pdf") + + document.filename = "test.pdf" + self.assertEqual(document.source_filename, "test.pdf") + + @override_settings(PAPERLESS_FILENAME_FORMAT="") + def test_generate_source_filename(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + self.assertEqual(document.generate_source_filename(), "0000001.pdf") + + document.storage_type = Document.STORAGE_TYPE_GPG + self.assertEqual(document.generate_source_filename(), + "0000001.pdf.gpg") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_file_renaming(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Test source_path + self.assertEqual(document.source_path, settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf") + + # Enable encryption and check again + document.storage_type = Document.STORAGE_TYPE_GPG + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf.gpg") + document.save() + + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), True) + + # Set a correspondent and save the document + document.correspondent = Correspondent.objects.get_or_create( + name="test")[0] + document.save() + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/test"), True) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), False) + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/test/test-0000001.pdf.gpg"), True) + self.assertEqual(document.generate_source_filename(), + "test/test-0000001.pdf.gpg") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_file_renaming_missing_permissions(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Test source_path + self.assertEqual(document.source_path, settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf") + + # Make the folder read- and execute-only (no writing and no renaming) + os.chmod(settings.MEDIA_ROOT + "/documents/originals/none", 0o555) + + # Set a correspondent and save the document + document.correspondent = Correspondent.objects.get_or_create( + name="test")[0] + document.save() + + # Check proper handling of files + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/none/none-0000001.pdf"), True) + self.assertEqual(document.source_filename, + "none/none-0000001.pdf") + + os.chmod(settings.MEDIA_ROOT + "/documents/originals/none", 0o777) + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_document_delete(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Ensure file deletion after delete + document.delete() + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf"), False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), False) + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_document_delete_nofile(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_directory_not_empty(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + Path(document.source_path + "test").touch() + + # Set a correspondent and save the document + document.correspondent = Correspondent.objects.get_or_create( + name="test")[0] + document.save() + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/test"), True) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), True) + + # Cleanup + os.remove(settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdftest") + os.rmdir(settings.MEDIA_ROOT + "/documents/originals/none") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[type]}") + def test_tags_with_underscore(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Add tag to document + document.tags.create(name="type_demo") + document.tags.create(name="foo_bar") + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "demo-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[type]}") + def test_tags_with_dash(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Add tag to document + document.tags.create(name="type-demo") + document.tags.create(name="foo-bar") + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "demo-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[type]}") + def test_tags_malformed(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Add tag to document + document.tags.create(name="type:demo") + document.tags.create(name="foo:bar") + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[0]}") + def test_tags_all(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Add tag to document + document.tags.create(name="demo") + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "demo-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[0]}") + def test_tags_out_of_bounds_0(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[10000000]}") + def test_tags_out_of_bounds_10000000(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{tags[99]}") + def test_tags_out_of_bounds_99(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + document.delete() + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}/{correspondent}") + def test_nested_directory_cleanup(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none/none"), True) + + document.delete() + + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + + "/documents/originals/none/none/none-0000001.pdf"), + False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none/none"), False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals"), True) + + @override_settings(PAPERLESS_FILENAME_FORMAT=None) + def test_format_none(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + self.assertEqual(document.generate_source_filename(), "0000001.pdf") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_document_renamed(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Test source_path + self.assertEqual(document.source_path, settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf") + + # Rename the document "illegaly" + os.makedirs(settings.MEDIA_ROOT + "/documents/originals/test") + os.rename(settings.MEDIA_ROOT + "/documents/originals/" + + "none/none-0000001.pdf", + settings.MEDIA_ROOT + "/documents/originals/" + + "test/test-0000001.pdf") + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/test/test-0000001.pdf"), True) + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/none/none-0000001.pdf"), False) + + # Set new correspondent and expect document to be saved properly + document.correspondent = Correspondent.objects.get_or_create( + name="foo")[0] + document.save() + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/foo/foo-0000001.pdf"), True) + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/foo"), True) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/test"), False) + self.assertEqual(document.generate_source_filename(), + "foo/foo-0000001.pdf") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_document_renamed_encrypted(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_GPG + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf.gpg") + document.create_source_directory() + Path(document.source_path).touch() + + # Test source_path + self.assertEqual(document.source_path, settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf.gpg") + + # Rename the document "illegaly" + os.makedirs(settings.MEDIA_ROOT + "/documents/originals/test") + os.rename(settings.MEDIA_ROOT + "/documents/originals/" + + "none/none-0000001.pdf.gpg", + settings.MEDIA_ROOT + "/documents/originals/" + + "test/test-0000001.pdf.gpg") + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/test/test-0000001.pdf.gpg"), True) + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/none/none-0000001.pdf"), False) + + # Set new correspondent and expect document to be saved properly + document.correspondent = Correspondent.objects.get_or_create( + name="foo")[0] + document.save() + self.assertEqual(os.path.isfile(settings.MEDIA_ROOT + "/documents/" + + "originals/foo/foo-0000001.pdf.gpg"), True) + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/foo"), True) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), False) + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/test"), False) + self.assertEqual(document.generate_source_filename(), + "foo/foo-0000001.pdf.gpg") + + def test_delete_all_empty_subdirectories(self): + # Create our working directory + tmp = "/tmp/paperless-tests-{}".format(str(uuid4())[:8]) + os.makedirs(tmp) + self.add_to_deletion_list(tmp) + + os.makedirs(os.path.join(tmp, "empty")) + os.makedirs(os.path.join(tmp, "empty", "subdirectory")) + + os.makedirs(os.path.join(tmp, "notempty")) + Path(os.path.join(tmp, "notempty", "file")).touch() + + Document.delete_all_empty_subdirectories(tmp) + + self.assertEqual(os.path.isdir(os.path.join(tmp, "notempty")), True) + self.assertEqual(os.path.isdir(os.path.join(tmp, "empty")), False) + self.assertEqual(os.path.isfile( + os.path.join(tmp, "notempty", "file")), True) + + def test_try_delete_empty_directories(self): + # Create our working directory + tmp = "/tmp/paperless-tests-{}".format(str(uuid4())[:8]) + os.makedirs(tmp) + self.add_to_deletion_list(tmp) + + os.makedirs(os.path.join(tmp, "notempty")) + Path(os.path.join(tmp, "notempty", "file")).touch() + os.makedirs(os.path.join(tmp, "notempty", "empty")) + + Document.try_delete_empty_directories( + os.path.join(tmp, "notempty", "empty")) + self.assertEqual(os.path.isdir(os.path.join(tmp, "notempty")), True) + self.assertEqual(os.path.isfile( + os.path.join(tmp, "notempty", "file")), True) + self.assertEqual(os.path.isdir( + os.path.join(tmp, "notempty", "empty")), False) + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_document_accidentally_deleted(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Test source_path + self.assertEqual(document.source_path, settings.MEDIA_ROOT + + "/documents/originals/none/none-0000001.pdf") + + # Delete the document "illegaly" + os.remove(settings.MEDIA_ROOT + "/documents/originals/" + + "none/none-0000001.pdf") + + # Set new correspondent and expect document to be saved properly + document.correspondent = Correspondent.objects.get_or_create( + name="foo")[0] + document.save() + + # Check proper handling of files + self.assertEqual(os.path.isdir(settings.MEDIA_ROOT + + "/documents/originals/none"), True) + self.assertEqual(document.source_filename, + "none/none-0000001.pdf") + + @override_settings(PAPERLESS_FILENAME_FORMAT="{correspondent}/" + + "{correspondent}") + def test_set_filename(self): + document = Document() + document.file_type = "pdf" + document.storage_type = Document.STORAGE_TYPE_UNENCRYPTED + document.save() + + # Ensure that filename is properly generated + tmp = document.source_filename + self.assertEqual(document.generate_source_filename(), + "none/none-0000001.pdf") + document.create_source_directory() + Path(document.source_path).touch() + + # Set existing filename + document.set_filename(tmp) + self.assertEqual(document.source_filename, "none/none-0000001.pdf") + + # Set non-existing filename + document.set_filename("doesnotexist") + self.assertEqual(document.source_filename, "none/none-0000001.pdf") diff --git a/src/documents/views.py b/src/documents/views.py index 5b819b9ba..f318d9b28 100755 --- a/src/documents/views.py +++ b/src/documents/views.py @@ -76,7 +76,10 @@ class FetchView(SessionOrBasicAuthMixin, DetailView): content_type=content_types[self.object.file_type] ) - DISPOSITION = 'inline' if settings.INLINE_DOC else 'attachment' + DISPOSITION = ( + 'inline' if settings.INLINE_DOC or self.kwargs["kind"] == 'preview' + else 'attachment' + ) response["Content-Disposition"] = '{}; filename="{}"'.format( DISPOSITION, self.object.file_name) diff --git a/src/paperless/settings.py b/src/paperless/settings.py index ed6c0fb1f..e738d53dc 100644 --- a/src/paperless/settings.py +++ b/src/paperless/settings.py @@ -10,7 +10,9 @@ For the full list of settings and their values, see https://docs.djangoproject.com/en/1.10/ref/settings/ """ +import json import os +import re from dotenv import load_dotenv @@ -62,6 +64,7 @@ FORCE_SCRIPT_NAME = os.getenv("PAPERLESS_FORCE_SCRIPT_NAME") # Application definition INSTALLED_APPS = [ + "whitenoise.runserver_nostatic", "django.contrib.auth", "django.contrib.contenttypes", @@ -92,6 +95,7 @@ if os.getenv("PAPERLESS_INSTALLED_APPS"): MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', + 'whitenoise.middleware.WhiteNoiseMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', @@ -101,8 +105,11 @@ MIDDLEWARE = [ 'django.middleware.clickjacking.XFrameOptionsMiddleware', ] +# Enable whitenoise compression and caching +STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage' + # We allow CORS from localhost:8080 -CORS_ORIGIN_WHITELIST = tuple(os.getenv("PAPERLESS_CORS_ALLOWED_HOSTS", "localhost:8080").split(",")) +CORS_ORIGIN_WHITELIST = tuple(os.getenv("PAPERLESS_CORS_ALLOWED_HOSTS", "http://localhost:8080,https://localhost:8080").split(",")) # If auth is disabled, we just use our "bypass" authentication middleware if bool(os.getenv("PAPERLESS_DISABLE_LOGIN", "false").lower() in ("yes", "y", "1", "t", "true")): @@ -325,8 +332,16 @@ FY_END = os.getenv("PAPERLESS_FINANCIAL_YEAR_END") DATE_ORDER = os.getenv("PAPERLESS_DATE_ORDER", "DMY") FILENAME_DATE_ORDER = os.getenv("PAPERLESS_FILENAME_DATE_ORDER") +# Transformations applied before filename parsing +FILENAME_PARSE_TRANSFORMS = [] +for t in json.loads(os.getenv("PAPERLESS_FILENAME_PARSE_TRANSFORMS", "[]")): + FILENAME_PARSE_TRANSFORMS.append((re.compile(t["pattern"]), t["repl"])) + # Specify for how many years a correspondent is considered recent. Recent # correspondents will be shown in a separate "Recent correspondents" filter as # well. Set to 0 to disable this filter. PAPERLESS_RECENT_CORRESPONDENT_YEARS = int(os.getenv( "PAPERLESS_RECENT_CORRESPONDENT_YEARS", 0)) + +# Specify the filename format for out files +PAPERLESS_FILENAME_FORMAT = os.getenv("PAPERLESS_FILENAME_FORMAT") diff --git a/src/paperless/urls.py b/src/paperless/urls.py index b74d821f4..d208b3470 100755 --- a/src/paperless/urls.py +++ b/src/paperless/urls.py @@ -39,7 +39,7 @@ urlpatterns = [ # File downloads url( - r"^fetch/(?P<kind>doc|thumb)/(?P<pk>\d+)$", + r"^fetch/(?P<kind>doc|thumb|preview)/(?P<pk>\d+)$", FetchView.as_view(), name="fetch" ), diff --git a/src/paperless_tesseract/tests/test_date.py b/src/paperless_tesseract/tests/test_date.py index ac2f9648f..9e9d48b90 100644 --- a/src/paperless_tesseract/tests/test_date.py +++ b/src/paperless_tesseract/tests/test_date.py @@ -175,10 +175,26 @@ class TestDate(TestCase): @mock.patch( "paperless_tesseract.parsers.RasterisedDocumentParser.get_text", - return_value="01-07-0590 00:00:00" + return_value="20 408000l 2475" ) @mock.patch(MOCK_SCRATCH, SCRATCH) - def test_crazy_date_past(self, *args): + def test_crazy_date_with_spaces(self, *args): document = RasterisedDocumentParser("/dev/null") document.get_text() self.assertIsNone(document.get_date()) + + @mock.patch( + "paperless_tesseract.parsers.RasterisedDocumentParser.get_text", + return_value="No date in here" + ) + @mock.patch( + "paperless_tesseract.parsers.RasterisedDocumentParser." + "FILENAME_DATE_ORDER", + new_callable=mock.PropertyMock, + return_value="YMD" + ) + @mock.patch(MOCK_SCRATCH, SCRATCH) + def test_filename_date_parse_invalid(self, *args): + document = RasterisedDocumentParser("/tmp/20 408000l 2475 - test.pdf") + document.get_text() + self.assertIsNone(document.get_date())