Compare commits
230 Commits
releases/d
...
versions/m
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9e2ef57e00 | ||
|
|
756765ce4a | ||
|
|
53096b8bdd | ||
|
|
8aa2567a56 | ||
|
|
ce6e568001 | ||
|
|
d1f0e23c53 | ||
|
|
3f33bdd9c2 | ||
|
|
b2390843ab | ||
|
|
fc14341d40 | ||
|
|
57dd5b1bca | ||
|
|
c731ab7050 | ||
|
|
bd0d298be3 | ||
|
|
cc8147d002 | ||
|
|
1b327b99f0 | ||
|
|
7b3a83ee39 | ||
|
|
4659269349 | ||
|
|
517bb4e9a2 | ||
|
|
162cd256e7 | ||
|
|
339b7dd836 | ||
|
|
949c0ab285 | ||
|
|
cb6cb4121f | ||
|
|
042727aaa9 | ||
|
|
5b304ea742 | ||
|
|
ce4413d539 | ||
|
|
547c31d216 | ||
|
|
f4293a7c06 | ||
|
|
1779d482ac | ||
|
|
e0e4f238f6 | ||
|
|
fecfb37a84 | ||
|
|
3e2aaf391e | ||
|
|
230fde0ab2 | ||
|
|
d9865af200 | ||
|
|
72f8fcf720 | ||
|
|
30668d9d0b | ||
|
|
d5aab12b8d | ||
|
|
ebc0a5f449 | ||
|
|
415d3bcd2f | ||
|
|
b985f2ef05 | ||
|
|
15c953815e | ||
|
|
390e552c1f | ||
|
|
9041f00caa | ||
|
|
b0163319eb | ||
|
|
762cdc5b89 | ||
|
|
396cbb4b22 | ||
|
|
8b0cd93526 | ||
|
|
f97ccb693b | ||
|
|
c3b539ba19 | ||
|
|
80126f2326 | ||
|
|
00e3d40231 | ||
|
|
0953127420 | ||
|
|
02505ba855 | ||
|
|
6fe41660bd | ||
|
|
7695178992 | ||
|
|
b03758ed8b | ||
|
|
d7818b64b0 | ||
|
|
fb53726888 | ||
|
|
8da1a64410 | ||
|
|
62430bf341 | ||
|
|
792aa64829 | ||
|
|
e62e684107 | ||
|
|
a3d63dce80 | ||
|
|
8adb342e24 | ||
|
|
c9567d0c6d | ||
|
|
907e2213e9 | ||
|
|
dea3bbdf09 | ||
|
|
61c6562860 | ||
|
|
8322bd3a27 | ||
|
|
11898a36fe | ||
|
|
2d97024d93 | ||
|
|
d543a71909 | ||
|
|
c652a6c7f6 | ||
|
|
1bc3b58d4e | ||
|
|
4e6e4789e3 | ||
|
|
d1ba081fb7 | ||
|
|
03c63bcf80 | ||
|
|
d190dbca03 | ||
|
|
4384452423 | ||
|
|
76fef4f247 | ||
|
|
f5d0e4d560 | ||
|
|
4b3ab82ee2 | ||
|
|
f8eda67bd5 | ||
|
|
58bcf20a46 | ||
|
|
49979dede5 | ||
| 09f481f5f0 | |||
|
|
a250919acc | ||
|
|
38980e5f75 | ||
|
|
6503d9474d | ||
|
|
e7734def58 | ||
|
|
f50d22b382 | ||
|
|
ad37228466 | ||
|
|
0917bd57b3 | ||
|
|
4dd270e75b | ||
|
|
3428c6aa20 | ||
|
|
eb1fb8511b | ||
|
|
bdbc7ef086 | ||
|
|
abea863184 | ||
|
|
d394583729 | ||
|
|
4db59c0808 | ||
|
|
12f24316a1 | ||
|
|
ef0843276b | ||
|
|
e20102333e | ||
|
|
4ecf075fd4 | ||
|
|
cc81a6905a | ||
|
|
3c9454160f | ||
|
|
2e1600c334 | ||
|
|
3e9f30cb91 | ||
|
|
a3a78f755d | ||
|
|
3988dedebf | ||
|
|
ff34c7d00a | ||
|
|
fe2de33e98 | ||
|
|
3efd1bd89d | ||
|
|
ea516cbc23 | ||
|
|
52ad3e7418 | ||
|
|
a001b4bbb3 | ||
|
|
31ed0e1ac8 | ||
|
|
9ad82695d9 | ||
|
|
69af4dd6b3 | ||
|
|
1c7ceca432 | ||
|
|
c05dcf5b05 | ||
|
|
85b05dd6ec | ||
|
|
9752584135 | ||
|
|
fd0d5728a1 | ||
|
|
88863fd6d0 | ||
|
|
3a7025d9c4 | ||
|
|
150c5d8cc2 | ||
|
|
93ba547350 | ||
|
|
f920dffc01 | ||
|
|
c2e99e6efb | ||
|
|
ff6674cc4a | ||
|
|
669dfeb30a | ||
|
|
6635bb4235 | ||
|
|
88bc29e4d7 | ||
|
|
9315776926 | ||
|
|
40a306996c | ||
|
|
033cecd946 | ||
|
|
ee63829e7f | ||
|
|
e4bc007bba | ||
|
|
84b329f661 | ||
|
|
4c73239dde | ||
|
|
2e12a6af41 | ||
|
|
3d7e6b6fbe | ||
|
|
6f907d156a | ||
|
|
fac77a2f73 | ||
|
|
0c3b6e5388 | ||
|
|
e652c7208c | ||
|
|
53928b2ab6 | ||
|
|
afc6b54520 | ||
|
|
070355033e | ||
|
|
0029d3074f | ||
|
|
4558894faf | ||
|
|
adeea6247f | ||
|
|
3563297d48 | ||
|
|
1e1b4dedf4 | ||
|
|
d65bbb718a | ||
|
|
5352c6ac6f | ||
|
|
cb7d5bf82a | ||
|
|
41a7d00e9e | ||
|
|
82d7339a64 | ||
|
|
e889021f43 | ||
|
|
d3a53fb53a | ||
|
|
b6565effb5 | ||
|
|
cf43ef2f73 | ||
|
|
6ca2845d19 | ||
|
|
ab601f9180 | ||
|
|
0b42567179 | ||
|
|
030ddd68e0 | ||
|
|
649571ebb1 | ||
|
|
b99bb88008 | ||
|
|
fd08a23339 | ||
|
|
917ec55ada | ||
|
|
ec4644b5c9 | ||
|
|
ff86c4c518 | ||
|
|
daebf2ddcc | ||
|
|
49a16acdf5 | ||
|
|
8c064c953a | ||
|
|
3c7a23a5a9 | ||
|
|
6bcf35bef5 | ||
|
|
7ef6102876 | ||
|
|
4363bba0fe | ||
|
|
e2f2181ebb | ||
|
|
d4f7e2cd16 | ||
|
|
058e36b4a9 | ||
|
|
1ddd5f26b1 | ||
|
|
44652d49fb | ||
|
|
119c1bde76 | ||
|
|
ed227b4111 | ||
|
|
c44090aca6 | ||
|
|
8a7da6a103 | ||
|
|
3e3b1f75a0 | ||
|
|
1ab7b7b9b1 | ||
|
|
3fab5c1427 | ||
|
|
516c3aeb2c | ||
|
|
3ac1000b46 | ||
|
|
4adeefc978 | ||
|
|
8bc4b6a95e | ||
|
|
37e85590e8 | ||
|
|
78a0189e1c | ||
|
|
91b0b2d9c3 | ||
|
|
8a54deba3d | ||
|
|
22da1e0a78 | ||
|
|
c9668d62e5 | ||
|
|
7a01a77c43 | ||
|
|
9564db398f | ||
|
|
7faa24eb7b | ||
|
|
51f278301b | ||
|
|
2cc35c3c61 | ||
|
|
8c73fda1ae | ||
|
|
8811c8269f | ||
|
|
f36f99c5fb | ||
|
|
0e972eff06 | ||
|
|
7913b5ddcc | ||
|
|
1c86ea5b5b | ||
|
|
ec6a3bd960 | ||
|
|
080553c797 | ||
|
|
08ee07e652 | ||
|
|
d7d77fcb55 | ||
|
|
bb5324ef50 | ||
|
|
4c212f6ea4 | ||
|
|
941356ed69 | ||
|
|
97804b255b | ||
|
|
06c3ef6583 | ||
|
|
6cd857e2bf | ||
|
|
fbb0f0b9bd | ||
|
|
9e068c3e83 | ||
|
|
72a3807354 | ||
|
|
109fcba795 | ||
|
|
01380e0572 | ||
|
|
5146c6d202 | ||
|
|
300bdbfc8a | ||
|
|
a0331e0236 |
@@ -19,7 +19,7 @@ job_docker_build:
|
|||||||
- docker build --pull -t "$CI_REGISTRY_IMAGE" -f docker/Dockerfile .
|
- docker build --pull -t "$CI_REGISTRY_IMAGE" -f docker/Dockerfile .
|
||||||
- VERSION=`cat docker/rootfs/version`
|
- VERSION=`cat docker/rootfs/version`
|
||||||
- docker tag "$CI_REGISTRY_IMAGE" "$CI_REGISTRY_IMAGE:$VERSION"
|
- docker tag "$CI_REGISTRY_IMAGE" "$CI_REGISTRY_IMAGE:$VERSION"
|
||||||
- docker run --rm "$CI_REGISTRY_IMAGE:$VERSION" run-tests
|
- docker run --rm "$CI_REGISTRY_IMAGE:$VERSION" run_tests
|
||||||
- docker push "$CI_REGISTRY_IMAGE:$VERSION"
|
- docker push "$CI_REGISTRY_IMAGE:$VERSION"
|
||||||
- docker push "$CI_REGISTRY_IMAGE:latest"
|
- docker push "$CI_REGISTRY_IMAGE:latest"
|
||||||
- docker tag "$CI_REGISTRY_IMAGE:$VERSION" registry-1.docker.io/mayanedms/mayanedms:"$VERSION"
|
- docker tag "$CI_REGISTRY_IMAGE:$VERSION" registry-1.docker.io/mayanedms/mayanedms:"$VERSION"
|
||||||
@@ -58,7 +58,7 @@ job_docker_nightly:
|
|||||||
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
||||||
script:
|
script:
|
||||||
- docker build --pull -t "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" -f docker/Dockerfile .
|
- docker build --pull -t "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" -f docker/Dockerfile .
|
||||||
- docker run --rm "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" run-tests
|
- docker run --rm "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" run_tests
|
||||||
- docker push "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG"
|
- docker push "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG"
|
||||||
only:
|
only:
|
||||||
- nightly
|
- nightly
|
||||||
@@ -152,7 +152,9 @@ job_push_python:
|
|||||||
- locale-gen en_US.UTF-8
|
- locale-gen en_US.UTF-8
|
||||||
- update-locale LANG=en_US.UTF-8
|
- update-locale LANG=en_US.UTF-8
|
||||||
- export LC_ALL=en_US.UTF-8
|
- export LC_ALL=en_US.UTF-8
|
||||||
- apt-get install -qq curl exiftool gcc ghostscript gnupg1 graphviz libfuse2 libjpeg-dev libmagic1 libpng-dev libtiff-dev poppler-utils libreoffice poppler-utils python-dev python-pip tesseract-ocr tesseract-ocr-deu
|
- apt-get install -qq curl exiftool gcc ghostscript gnupg1 graphviz libfuse2 libjpeg-dev libmagic1 libpng-dev libtiff-dev poppler-utils libreoffice poppler-utils python-dev python-virtualenv python3-dev tesseract-ocr tesseract-ocr-deu
|
||||||
|
- virtualenv venv -p /usr/bin/python3
|
||||||
|
- . venv/bin/activate
|
||||||
- pip install -r requirements.txt -r requirements/testing-base.txt
|
- pip install -r requirements.txt -r requirements/testing-base.txt
|
||||||
only:
|
only:
|
||||||
- releases/all
|
- releases/all
|
||||||
@@ -170,6 +172,7 @@ test-mysql:
|
|||||||
- mysql:8.0.3
|
- mysql:8.0.3
|
||||||
script:
|
script:
|
||||||
- apt-get install -qq libmysqlclient-dev mysql-client
|
- apt-get install -qq libmysqlclient-dev mysql-client
|
||||||
|
- . venv/bin/activate
|
||||||
- pip install mysqlclient
|
- pip install mysqlclient
|
||||||
- mysql -h"$MYSQL_PORT_3306_TCP_ADDR" -P"$MYSQL_PORT_3306_TCP_PORT" -uroot -p"$MYSQL_ENV_MYSQL_ROOT_PASSWORD" -e "set global character_set_server=utf8mb4;"
|
- mysql -h"$MYSQL_PORT_3306_TCP_ADDR" -P"$MYSQL_PORT_3306_TCP_PORT" -uroot -p"$MYSQL_ENV_MYSQL_ROOT_PASSWORD" -e "set global character_set_server=utf8mb4;"
|
||||||
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci.db_mysql --nomigrations
|
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci.db_mysql --nomigrations
|
||||||
@@ -185,6 +188,7 @@ test-postgres:
|
|||||||
- postgres
|
- postgres
|
||||||
script:
|
script:
|
||||||
- apt-get install -qq libpq-dev
|
- apt-get install -qq libpq-dev
|
||||||
|
- . venv/bin/activate
|
||||||
- pip install psycopg2
|
- pip install psycopg2
|
||||||
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci.db_postgres --nomigrations
|
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci.db_postgres --nomigrations
|
||||||
tags:
|
tags:
|
||||||
@@ -193,6 +197,7 @@ test-postgres:
|
|||||||
test-sqlite:
|
test-sqlite:
|
||||||
<<: *test_base
|
<<: *test_base
|
||||||
script:
|
script:
|
||||||
|
- . venv/bin/activate
|
||||||
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci --nomigrations
|
- python manage.py test --mayan-apps --settings=mayan.settings.testing.gitlab-ci --nomigrations
|
||||||
|
|
||||||
deploy_demo:
|
deploy_demo:
|
||||||
|
|||||||
13
.tx/config
13
.tx/config
@@ -115,6 +115,12 @@ source_lang = en
|
|||||||
source_file = mayan/apps/events/locale/en/LC_MESSAGES/django.po
|
source_file = mayan/apps/events/locale/en/LC_MESSAGES/django.po
|
||||||
type = PO
|
type = PO
|
||||||
|
|
||||||
|
[mayan-edms.file_caching-3-0]
|
||||||
|
file_filter = mayan/apps/file_caching/locale/<lang>/LC_MESSAGES/django.po
|
||||||
|
source_lang = en
|
||||||
|
source_file = mayan/apps/file_caching/locale/en/LC_MESSAGES/django.po
|
||||||
|
type = PO
|
||||||
|
|
||||||
[mayan-edms.file_metadata-3-0]
|
[mayan-edms.file_metadata-3-0]
|
||||||
file_filter = mayan/apps/file_metadata/locale/<lang>/LC_MESSAGES/django.po
|
file_filter = mayan/apps/file_metadata/locale/<lang>/LC_MESSAGES/django.po
|
||||||
source_lang = en
|
source_lang = en
|
||||||
@@ -222,3 +228,10 @@ file_filter = mayan/apps/user_management/locale/<lang>/LC_MESSAGES/django.po
|
|||||||
source_lang = en
|
source_lang = en
|
||||||
source_file = mayan/apps/user_management/locale/en/LC_MESSAGES/django.po
|
source_file = mayan/apps/user_management/locale/en/LC_MESSAGES/django.po
|
||||||
type = PO
|
type = PO
|
||||||
|
|
||||||
|
[mayan-edms.weblink-3-0]
|
||||||
|
file_filter = mayan/apps/weblinks/locale/<lang>/LC_MESSAGES/django.po
|
||||||
|
source_lang = en
|
||||||
|
source_file = mayan/apps/weblinks/locale/en/LC_MESSAGES/django.po
|
||||||
|
type = PO
|
||||||
|
|
||||||
|
|||||||
1061
HISTORY.rst
1061
HISTORY.rst
File diff suppressed because it is too large
Load Diff
41
Makefile
41
Makefile
@@ -1,5 +1,15 @@
|
|||||||
.PHONY: clean-pyc clean-build
|
.PHONY: clean-pyc clean-build
|
||||||
|
|
||||||
|
DOCKER_MYSQL_IMAGE = mysql:8.0
|
||||||
|
DOCKER_ORACLE_IMAGE = wnameless/oracle-xe-11g
|
||||||
|
DOCKER_POSTGRES_IMAGE = postgres:9.6-alpine
|
||||||
|
DOCKER_REDIS_IMAGE = redis:5.0-alpine
|
||||||
|
|
||||||
|
PYTHON_MYSQL_VERSION = 1.4.4
|
||||||
|
PYTHON_PSYCOPG2_VERSION = 2.8.3
|
||||||
|
PYTHON_RABBITMQ_VERSION = 2.0.0
|
||||||
|
PYTHON_REDIS_VERSION = 3.2.1
|
||||||
|
|
||||||
help:
|
help:
|
||||||
@echo "Usage: make <target>\n"
|
@echo "Usage: make <target>\n"
|
||||||
@awk 'BEGIN {FS = ":.*##"} /^[a-zA-Z_-]+:.*?## / { printf " * %-40s -%s\n", $$1, $$2 }' $(MAKEFILE_LIST)|sort
|
@awk 'BEGIN {FS = ":.*##"} /^[a-zA-Z_-]+:.*?## / { printf " * %-40s -%s\n", $$1, $$2 }' $(MAKEFILE_LIST)|sort
|
||||||
@@ -18,7 +28,7 @@ clean-pyc: ## Remove Python artifacts.
|
|||||||
find . -name '*.pyc' -exec rm -f {} +
|
find . -name '*.pyc' -exec rm -f {} +
|
||||||
find . -name '*.pyo' -exec rm -f {} +
|
find . -name '*.pyo' -exec rm -f {} +
|
||||||
find . -name '*~' -exec rm -f {} +
|
find . -name '*~' -exec rm -f {} +
|
||||||
|
find . -name '__pycache__' -exec rm -R -f {} +
|
||||||
|
|
||||||
# Testing
|
# Testing
|
||||||
|
|
||||||
@@ -33,10 +43,10 @@ test-all: clean-pyc
|
|||||||
test-launch-postgres:
|
test-launch-postgres:
|
||||||
@docker rm -f test-postgres || true
|
@docker rm -f test-postgres || true
|
||||||
@docker volume rm test-postgres || true
|
@docker volume rm test-postgres || true
|
||||||
docker run -d --name test-postgres -p 5432:5432 -v test-postgres:/var/lib/postgresql/data healthcheck/postgres
|
docker run -d --name test-postgres -p 5432:5432 -v test-postgres:/var/lib/postgresql/data $(DOCKER_POSTGRES_IMAGE)
|
||||||
sudo apt-get install -q libpq-dev
|
sudo apt-get install -q libpq-dev
|
||||||
pip install psycopg2
|
pip install psycopg2==$(PYTHON_PSYCOPG2_VERSION)
|
||||||
while ! docker inspect --format='{{json .State.Health}}' test-postgres|grep 'Status":"healthy"'; do sleep 1; done
|
while ! nc -z 127.0.0.1 5432; do sleep 1; done
|
||||||
|
|
||||||
test-with-postgres: ## MODULE=<python module name> - Run tests for a single app, module or test class against a Postgres database container.
|
test-with-postgres: ## MODULE=<python module name> - Run tests for a single app, module or test class against a Postgres database container.
|
||||||
test-with-postgres: test-launch-postgres
|
test-with-postgres: test-launch-postgres
|
||||||
@@ -53,10 +63,10 @@ test-with-postgres-all: test-launch-postgres
|
|||||||
test-launch-mysql:
|
test-launch-mysql:
|
||||||
@docker rm -f test-mysql || true
|
@docker rm -f test-mysql || true
|
||||||
@docker volume rm test-mysql || true
|
@docker volume rm test-mysql || true
|
||||||
docker run -d --name test-mysql -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=True -e MYSQL_DATABASE=mayan -v test-mysql:/var/lib/mysql healthcheck/mysql
|
docker run -d --name test-mysql -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=True -e MYSQL_DATABASE=mayan -v test-mysql:/var/lib/mysql $(DOCKER_MYSQL_IMAGE)
|
||||||
sudo apt-get install -q libmysqlclient-dev mysql-client
|
sudo apt-get install -q libmysqlclient-dev mysql-client
|
||||||
pip install mysqlclient
|
pip install mysqlclient==$(PYTHON_MYSQL_VERSION)
|
||||||
while ! docker inspect --format='{{json .State.Health}}' test-mysql|grep 'Status":"healthy"'; do sleep 1; done
|
while ! nc -z 127.0.0.1 3306; do sleep 1; done
|
||||||
mysql -h 127.0.0.1 -P 3306 -uroot -e "set global character_set_server=utf8mb4;"
|
mysql -h 127.0.0.1 -P 3306 -uroot -e "set global character_set_server=utf8mb4;"
|
||||||
|
|
||||||
test-with-mysql: ## MODULE=<python module name> - Run tests for a single app, module or test class against a MySQL database container.
|
test-with-mysql: ## MODULE=<python module name> - Run tests for a single app, module or test class against a MySQL database container.
|
||||||
@@ -75,7 +85,7 @@ test-with-mysql-all: test-launch-mysql
|
|||||||
test-launch-oracle:
|
test-launch-oracle:
|
||||||
@docker rm -f test-oracle || true
|
@docker rm -f test-oracle || true
|
||||||
@docker volume rm test-oracle || true
|
@docker volume rm test-oracle || true
|
||||||
docker run -d --name test-oracle -p 49160:22 -p 49161:1521 -e ORACLE_ALLOW_REMOTE=true -v test-oracle:/u01/app/oracle wnameless/oracle-xe-11g
|
docker run -d --name test-oracle -p 49160:22 -p 49161:1521 -e ORACLE_ALLOW_REMOTE=true -v test-oracle:/u01/app/oracle $(DOCKER_ORACLE_IMAGE)
|
||||||
# https://gist.github.com/kimus/10012910
|
# https://gist.github.com/kimus/10012910
|
||||||
pip install cx_Oracle
|
pip install cx_Oracle
|
||||||
while ! nc -z 127.0.0.1 49161; do sleep 1; done
|
while ! nc -z 127.0.0.1 49161; do sleep 1; done
|
||||||
@@ -234,20 +244,21 @@ generate-requirements: ## Generate all requirements files from the project deped
|
|||||||
# Dev server
|
# Dev server
|
||||||
|
|
||||||
runserver: ## Run the development server.
|
runserver: ## Run the development server.
|
||||||
./manage.py runserver --settings=mayan.settings.development $(ADDRPORT)
|
./manage.py runserver --nothreading --settings=mayan.settings.development $(ADDRPORT)
|
||||||
|
|
||||||
runserver_plus: ## Run the Django extension's development server.
|
runserver_plus: ## Run the Django extension's development server.
|
||||||
./manage.py runserver_plus --settings=mayan.settings.development $(ADDRPORT)
|
./manage.py runserver_plus --nothreading --settings=mayan.settings.development $(ADDRPORT)
|
||||||
|
|
||||||
shell_plus: ## Run the shell_plus command.
|
shell_plus: ## Run the shell_plus command.
|
||||||
./manage.py shell_plus --settings=mayan.settings.development
|
./manage.py shell_plus --settings=mayan.settings.development
|
||||||
|
|
||||||
test-with-docker-services-on: ## Launch and initialize production-like services using Docker (Postgres and Redis).
|
test-with-docker-services-on: ## Launch and initialize production-like services using Docker (Postgres and Redis).
|
||||||
docker run -d --name redis -p 6379:6379 redis
|
docker run -d --name redis -p 6379:6379 $(DOCKER_REDIS_IMAGE)
|
||||||
docker run -d --name postgres -p 5432:5432 postgres
|
docker run -d --name postgres -p 5432:5432 $(DOCKER_POSTGRES_IMAGE)
|
||||||
while ! nc -z 127.0.0.1 6379; do sleep 1; done
|
while ! nc -z 127.0.0.1 6379; do sleep 1; done
|
||||||
while ! nc -z 127.0.0.1 5432; do sleep 1; done
|
while ! nc -z 127.0.0.1 5432; do sleep 1; done
|
||||||
sleep 4
|
sleep 4
|
||||||
|
pip install psycopg2==$(PYTHON_PSYCOPG2_VERSION) redis==$(PYTHON_REDIS_VERSION)
|
||||||
./manage.py initialsetup --settings=mayan.settings.staging.docker
|
./manage.py initialsetup --settings=mayan.settings.staging.docker
|
||||||
|
|
||||||
test-with-docker-services-off: ## Stop and delete the Docker production-like services.
|
test-with-docker-services-off: ## Stop and delete the Docker production-like services.
|
||||||
@@ -258,10 +269,10 @@ test-with-docker-frontend: ## Launch a front end instance that uses the producti
|
|||||||
./manage.py runserver --settings=mayan.settings.staging.docker
|
./manage.py runserver --settings=mayan.settings.staging.docker
|
||||||
|
|
||||||
test-with-docker-worker: ## Launch a worker instance that uses the production-like services.
|
test-with-docker-worker: ## Launch a worker instance that uses the production-like services.
|
||||||
./manage.py celery worker --settings=mayan.settings.staging.docker -B -l INFO -O fair
|
DJANGO_SETTINGS_MODULE=mayan.settings.staging.docker ./manage.py celery worker -A mayan -B -l INFO -O fair
|
||||||
|
|
||||||
docker-mysql-on: ## Launch and initialize a MySQL Docker container.
|
docker-mysql-on: ## Launch and initialize a MySQL Docker container.
|
||||||
docker run -d --name mysql -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=True -e MYSQL_DATABASE=mayan_edms mysql
|
docker run -d --name mysql -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=True -e MYSQL_DATABASE=mayan_edms $(DOCKER_MYSQL_IMAGE)
|
||||||
while ! nc -z 127.0.0.1 3306; do sleep 1; done
|
while ! nc -z 127.0.0.1 3306; do sleep 1; done
|
||||||
|
|
||||||
docker-mysql-off: ## Stop and delete the MySQL Docker container.
|
docker-mysql-off: ## Stop and delete the MySQL Docker container.
|
||||||
@@ -269,7 +280,7 @@ docker-mysql-off: ## Stop and delete the MySQL Docker container.
|
|||||||
docker rm mysql
|
docker rm mysql
|
||||||
|
|
||||||
docker-postgres-on: ## Launch and initialize a PostgreSQL Docker container.
|
docker-postgres-on: ## Launch and initialize a PostgreSQL Docker container.
|
||||||
docker run -d --name postgres -p 5432:5432 postgres
|
docker run -d --name postgres -p 5432:5432 $(DOCKER_POSTGRES_IMAGE)
|
||||||
while ! nc -z 127.0.0.1 5432; do sleep 1; done
|
while ! nc -z 127.0.0.1 5432; do sleep 1; done
|
||||||
|
|
||||||
docker-postgres-off: ## Stop and delete the PostgreSQL Docker container.
|
docker-postgres-off: ## Stop and delete the PostgreSQL Docker container.
|
||||||
|
|||||||
@@ -1,72 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
INSTALLATION_DIRECTORY=/home/vagrant/mayan-edms/
|
|
||||||
DB_NAME=mayan_edms
|
|
||||||
DB_PASSWORD=test123
|
|
||||||
|
|
||||||
cat << EOF | sudo tee -a /etc/motd.tail
|
|
||||||
**********************************sudo apt
|
|
||||||
|
|
||||||
Mayan EDMS Vagrant Development Box
|
|
||||||
|
|
||||||
**********************************
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# Update sources
|
|
||||||
echo -e "\n -> Running apt-get update & upgrade \n"
|
|
||||||
sudo apt-get -qq update
|
|
||||||
sudo apt-get -y upgrade
|
|
||||||
|
|
||||||
echo -e "\n -> Installing core binaries \n"
|
|
||||||
sudo apt-get -y install git-core python-virtualenv gcc python-dev libjpeg-dev libpng-dev libtiff-dev tesseract-ocr poppler-utils libreoffice
|
|
||||||
|
|
||||||
echo -e "\n -> Cloning development branch of repository \n"
|
|
||||||
git clone /mayan-edms-repository/ $INSTALLATION_DIRECTORY
|
|
||||||
cd $INSTALLATION_DIRECTORY
|
|
||||||
git checkout development
|
|
||||||
git reset HEAD --hard
|
|
||||||
|
|
||||||
echo -e "\n -> Setting up virtual env \n"
|
|
||||||
virtualenv venv
|
|
||||||
source venv/bin/activate
|
|
||||||
|
|
||||||
echo -e "\n -> Installing python dependencies \n"
|
|
||||||
pip install -r requirements.txt
|
|
||||||
|
|
||||||
echo -e "\n -> Running Mayan EDMS initial setup \n"
|
|
||||||
./manage.py initialsetup
|
|
||||||
|
|
||||||
echo -e "\n -> Installing Redis server \n"
|
|
||||||
sudo apt-get install -y redis-server
|
|
||||||
pip install redis
|
|
||||||
|
|
||||||
echo -e "\n -> Installing testing software \n"
|
|
||||||
pip install coverage
|
|
||||||
|
|
||||||
echo -e "\n -> Installing MySQL \n"
|
|
||||||
sudo debconf-set-selections <<< 'mysql-server mysql-server/root_password password '$DB_PASSWORD
|
|
||||||
sudo debconf-set-selections <<< 'mysql-server mysql-server/root_password_again password '$DB_PASSWORD
|
|
||||||
sudo apt-get install -y mysql-server libmysqlclient-dev
|
|
||||||
# Create a passwordless root and travis users
|
|
||||||
mysql -u root -p$DB_PASSWORD -e "SET PASSWORD = PASSWORD('');"
|
|
||||||
mysql -u root -e "CREATE USER 'travis'@'localhost' IDENTIFIED BY '';GRANT ALL PRIVILEGES ON * . * TO 'travis'@'localhost';FLUSH PRIVILEGES;"
|
|
||||||
mysql -u travis -e "CREATE DATABASE $DB_NAME;"
|
|
||||||
pip install mysql-python
|
|
||||||
|
|
||||||
echo -e "\n -> Installing PostgreSQL \n"
|
|
||||||
sudo apt-get install -y postgresql postgresql-server-dev-all
|
|
||||||
sudo -u postgres psql -c 'create database mayan_edms;' -U postgres
|
|
||||||
sudo cat > /etc/postgresql/9.3/main/pg_hba.conf << EOF
|
|
||||||
local all postgres trust
|
|
||||||
|
|
||||||
# TYPE DATABASE USER ADDRESS METHOD
|
|
||||||
|
|
||||||
# "local" is for Unix domain socket connections only
|
|
||||||
local all all peer
|
|
||||||
# IPv4 local connections:
|
|
||||||
host all all 127.0.0.1/32 md5
|
|
||||||
# IPv6 local connections:
|
|
||||||
host all all ::1/128 md5
|
|
||||||
EOF
|
|
||||||
|
|
||||||
pip install -q psycopg2
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -5,21 +5,25 @@ set -e
|
|||||||
# $ curl -fsSL get.mayan-edms.com -o get-mayan-edms.sh
|
# $ curl -fsSL get.mayan-edms.com -o get-mayan-edms.sh
|
||||||
# $ sh get-mayan-edms.sh
|
# $ sh get-mayan-edms.sh
|
||||||
#
|
#
|
||||||
# NOTE: Make sure to verify the contents of the script
|
# NOTE: Before executing, make sure to verify the contents of the script
|
||||||
# you downloaded matches the contents of docker.sh
|
# you downloaded matches the contents of docker.sh
|
||||||
# located at https://gitlab.com/mayan-edms/mayan-edms/blob/master/contrib/scripts/install/docker.sh
|
# located at https://gitlab.com/mayan-edms/mayan-edms/blob/master/contrib/scripts/install/docker.sh
|
||||||
# before executing.
|
|
||||||
|
|
||||||
: ${VERBOSE:=true}
|
: ${VERBOSE:=true}
|
||||||
: ${INSTALL_DOCKER:=false}
|
: ${INSTALL_DOCKER:=false}
|
||||||
: ${DELETE_VOLUMES:=false}
|
: ${DELETE_VOLUMES:=false}
|
||||||
|
: ${USE_DOCKER_NETWORK:=true}
|
||||||
|
: ${DOCKER_NETWORK_NAME:=mayan}
|
||||||
: ${DATABASE_USER:=mayan}
|
: ${DATABASE_USER:=mayan}
|
||||||
: ${DATABASE_NAME:=mayan}
|
: ${DATABASE_NAME:=mayan}
|
||||||
: ${DATABASE_PASSWORD:=mayanuserpass}
|
: ${DATABASE_PASSWORD:=mayanuserpass}
|
||||||
: ${DOCKER_POSTGRES_IMAGE:=postgres:9.6}
|
: ${DOCKER_POSTGRES_IMAGE:=postgres:9.6-alpine}
|
||||||
: ${DOCKER_POSTGRES_CONTAINER:=mayan-edms-postgres}
|
: ${DOCKER_POSTGRES_CONTAINER:=mayan-edms-postgres}
|
||||||
: ${DOCKER_POSTGRES_VOLUME:=/docker-volumes/mayan-edms/postgres}
|
: ${DOCKER_POSTGRES_VOLUME:=/docker-volumes/mayan-edms/postgres}
|
||||||
: ${DOCKER_POSTGRES_PORT:=5432}
|
: ${DOCKER_POSTGRES_PORT:=5432}
|
||||||
|
: ${DOCKER_REDIS_IMAGE:=redis:5.0-alpine}
|
||||||
|
: ${DOCKER_REDIS_CONTAINER:=mayan-edms-redis}
|
||||||
|
: ${DOCKER_REDIS_PORT:=6379}
|
||||||
: ${DOCKER_MAYAN_IMAGE:=mayanedms/mayanedms:latest}
|
: ${DOCKER_MAYAN_IMAGE:=mayanedms/mayanedms:latest}
|
||||||
: ${DOCKER_MAYAN_CONTAINER:=mayan-edms}
|
: ${DOCKER_MAYAN_CONTAINER:=mayan-edms}
|
||||||
: ${DOCKER_MAYAN_VOLUME:=/docker-volumes/mayan-edms/media}
|
: ${DOCKER_MAYAN_VOLUME:=/docker-volumes/mayan-edms/media}
|
||||||
@@ -44,6 +48,8 @@ echo "Variable values to be used:"
|
|||||||
echo "---------------------------"
|
echo "---------------------------"
|
||||||
echo "INSTALL_DOCKER: $INSTALL_DOCKER"
|
echo "INSTALL_DOCKER: $INSTALL_DOCKER"
|
||||||
echo "DELETE_VOLUMES: $DELETE_VOLUMES"
|
echo "DELETE_VOLUMES: $DELETE_VOLUMES"
|
||||||
|
echo "USE_DOCKER_NETWORK: $USE_DOCKER_NETWORK"
|
||||||
|
echo "DOCKER_NETWORK_NAME: $DOCKER_NETWORK_NAME"
|
||||||
echo "DATABASE_USER: $DATABASE_USER"
|
echo "DATABASE_USER: $DATABASE_USER"
|
||||||
echo "DATABASE_NAME: $DATABASE_NAME"
|
echo "DATABASE_NAME: $DATABASE_NAME"
|
||||||
echo "DATABASE_PASSWORD: $DATABASE_PASSWORD"
|
echo "DATABASE_PASSWORD: $DATABASE_PASSWORD"
|
||||||
@@ -51,10 +57,17 @@ echo "DOCKER_POSTGRES_IMAGE: $DOCKER_POSTGRES_IMAGE"
|
|||||||
echo "DOCKER_POSTGRES_CONTAINER: $DOCKER_POSTGRES_CONTAINER"
|
echo "DOCKER_POSTGRES_CONTAINER: $DOCKER_POSTGRES_CONTAINER"
|
||||||
echo "DOCKER_POSTGRES_VOLUME: $DOCKER_POSTGRES_VOLUME"
|
echo "DOCKER_POSTGRES_VOLUME: $DOCKER_POSTGRES_VOLUME"
|
||||||
echo "DOCKER_POSTGRES_PORT: $DOCKER_POSTGRES_PORT"
|
echo "DOCKER_POSTGRES_PORT: $DOCKER_POSTGRES_PORT"
|
||||||
|
echo "DOCKER_REDIS_IMAGE: $DOCKER_REDIS_IMAGE"
|
||||||
|
echo "DOCKER_REDIS_CONTAINER: $DOCKER_REDIS_CONTAINER"
|
||||||
|
echo "DOCKER_REDIS_PORT: $DOCKER_REDIS_PORT"
|
||||||
echo "DOCKER_MAYAN_IMAGE: $DOCKER_MAYAN_IMAGE"
|
echo "DOCKER_MAYAN_IMAGE: $DOCKER_MAYAN_IMAGE"
|
||||||
echo "DOCKER_MAYAN_CONTAINER: $DOCKER_MAYAN_CONTAINER"
|
echo "DOCKER_MAYAN_CONTAINER: $DOCKER_MAYAN_CONTAINER"
|
||||||
echo "DOCKER_MAYAN_VOLUME: $DOCKER_MAYAN_VOLUME"
|
echo "DOCKER_MAYAN_VOLUME: $DOCKER_MAYAN_VOLUME"
|
||||||
echo "\nStarting in 10 seconds."
|
echo
|
||||||
|
echo "Override any of them by setting them before the script. "
|
||||||
|
echo "Example: INSTALL_DOCKER=true sh get-mayan-edms.sh"
|
||||||
|
|
||||||
|
echo "\nStarting in 10 seconds. Press CTRL+C to cancel."
|
||||||
sleep 10
|
sleep 10
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -72,33 +85,62 @@ if [ -z `which docker` ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
echo -n "* Removing existing Mayan EDMS and PostgreSQL containers (no data will be lost)..."
|
echo -n "* Removing existing Mayan EDMS and PostgreSQL containers (no data will be lost)..."
|
||||||
true || docker stop $DOCKER_MAYAN_CONTAINER >/dev/null 2>&1
|
docker rm -f $DOCKER_REDIS_CONTAINER >/dev/null 2>&1 || true
|
||||||
true || docker rm $DOCKER_MAYAN_CONTAINER >/dev/null 2>&1
|
docker rm -f $DOCKER_POSTGRES_CONTAINER >/dev/null 2>&1 || true
|
||||||
true || docker stop $DOCKER_POSTGRES_CONTAINER >/dev/null 2>&1
|
docker rm -f $DOCKER_MAYAN_CONTAINER >/dev/null 2>&1 || true
|
||||||
true || docker rm $DOCKER_POSTGRES_CONTAINER >/dev/null 2>&1
|
|
||||||
echo "Done"
|
echo "Done"
|
||||||
|
|
||||||
if [ "$DELETE_VOLUMES" = true ]; then
|
if [ "$DELETE_VOLUMES" = true ]; then
|
||||||
echo -n "* Deleting Docker volumes in 5 seconds (warning: this delete all document data)..."
|
echo -n "* Deleting Docker volumes in 5 seconds (warning: this will delete all document data). Press CTRL+C to cancel..."
|
||||||
sleep 5
|
sleep 5
|
||||||
true || rm DOCKER_MAYAN_VOLUME -Rf
|
rm DOCKER_MAYAN_VOLUME -Rf || true
|
||||||
true || rm DOCKER_POSTGRES_VOLUME -Rf
|
rm DOCKER_POSTGRES_VOLUME -Rf || true
|
||||||
echo "Done"
|
echo "Done"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -n "* Pulling (downloading) the Mayan EDMS Docker image..."
|
echo -n "* Pulling (downloading) the Redis Docker image..."
|
||||||
docker pull $DOCKER_MAYAN_IMAGE >/dev/null
|
docker pull $DOCKER_REDIS_IMAGE > /dev/null
|
||||||
echo "Done"
|
echo "Done"
|
||||||
|
|
||||||
echo -n "* Pulling (downloading) the PostgreSQL Docker image..."
|
echo -n "* Pulling (downloading) the PostgreSQL Docker image..."
|
||||||
docker pull $DOCKER_POSTGRES_IMAGE > /dev/null
|
docker pull $DOCKER_POSTGRES_IMAGE > /dev/null
|
||||||
echo "Done"
|
echo "Done"
|
||||||
|
|
||||||
|
echo -n "* Pulling (downloading) the Mayan EDMS Docker image..."
|
||||||
|
docker pull $DOCKER_MAYAN_IMAGE >/dev/null
|
||||||
|
echo "Done"
|
||||||
|
|
||||||
|
if [ "$USE_DOCKER_NETWORK" = true ]; then
|
||||||
|
echo -n "* Creating Docker network..."
|
||||||
|
docker network create $DOCKER_NETWORK_NAME 2> /dev/null || true
|
||||||
|
# Ignore error if the network already exists
|
||||||
|
echo "Done"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$USE_DOCKER_NETWORK" = true ]; then
|
||||||
|
NETWORK_ARGUMENT="--network=$DOCKER_NETWORK_NAME"
|
||||||
|
POSTGRES_PORT_ARGUMENT=""
|
||||||
|
REDIS_PORT_ARGUMENT=""
|
||||||
|
MAYAN_DATABASE_PORT_ARGUMENT=""
|
||||||
|
MAYAN_DATABASE_HOST_ARGUMENT="-e MAYAN_DATABASE_HOST=$DOCKER_POSTGRES_CONTAINER"
|
||||||
|
MAYAN_BROKER_URL_ARGUMENT="-e MAYAN_BROKER_URL=redis://$DOCKER_REDIS_CONTAINER:6379/0"
|
||||||
|
MAYAN_CELERY_RESULT_BACKEND_ARGUMENT="-e MAYAN_CELERY_RESULT_BACKEND=redis://$DOCKER_REDIS_CONTAINER:6379/1"
|
||||||
|
else
|
||||||
|
NETWORK_ARGUMENT=""
|
||||||
|
POSTGRES_PORT_ARGUMENT="-e $DOCKER_POSTGRES_PORT:5432"
|
||||||
|
REDIS_PORT_ARGUMENT="-e $DOCKER_REDIS_PORT:6379"
|
||||||
|
MAYAN_DATABASE_PORT_ARGUMENT="-e MAYAN_DATABASE_PORT=$DOCKER_POSTGRES_PORT"
|
||||||
|
MAYAN_DATABASE_HOST_ARGUMENT="-e MAYAN_DATABASE_HOST=172.17.0.1"
|
||||||
|
MAYAN_BROKER_URL_ARGUMENT="-e MAYAN_BROKER_URL=redis://172.17.0.1:6379/0"
|
||||||
|
MAYAN_CELERY_RESULT_BACKEND_ARGUMENT="-e MAYAN_CELERY_RESULT_BACKEND=redis://172.17.0.1:6379/1"
|
||||||
|
fi
|
||||||
|
|
||||||
echo -n "* Deploying the PostgreSQL container..."
|
echo -n "* Deploying the PostgreSQL container..."
|
||||||
docker run -d \
|
docker run -d \
|
||||||
--name $DOCKER_POSTGRES_CONTAINER \
|
--name $DOCKER_POSTGRES_CONTAINER \
|
||||||
|
$NETWORK_ARGUMENT \
|
||||||
--restart=always \
|
--restart=always \
|
||||||
-p $DOCKER_POSTGRES_PORT:5432 \
|
$POSTGRES_PORT_ARGUMENT \
|
||||||
-e POSTGRES_USER=$DATABASE_USER \
|
-e POSTGRES_USER=$DATABASE_USER \
|
||||||
-e POSTGRES_DB=$DATABASE_NAME \
|
-e POSTGRES_DB=$DATABASE_NAME \
|
||||||
-e POSTGRES_PASSWORD=$DATABASE_PASSWORD \
|
-e POSTGRES_PASSWORD=$DATABASE_PASSWORD \
|
||||||
@@ -106,6 +148,24 @@ docker run -d \
|
|||||||
$DOCKER_POSTGRES_IMAGE >/dev/null
|
$DOCKER_POSTGRES_IMAGE >/dev/null
|
||||||
echo "Done"
|
echo "Done"
|
||||||
|
|
||||||
|
echo -n "* Deploying the Redis container..."
|
||||||
|
docker run -d \
|
||||||
|
--name $DOCKER_REDIS_CONTAINER \
|
||||||
|
$NETWORK_ARGUMENT \
|
||||||
|
--restart=always \
|
||||||
|
$REDIS_PORT_ARGUMENT \
|
||||||
|
$DOCKER_REDIS_IMAGE \
|
||||||
|
redis-server \
|
||||||
|
--appendonly no \
|
||||||
|
--databases 2 \
|
||||||
|
--maxmemory 100mb \
|
||||||
|
--maxmemory-policy allkeys-lru \
|
||||||
|
--maxclients 500 \
|
||||||
|
--save "" \
|
||||||
|
--tcp-backlog 256 \
|
||||||
|
>/dev/null
|
||||||
|
echo "Done"
|
||||||
|
|
||||||
echo -n "* Waiting for the PostgreSQL container to be ready (10 seconds)..."
|
echo -n "* Waiting for the PostgreSQL container to be ready (10 seconds)..."
|
||||||
sleep 10
|
sleep 10
|
||||||
echo "Done"
|
echo "Done"
|
||||||
@@ -113,15 +173,18 @@ echo "Done"
|
|||||||
echo -n "* Deploying Mayan EDMS container..."
|
echo -n "* Deploying Mayan EDMS container..."
|
||||||
docker run -d \
|
docker run -d \
|
||||||
--name $DOCKER_MAYAN_CONTAINER \
|
--name $DOCKER_MAYAN_CONTAINER \
|
||||||
|
$NETWORK_ARGUMENT \
|
||||||
--restart=always \
|
--restart=always \
|
||||||
-p 80:8000 \
|
-p 80:8000 \
|
||||||
-e MAYAN_DATABASE_ENGINE=django.db.backends.postgresql \
|
-e MAYAN_DATABASE_ENGINE=django.db.backends.postgresql \
|
||||||
-e MAYAN_DATABASE_HOST=172.17.0.1 \
|
$MAYAN_DATABASE_HOST_ARGUMENT \
|
||||||
|
$MAYAN_DATABASE_PORT_ARGUMENT \
|
||||||
-e MAYAN_DATABASE_NAME=$DATABASE_NAME \
|
-e MAYAN_DATABASE_NAME=$DATABASE_NAME \
|
||||||
-e MAYAN_DATABASE_PASSWORD=$DATABASE_PASSWORD \
|
-e MAYAN_DATABASE_PASSWORD=$DATABASE_PASSWORD \
|
||||||
-e MAYAN_DATABASE_USER=$DATABASE_USER \
|
-e MAYAN_DATABASE_USER=$DATABASE_USER \
|
||||||
-e MAYAN_DATABASE_PORT=$DOCKER_POSTGRES_PORT \
|
|
||||||
-e MAYAN_DATABASE_CONN_MAX_AGE=0 \
|
-e MAYAN_DATABASE_CONN_MAX_AGE=0 \
|
||||||
|
$MAYAN_BROKER_URL_ARGUMENT \
|
||||||
|
$MAYAN_CELERY_RESULT_BACKEND_ARGUMENT \
|
||||||
-v $DOCKER_MAYAN_VOLUME:/var/lib/mayan \
|
-v $DOCKER_MAYAN_VOLUME:/var/lib/mayan \
|
||||||
$DOCKER_MAYAN_IMAGE >/dev/null
|
$DOCKER_MAYAN_IMAGE >/dev/null
|
||||||
echo "Done"
|
echo "Done"
|
||||||
|
|||||||
@@ -1,171 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# ====== CONFIG ======
|
|
||||||
INSTALLATION_DIRECTORY=/usr/share/mayan-edms/
|
|
||||||
DB_NAME=mayan_edms
|
|
||||||
DB_USERNAME=mayan
|
|
||||||
DB_PASSWORD=test123
|
|
||||||
# ==== END CONFIG ====
|
|
||||||
|
|
||||||
cat << EOF | tee -a /etc/motd.tail
|
|
||||||
**********************************
|
|
||||||
|
|
||||||
Mayan EDMS Vagrant Production Box
|
|
||||||
|
|
||||||
**********************************
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Running apt-get update & upgrade \n"
|
|
||||||
apt-get -qq update
|
|
||||||
apt-get -y upgrade
|
|
||||||
|
|
||||||
echo -e "\n -> Installing core binaries \n"
|
|
||||||
apt-get install nginx supervisor redis-server postgresql libpq-dev libjpeg-dev libmagic1 libpng-dev libreoffice libtiff-dev gcc ghostscript gpgv python-dev python-virtualenv tesseract-ocr poppler-utils -y
|
|
||||||
|
|
||||||
echo -e "\n -> Setting up virtualenv \n"
|
|
||||||
rm -f ${INSTALLATION_DIRECTORY}
|
|
||||||
virtualenv ${INSTALLATION_DIRECTORY}
|
|
||||||
source ${INSTALLATION_DIRECTORY}bin/activate
|
|
||||||
|
|
||||||
echo -e "\n -> Installing Mayan EDMS from PyPI \n"
|
|
||||||
pip install mayan-edms
|
|
||||||
|
|
||||||
echo -e "\n -> Installing Python client for PostgreSQL, Redis, and uWSGI \n"
|
|
||||||
pip install psycopg2 redis uwsgi
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the database for the installation \n"
|
|
||||||
echo "CREATE USER mayan WITH PASSWORD '$DB_PASSWORD';" | sudo -u postgres psql
|
|
||||||
sudo -u postgres createdb -O $DB_USERNAME $DB_NAME
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the directories for the logs \n"
|
|
||||||
mkdir /var/log/mayan
|
|
||||||
|
|
||||||
echo -e "\n -> Making a convenience symlink \n"
|
|
||||||
cd ${INSTALLATION_DIRECTORY}
|
|
||||||
ln -s lib/python2.7/site-packages/mayan .
|
|
||||||
|
|
||||||
echo -e "\n -> Creating an initial settings file \n"
|
|
||||||
mayan-edms.py createsettings
|
|
||||||
|
|
||||||
echo -e "\n -> Updating the mayan/settings/local.py file \n"
|
|
||||||
cat >> mayan/settings/local.py << EOF
|
|
||||||
DATABASES = {
|
|
||||||
'default': {
|
|
||||||
'ENGINE': 'django.db.backends.postgresql_psycopg2',
|
|
||||||
'NAME': '$DB_NAME',
|
|
||||||
'USER': '$DB_USERNAME',
|
|
||||||
'PASSWORD': '$DB_PASSWORD',
|
|
||||||
'HOST': 'localhost',
|
|
||||||
'PORT': '5432',
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
BROKER_URL = 'redis://127.0.0.1:6379/0'
|
|
||||||
CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/0'
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Migrating the database or initialize the project \n"
|
|
||||||
mayan-edms.py initialsetup
|
|
||||||
|
|
||||||
echo -e "\n -> Disabling the default NGINX site \n"
|
|
||||||
rm -f /etc/nginx/sites-enabled/default
|
|
||||||
|
|
||||||
echo -e "\n -> Creating a uwsgi.ini file \n"
|
|
||||||
cat > uwsgi.ini << EOF
|
|
||||||
[uwsgi]
|
|
||||||
chdir = ${INSTALLATION_DIRECTORY}lib/python2.7/site-packages/mayan
|
|
||||||
chmod-socket = 664
|
|
||||||
chown-socket = www-data:www-data
|
|
||||||
env = DJANGO_SETTINGS_MODULE=mayan.settings.production
|
|
||||||
gid = www-data
|
|
||||||
logto = /var/log/uwsgi/%n.log
|
|
||||||
pythonpath = ${INSTALLATION_DIRECTORY}lib/python2.7/site-packages
|
|
||||||
master = True
|
|
||||||
max-requests = 5000
|
|
||||||
socket = ${INSTALLATION_DIRECTORY}uwsgi.sock
|
|
||||||
uid = www-data
|
|
||||||
vacuum = True
|
|
||||||
wsgi-file = ${INSTALLATION_DIRECTORY}lib/python2.7/site-packages/mayan/wsgi.py
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the directory for the uWSGI log files \n"
|
|
||||||
mkdir -p /var/log/uwsgi
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the NGINX site file for Mayan EDMS, /etc/nginx/sites-available/mayan \n"
|
|
||||||
cat > /etc/nginx/sites-available/mayan << EOF
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
server_name localhost;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
include uwsgi_params;
|
|
||||||
uwsgi_pass unix:${INSTALLATION_DIRECTORY}uwsgi.sock;
|
|
||||||
|
|
||||||
client_max_body_size 30M; # Increse if your plan to upload bigger documents
|
|
||||||
proxy_read_timeout 30s; # Increase if your document uploads take more than 30 seconds
|
|
||||||
}
|
|
||||||
|
|
||||||
location /static {
|
|
||||||
alias ${INSTALLATION_DIRECTORY}mayan/media/static;
|
|
||||||
expires 1h;
|
|
||||||
}
|
|
||||||
|
|
||||||
location /favicon.ico {
|
|
||||||
alias ${INSTALLATION_DIRECTORY}mayan/media/static/appearance/images/favicon.ico;
|
|
||||||
expires 1h;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Enabling the NGINX site for Mayan EDMS \n"
|
|
||||||
ln -s /etc/nginx/sites-available/mayan /etc/nginx/sites-enabled/
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the supervisor file for the uWSGI process, /etc/supervisor/conf.d/mayan-uwsgi.conf \n"
|
|
||||||
cat > /etc/supervisor/conf.d/mayan-uwsgi.conf << EOF
|
|
||||||
[program:mayan-uwsgi]
|
|
||||||
command = ${INSTALLATION_DIRECTORY}bin/uwsgi --ini ${INSTALLATION_DIRECTORY}uwsgi.ini
|
|
||||||
user = root
|
|
||||||
autostart = true
|
|
||||||
autorestart = true
|
|
||||||
redirect_stderr = true
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Creating the supervisor file for the Celery worker, /etc/supervisor/conf.d/mayan-celery.conf \n"
|
|
||||||
cat > /etc/supervisor/conf.d/mayan-celery.conf << EOF
|
|
||||||
[program:mayan-worker]
|
|
||||||
command = ${INSTALLATION_DIRECTORY}bin/python ${INSTALLATION_DIRECTORY}bin/mayan-edms.py celery --settings=mayan.settings.production worker -Ofair -l ERROR
|
|
||||||
directory = ${INSTALLATION_DIRECTORY}
|
|
||||||
user = www-data
|
|
||||||
stdout_logfile = /var/log/mayan/worker-stdout.log
|
|
||||||
stderr_logfile = /var/log/mayan/worker-stderr.log
|
|
||||||
autostart = true
|
|
||||||
autorestart = true
|
|
||||||
startsecs = 10
|
|
||||||
stopwaitsecs = 10
|
|
||||||
killasgroup = true
|
|
||||||
priority = 998
|
|
||||||
|
|
||||||
[program:mayan-beat]
|
|
||||||
command = ${INSTALLATION_DIRECTORY}bin/python ${INSTALLATION_DIRECTORY}bin/mayan-edms.py celery --settings=mayan.settings.production beat -l ERROR
|
|
||||||
directory = ${INSTALLATION_DIRECTORY}
|
|
||||||
user = www-data
|
|
||||||
numprocs = 1
|
|
||||||
stdout_logfile = /var/log/mayan/beat-stdout.log
|
|
||||||
stderr_logfile = /var/log/mayan/beat-stderr.log
|
|
||||||
autostart = true
|
|
||||||
autorestart = true
|
|
||||||
startsecs = 10
|
|
||||||
stopwaitsecs = 1
|
|
||||||
killasgroup = true
|
|
||||||
priority = 998
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo -e "\n -> Collecting the static files \n"
|
|
||||||
mayan-edms.py preparestatic --noinput
|
|
||||||
|
|
||||||
echo -e "\n -> Making the installation directory readable and writable by the webserver user \n"
|
|
||||||
chown www-data:www-data ${INSTALLATION_DIRECTORY} -R
|
|
||||||
|
|
||||||
echo -e "\n -> Restarting the services \n"
|
|
||||||
/etc/init.d/nginx restart
|
|
||||||
/etc/init.d/supervisor restart
|
|
||||||
@@ -13,11 +13,12 @@ APP_LIST = (
|
|||||||
'checkouts', 'common', 'converter', 'dashboards', 'dependencies',
|
'checkouts', 'common', 'converter', 'dashboards', 'dependencies',
|
||||||
'django_gpg', 'document_comments', 'document_indexing',
|
'django_gpg', 'document_comments', 'document_indexing',
|
||||||
'document_parsing', 'document_signatures', 'document_states',
|
'document_parsing', 'document_signatures', 'document_states',
|
||||||
'documents', 'dynamic_search', 'events', 'file_metadata', 'linking',
|
'documents', 'dynamic_search', 'events', 'file_caching',
|
||||||
'lock_manager', 'mayan_statistics', 'mailer', 'metadata', 'mirroring',
|
'file_metadata', 'linking', 'lock_manager', 'mailer',
|
||||||
'motd', 'navigation', 'ocr', 'permissions', 'platform', 'rest_api',
|
'mayan_statistics', 'metadata', 'mirroring', 'motd', 'navigation',
|
||||||
'smart_settings', 'sources', 'storage', 'tags', 'task_manager',
|
'ocr', 'permissions', 'platform', 'rest_api', 'smart_settings',
|
||||||
'user_management'
|
'sources', 'storage', 'tags', 'task_manager', 'user_management',
|
||||||
|
'weblinks'
|
||||||
)
|
)
|
||||||
|
|
||||||
LANGUAGE_LIST = (
|
LANGUAGE_LIST = (
|
||||||
|
|||||||
@@ -1,35 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
NAME="mayan-edms"
|
|
||||||
DJANGODIR=/usr/share/mayan-edms
|
|
||||||
SOCKFILE=/var/tmp/filesystem.sock
|
|
||||||
USER=www-data
|
|
||||||
GROUP=www-data
|
|
||||||
NUM_WORKERS=3
|
|
||||||
DJANGO_SETTINGS_MODULE=mayan.settings.production
|
|
||||||
DJANGO_WSGI_MODULE=mayan.wsgi
|
|
||||||
TIMEOUT=600
|
|
||||||
|
|
||||||
echo "Starting $NAME as `whoami`"
|
|
||||||
|
|
||||||
# Activate the virtual environment
|
|
||||||
cd $DJANGODIR
|
|
||||||
source bin/activate
|
|
||||||
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
|
|
||||||
export PYTHONPATH=$DJANGODIR:$PYTHONPATH
|
|
||||||
|
|
||||||
# Create the run directory if it doesn't exist
|
|
||||||
RUNDIR=$(dirname $SOCKFILE)
|
|
||||||
test -d $RUNDIR || mkdir -p $RUNDIR
|
|
||||||
|
|
||||||
# Start your Django Unicorn
|
|
||||||
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
|
|
||||||
exec bin/gunicorn ${DJANGO_WSGI_MODULE}:application \
|
|
||||||
--name $NAME \
|
|
||||||
--workers $NUM_WORKERS \
|
|
||||||
--user=$USER --group=$GROUP \
|
|
||||||
--log-level=debug \
|
|
||||||
--bind=unix:$SOCKFILE \
|
|
||||||
--timeout=$TIMEOUT
|
|
||||||
|
|
||||||
|
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
# BASE_IMAGE - Bare bones image with the base packages needed to run Mayan EDMS
|
# BASE_IMAGE - Bare bones image with the base packages needed to run Mayan EDMS
|
||||||
####
|
####
|
||||||
|
|
||||||
FROM debian:9.8-slim as BASE_IMAGE
|
FROM debian:10.0-slim as BASE_IMAGE
|
||||||
|
|
||||||
LABEL maintainer="Roberto Rosario roberto.rosario@mayan-edms.com"
|
LABEL maintainer="Roberto Rosario roberto.rosario@mayan-edms.com"
|
||||||
|
|
||||||
@@ -22,18 +22,21 @@ RUN set -x \
|
|||||||
&& DEBIAN_FRONTEND=noninteractive \
|
&& DEBIAN_FRONTEND=noninteractive \
|
||||||
apt-get update \
|
apt-get update \
|
||||||
&& apt-get install -y --no-install-recommends \
|
&& apt-get install -y --no-install-recommends \
|
||||||
|
ca-certificates \
|
||||||
exiftool \
|
exiftool \
|
||||||
|
fonts-arphic-uming \
|
||||||
|
fonts-arphic-ukai \
|
||||||
ghostscript \
|
ghostscript \
|
||||||
gpgv \
|
gpgv \
|
||||||
gnupg1 \
|
gnupg1 \
|
||||||
graphviz \
|
graphviz \
|
||||||
libfuse2 \
|
libfuse2 \
|
||||||
libmagic1 \
|
libmagic1 \
|
||||||
libmariadbclient18 \
|
libmariadb3 \
|
||||||
libreoffice \
|
libreoffice \
|
||||||
libpq5 \
|
libpq5 \
|
||||||
poppler-utils \
|
poppler-utils \
|
||||||
redis-server \
|
python3-distutils \
|
||||||
sane-utils \
|
sane-utils \
|
||||||
sudo \
|
sudo \
|
||||||
supervisor \
|
supervisor \
|
||||||
@@ -52,22 +55,20 @@ apt-get update \
|
|||||||
&& if [ "$(uname -m)" = "armv7l" ]; then \
|
&& if [ "$(uname -m)" = "armv7l" ]; then \
|
||||||
ln -s /usr/lib/arm-linux-gnueabihf/libz.so /usr/lib/ \
|
ln -s /usr/lib/arm-linux-gnueabihf/libz.so /usr/lib/ \
|
||||||
&& ln -s /usr/lib/arm-linux-gnueabihf/libjpeg.so /usr/lib/ \
|
&& ln -s /usr/lib/arm-linux-gnueabihf/libjpeg.so /usr/lib/ \
|
||||||
; fi \
|
; fi
|
||||||
# Discard data when Redis runs out of memory
|
|
||||||
&& echo "maxmemory-policy allkeys-lru" >> /etc/redis/redis.conf \
|
|
||||||
# Disable saving the Redis database
|
|
||||||
echo "save \"\"" >> /etc/redis/redis.conf \
|
|
||||||
# Only provision 1 database
|
|
||||||
&& echo "databases 1" >> /etc/redis/redis.conf
|
|
||||||
|
|
||||||
|
|
||||||
####
|
####
|
||||||
# BUILDER_IMAGE - This image buildS the Python package and is discarded afterwards
|
# BUILDER_IMAGE - This image builds the Python package and is discarded afterwards
|
||||||
|
# only the build artifact is carried over to the next image.
|
||||||
####
|
####
|
||||||
|
|
||||||
# Reuse image
|
# Reuse image
|
||||||
FROM BASE_IMAGE as BUILDER_IMAGE
|
FROM BASE_IMAGE as BUILDER_IMAGE
|
||||||
|
|
||||||
|
# Python libraries caching
|
||||||
|
ARG PIP_INDEX_URL
|
||||||
|
ARG PIP_TRUSTED_HOST
|
||||||
|
|
||||||
WORKDIR /src
|
WORKDIR /src
|
||||||
|
|
||||||
# Copy the source files needed to build the Python package
|
# Copy the source files needed to build the Python package
|
||||||
@@ -96,39 +97,40 @@ apt-get install -y --no-install-recommends \
|
|||||||
libssl-dev \
|
libssl-dev \
|
||||||
g++ \
|
g++ \
|
||||||
gcc \
|
gcc \
|
||||||
python-dev \
|
python3-dev \
|
||||||
python-virtualenv \
|
python3-venv \
|
||||||
&& mkdir -p "${PROJECT_INSTALL_DIR}" \
|
&& mkdir -p "${PROJECT_INSTALL_DIR}" \
|
||||||
&& chown -R mayan:mayan "${PROJECT_INSTALL_DIR}" \
|
&& chown -R mayan:mayan "${PROJECT_INSTALL_DIR}" \
|
||||||
&& chown -R mayan:mayan /src
|
&& chown -R mayan:mayan /src
|
||||||
|
|
||||||
USER mayan
|
USER mayan
|
||||||
RUN python -m virtualenv "${PROJECT_INSTALL_DIR}" \
|
RUN python3 -m venv "${PROJECT_INSTALL_DIR}" \
|
||||||
&& . "${PROJECT_INSTALL_DIR}/bin/activate" \
|
&& . "${PROJECT_INSTALL_DIR}/bin/activate" \
|
||||||
&& pip install --no-cache-dir --no-use-pep517 \
|
&& pip install --no-cache-dir \
|
||||||
librabbitmq==1.6.1 \
|
librabbitmq==2.0.0 \
|
||||||
mysql-python==1.2.5 \
|
mysqlclient==1.4.2.post1 \
|
||||||
psycopg2==2.7.3.2 \
|
psycopg2==2.8.3 \
|
||||||
redis==2.10.6 \
|
redis==3.2.1 \
|
||||||
|
flower==0.9.3 \
|
||||||
# psutil is needed by ARM builds otherwise gevent and gunicorn fail to start
|
# psutil is needed by ARM builds otherwise gevent and gunicorn fail to start
|
||||||
&& UNAME=`uname -m` && if [ "${UNAME#*arm}" != $UNAME ]; then \
|
&& UNAME=`uname -m` && if [ "${UNAME#*arm}" != $UNAME ]; then \
|
||||||
pip install --no-cache-dir --no-use-pep517 \
|
pip install --no-cache-dir \
|
||||||
psutil==5.6.2 \
|
psutil==5.6.2 \
|
||||||
; fi \
|
; fi \
|
||||||
# Install the Python packages needed to build Mayan EDMS
|
# Install the Python packages needed to build Mayan EDMS
|
||||||
&& pip install --no-cache-dir --no-use-pep517 -r /src/requirements/build.txt \
|
&& pip install --no-cache-dir -r /src/requirements/build.txt \
|
||||||
# Build Mayan EDMS
|
# Build Mayan EDMS
|
||||||
&& python setup.py sdist \
|
&& python3 setup.py sdist \
|
||||||
# Install the built Mayan EDMS package
|
# Install the built Mayan EDMS package
|
||||||
&& pip install --no-cache-dir --no-use-pep517 dist/mayan* \
|
&& pip install --no-cache-dir dist/mayan* \
|
||||||
# Install the static content
|
# Install the static content
|
||||||
&& mayan-edms.py installjavascript \
|
&& mayan-edms.py installdependencies \
|
||||||
&& MAYAN_STATIC_ROOT=${PROJECT_INSTALL_DIR}/static mayan-edms.py preparestatic --link --noinput
|
&& MAYAN_STATIC_ROOT=${PROJECT_INSTALL_DIR}/static mayan-edms.py preparestatic --link --noinput
|
||||||
|
|
||||||
COPY --chown=mayan:mayan requirements/testing-base.txt "${PROJECT_INSTALL_DIR}"
|
COPY --chown=mayan:mayan requirements/testing-base.txt "${PROJECT_INSTALL_DIR}"
|
||||||
|
|
||||||
####
|
####
|
||||||
# Final image - BASE_IMAGE + Mayan install directory from the builder image
|
# Final image - BASE_IMAGE + BUILDER_IMAGE artifact (Mayan install directory)
|
||||||
####
|
####
|
||||||
|
|
||||||
FROM BASE_IMAGE
|
FROM BASE_IMAGE
|
||||||
@@ -144,7 +146,7 @@ VOLUME ["/var/lib/mayan"]
|
|||||||
ENTRYPOINT ["entrypoint.sh"]
|
ENTRYPOINT ["entrypoint.sh"]
|
||||||
|
|
||||||
EXPOSE 8000
|
EXPOSE 8000
|
||||||
CMD ["mayan"]
|
CMD ["run_all"]
|
||||||
|
|
||||||
RUN ${PROJECT_INSTALL_DIR}/bin/mayan-edms.py platformtemplate supervisord_docker > /etc/supervisor/conf.d/mayan.conf \
|
RUN ${PROJECT_INSTALL_DIR}/bin/mayan-edms.py platformtemplate supervisord_docker > /etc/supervisor/conf.d/mayan.conf \
|
||||||
&& apt-get clean autoclean \
|
&& apt-get clean autoclean \
|
||||||
|
|||||||
@@ -1,4 +1,9 @@
|
|||||||
APT_PROXY ?= `/sbin/ip route|awk '/docker0/ { print $$9 }'`:3142
|
HOST_IP = `/sbin/ip route|awk '/docker0/ { print $$9 }'`
|
||||||
|
|
||||||
|
APT_PROXY ?= $(HOST_IP):3142
|
||||||
|
PIP_INDEX_URL ?= http://$(HOST_IP):3141/root/pypi/+simple/
|
||||||
|
PIP_TRUSTED_HOST ?= $(HOST_IP)
|
||||||
|
|
||||||
IMAGE_VERSION ?= `cat docker/rootfs/version`
|
IMAGE_VERSION ?= `cat docker/rootfs/version`
|
||||||
CONSOLE_COLUMNS ?= `echo $$(tput cols)`
|
CONSOLE_COLUMNS ?= `echo $$(tput cols)`
|
||||||
CONSOLE_LINES ?= `echo $$(tput lines)`
|
CONSOLE_LINES ?= `echo $$(tput lines)`
|
||||||
@@ -7,7 +12,7 @@ docker-build: ## Build a new image locally.
|
|||||||
docker build -t mayanedms/mayanedms:$(IMAGE_VERSION) -f docker/Dockerfile .
|
docker build -t mayanedms/mayanedms:$(IMAGE_VERSION) -f docker/Dockerfile .
|
||||||
|
|
||||||
docker-build-with-proxy: ## Build a new image locally using an APT proxy as APT_PROXY.
|
docker-build-with-proxy: ## Build a new image locally using an APT proxy as APT_PROXY.
|
||||||
docker build -t mayanedms/mayanedms:$(IMAGE_VERSION) -f docker/Dockerfile --build-arg APT_PROXY=$(APT_PROXY) .
|
docker build -t mayanedms/mayanedms:$(IMAGE_VERSION) -f docker/Dockerfile --build-arg APT_PROXY=$(APT_PROXY) --build-arg PIP_INDEX_URL=$(PIP_INDEX_URL) --build-arg PIP_TRUSTED_HOST=$(PIP_TRUSTED_HOST) --build-arg HTTP_PROXY=$(HTTP_PROXY) --build-arg HTTPS_PROXY=$(HTTPS_PROXY) .
|
||||||
|
|
||||||
docker-shell: ## Launch a bash instance inside a running container. Pass the container name via DOCKER_CONTAINER.
|
docker-shell: ## Launch a bash instance inside a running container. Pass the container name via DOCKER_CONTAINER.
|
||||||
docker exec -e TERM=$(TERM) -e "COLUMNS=$(CONSOLE_COLUMNS)" -e "LINES=$(CONSOLE_LINES)" -it $(DOCKER_CONTAINER) /bin/bash
|
docker exec -e TERM=$(TERM) -e "COLUMNS=$(CONSOLE_COLUMNS)" -e "LINES=$(CONSOLE_LINES)" -it $(DOCKER_CONTAINER) /bin/bash
|
||||||
@@ -23,3 +28,13 @@ docker-test-cleanup: ## Delete the test container and the test volume.
|
|||||||
docker-test-all: ## Build and executed the test suite in a test container.
|
docker-test-all: ## Build and executed the test suite in a test container.
|
||||||
docker-test-all: docker-build-with-proxy
|
docker-test-all: docker-build-with-proxy
|
||||||
docker run --rm run-tests
|
docker run --rm run-tests
|
||||||
|
|
||||||
|
docker-compose-build:
|
||||||
|
docker-compose -f docker/docker-compose.yml -p mayan-edms build
|
||||||
|
|
||||||
|
docker-compose-build-with-proxy:
|
||||||
|
docker-compose -f docker/docker-compose.yml -p mayan-edms build --build-arg APT_PROXY=$(APT_PROXY) --build-arg PIP_INDEX_URL=$(PIP_INDEX_URL) --build-arg PIP_TRUSTED_HOST=$(PIP_TRUSTED_HOST) --build-arg HTTP_PROXY=$(HTTP_PROXY) --build-arg HTTPS_PROXY=$(HTTPS_PROXY)
|
||||||
|
|
||||||
|
docker-compose-up:
|
||||||
|
docker-compose -f docker/docker-compose.yml -p mayan-edms up
|
||||||
|
|
||||||
|
|||||||
@@ -1,72 +0,0 @@
|
|||||||
version: '2.1'
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
broker:
|
|
||||||
driver: local
|
|
||||||
app:
|
|
||||||
driver: local
|
|
||||||
db:
|
|
||||||
driver: local
|
|
||||||
results:
|
|
||||||
driver: local
|
|
||||||
|
|
||||||
services:
|
|
||||||
broker:
|
|
||||||
container_name: mayan-edms-broker
|
|
||||||
image: healthcheck/rabbitmq
|
|
||||||
environment:
|
|
||||||
RABBITMQ_DEFAULT_USER: mayan
|
|
||||||
RABBITMQ_DEFAULT_PASS: mayan
|
|
||||||
RABBITMQ_DEFAULT_VHOST: mayan
|
|
||||||
volumes:
|
|
||||||
- broker:/var/lib/rabbitmq
|
|
||||||
results:
|
|
||||||
container_name: mayan-edms-results
|
|
||||||
image: healthcheck/redis
|
|
||||||
volumes:
|
|
||||||
- results:/data
|
|
||||||
#db:
|
|
||||||
# container_name: mayan-edms-db
|
|
||||||
# image: healthcheck/mysql
|
|
||||||
# environment:
|
|
||||||
# MYSQL_DATABASE: mayan
|
|
||||||
# MYSQL_PASSWORD: mayan-password
|
|
||||||
# MYSQL_ROOT_PASSWORD: root-password
|
|
||||||
# MYSQL_USER: mayan
|
|
||||||
# volumes:
|
|
||||||
# - db:/var/lib/mysql
|
|
||||||
db:
|
|
||||||
container_name: mayan-edms-db
|
|
||||||
image: healthcheck/postgres
|
|
||||||
environment:
|
|
||||||
POSTGRES_DB: mayan
|
|
||||||
POSTGRES_PASSWORD: mayan-password
|
|
||||||
POSTGRES_USER: mayan
|
|
||||||
volumes:
|
|
||||||
- db:/var/lib/postgresql/data
|
|
||||||
mayan-edms:
|
|
||||||
container_name: mayan-edms-app
|
|
||||||
image: mayan-edms/next
|
|
||||||
build:
|
|
||||||
context: ./
|
|
||||||
args:
|
|
||||||
- APT_PROXY=172.18.0.1:3142
|
|
||||||
depends_on:
|
|
||||||
broker:
|
|
||||||
condition: service_healthy
|
|
||||||
db:
|
|
||||||
condition: service_healthy
|
|
||||||
results:
|
|
||||||
condition: service_healthy
|
|
||||||
environment:
|
|
||||||
MAYAN_BROKER_URL: amqp://mayan:mayan@broker:5672/mayan
|
|
||||||
MAYAN_CELERY_RESULT_BACKEND: redis://results:6379/0
|
|
||||||
MAYAN_DATABASE_ENGINE: django.db.backends.postgresql
|
|
||||||
MAYAN_DATABASE_HOST: db
|
|
||||||
MAYAN_DATABASE_NAME: mayan
|
|
||||||
MAYAN_DATABASE_PASSWORD: mayan-password
|
|
||||||
MAYAN_DATABASE_USER: mayan
|
|
||||||
ports:
|
|
||||||
- "80:80"
|
|
||||||
volumes:
|
|
||||||
- app:/var/lib/mayan
|
|
||||||
@@ -1,58 +1,130 @@
|
|||||||
version: '2.1'
|
version: '3.7'
|
||||||
|
|
||||||
volumes:
|
networks:
|
||||||
broker:
|
mayan-bridge:
|
||||||
driver: local
|
driver: bridge
|
||||||
app:
|
|
||||||
driver: local
|
|
||||||
db:
|
|
||||||
driver: local
|
|
||||||
results:
|
|
||||||
driver: local
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
broker:
|
app:
|
||||||
container_name: mayan-edms-broker
|
build:
|
||||||
image: healthcheck/rabbitmq
|
context: ..
|
||||||
environment:
|
dockerfile: ./docker/Dockerfile
|
||||||
RABBITMQ_DEFAULT_USER: mayan
|
|
||||||
RABBITMQ_DEFAULT_PASS: mayan
|
|
||||||
RABBITMQ_DEFAULT_VHOST: mayan
|
|
||||||
volumes:
|
|
||||||
- broker:/var/lib/rabbitmq
|
|
||||||
results:
|
|
||||||
container_name: mayan-edms-results
|
|
||||||
image: healthcheck/redis
|
|
||||||
volumes:
|
|
||||||
- results:/data
|
|
||||||
db:
|
|
||||||
container_name: mayan-edms-db
|
|
||||||
image: healthcheck/postgres
|
|
||||||
environment:
|
|
||||||
POSTGRES_DB: mayan
|
|
||||||
POSTGRES_PASSWORD: mayan-password
|
|
||||||
POSTGRES_USER: mayan
|
|
||||||
volumes:
|
|
||||||
- db:/var/lib/postgresql/data
|
|
||||||
mayan-edms:
|
|
||||||
container_name: mayan-edms-app
|
|
||||||
image: mayanedms/mayanedms:latest
|
|
||||||
depends_on:
|
depends_on:
|
||||||
broker:
|
- postgresql
|
||||||
condition: service_healthy
|
- redis
|
||||||
db:
|
# Enable to use RabbitMQ
|
||||||
condition: service_healthy
|
#- rabbitmq
|
||||||
results:
|
environment: &mayan_env
|
||||||
condition: service_healthy
|
# Enable to use RabbitMQ
|
||||||
environment:
|
# MAYAN_CELERY_BROKER_URL: amqp://mayan:mayanrabbitpass@broker:5672/mayan
|
||||||
MAYAN_BROKER_URL: amqp://mayan:mayan@broker:5672/mayan
|
# Disable Redis Broker to use RabbitMQ as Broker
|
||||||
MAYAN_CELERY_RESULT_BACKEND: redis://results:6379/0
|
MAYAN_CELERY_BROKER_URL: redis://redis:6379/1
|
||||||
MAYAN_DATABASE_ENGINE: django.db.backends.postgresql
|
MAYAN_CELERY_RESULT_BACKEND: redis://redis:6379/0
|
||||||
MAYAN_DATABASE_HOST: db
|
MAYAN_DATABASES: "{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayandbpass','USER':'mayan','HOST':'postgresql'}}"
|
||||||
MAYAN_DATABASE_NAME: mayan
|
image: mayanedms/mayanedms:3.2.6
|
||||||
MAYAN_DATABASE_PASSWORD: mayan-password
|
networks:
|
||||||
MAYAN_DATABASE_USER: mayan
|
- mayan-bridge
|
||||||
ports:
|
ports:
|
||||||
- "80:8000"
|
- "80:8000"
|
||||||
|
restart: unless-stopped
|
||||||
volumes:
|
volumes:
|
||||||
- app:/var/lib/mayan
|
- /docker-volumes/mayan-edms/media:/var/lib/mayan
|
||||||
|
|
||||||
|
postgresql:
|
||||||
|
environment:
|
||||||
|
POSTGRES_DB: mayan
|
||||||
|
POSTGRES_PASSWORD: mayandbpass
|
||||||
|
POSTGRES_USER: mayan
|
||||||
|
image: postgres:9.6
|
||||||
|
networks:
|
||||||
|
- mayan-bridge
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- /docker-volumes/mayan-edms/postgres:/var/lib/postgresql/data
|
||||||
|
|
||||||
|
redis:
|
||||||
|
command:
|
||||||
|
- redis-server
|
||||||
|
- --databases
|
||||||
|
- "2"
|
||||||
|
- --maxmemory-policy
|
||||||
|
- allkeys-lru
|
||||||
|
- --save
|
||||||
|
- ""
|
||||||
|
image: redis:5.0
|
||||||
|
networks:
|
||||||
|
- mayan-bridge
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
# Optional services
|
||||||
|
|
||||||
|
# celery_flower:
|
||||||
|
# command:
|
||||||
|
# - run_celery
|
||||||
|
# - flower
|
||||||
|
# depends_on:
|
||||||
|
# - postgresql
|
||||||
|
# - redis
|
||||||
|
# # Enable to use RabbitMQ
|
||||||
|
# # - rabbitmq
|
||||||
|
# environment:
|
||||||
|
# <<: *mayan_env
|
||||||
|
# image: mayanedms/mayanedms:3.2.6
|
||||||
|
# networks:
|
||||||
|
# - mayan-bridge
|
||||||
|
# ports:
|
||||||
|
# - "5555:5555"
|
||||||
|
# restart: unless-stopped
|
||||||
|
|
||||||
|
# Enable to use RabbitMQ
|
||||||
|
# rabbitmq:
|
||||||
|
# container_name: mayan-edms-rabbitmq
|
||||||
|
# image: healthcheck/rabbitmq
|
||||||
|
# environment:
|
||||||
|
# RABBITMQ_DEFAULT_USER: mayan
|
||||||
|
# RABBITMQ_DEFAULT_PASS: mayanrabbitpass
|
||||||
|
# RABBITMQ_DEFAULT_VHOST: mayan
|
||||||
|
# networks:
|
||||||
|
# - mayan-bridge
|
||||||
|
# restart: unless-stopped
|
||||||
|
# volumes:
|
||||||
|
# - /docker-volumes/mayan-edms/rabbitmq:/var/lib/rabbitmq
|
||||||
|
|
||||||
|
# Enable to run stand alone workers
|
||||||
|
# worker_fast:
|
||||||
|
# command:
|
||||||
|
# - run_worker
|
||||||
|
# - fast
|
||||||
|
# depends_on:
|
||||||
|
# - postgresql
|
||||||
|
# - redis
|
||||||
|
# # Enable to use RabbitMQ
|
||||||
|
# # - rabbitmq
|
||||||
|
# environment:
|
||||||
|
# <<: *mayan_env
|
||||||
|
# image: mayanedms/mayanedms:3.2.6
|
||||||
|
# networks:
|
||||||
|
# - mayan-bridge
|
||||||
|
# restart: unless-stopped
|
||||||
|
# volumes:
|
||||||
|
# - /docker-volumes/mayan-edms/media:/var/lib/mayan
|
||||||
|
|
||||||
|
# Enable to run stand frontend gunicorn
|
||||||
|
# frontend:
|
||||||
|
# command:
|
||||||
|
# - run_frontend
|
||||||
|
# depends_on:
|
||||||
|
# - postgresql
|
||||||
|
# - redis
|
||||||
|
# # Enable to use RabbitMQ
|
||||||
|
# # - rabbitmq
|
||||||
|
# environment:
|
||||||
|
# <<: *mayan_env
|
||||||
|
# image: mayanedms/mayanedms:3.2.6
|
||||||
|
# networks:
|
||||||
|
# - mayan-bridge
|
||||||
|
# ports:
|
||||||
|
# - "81:8000"
|
||||||
|
# restart: unless-stopped
|
||||||
|
# volumes:
|
||||||
|
# - /docker-volumes/mayan-edms/media:/var/lib/mayan
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Use bash and not sh to support argument slicing "${@:2}"
|
||||||
|
# sh defaults to dash instead of bash.
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
echo "mayan: starting entrypoint.sh"
|
echo "mayan: starting entrypoint.sh"
|
||||||
@@ -11,17 +14,13 @@ DEFAULT_USER_GID=1000
|
|||||||
MAYAN_USER_UID=${MAYAN_USER_UID:-${DEFAULT_USER_UID}}
|
MAYAN_USER_UID=${MAYAN_USER_UID:-${DEFAULT_USER_UID}}
|
||||||
MAYAN_USER_GID=${MAYAN_USER_GID:-${DEFAULT_USER_GID}}
|
MAYAN_USER_GID=${MAYAN_USER_GID:-${DEFAULT_USER_GID}}
|
||||||
|
|
||||||
export MAYAN_DEFAULT_BROKER_URL=redis://127.0.0.1:6379/0
|
|
||||||
export MAYAN_DEFAULT_CELERY_RESULT_BACKEND=redis://127.0.0.1:6379/0
|
|
||||||
|
|
||||||
export MAYAN_ALLOWED_HOSTS='["*"]'
|
export MAYAN_ALLOWED_HOSTS='["*"]'
|
||||||
export MAYAN_BIN=/opt/mayan-edms/bin/mayan-edms.py
|
export MAYAN_BIN=/opt/mayan-edms/bin/mayan-edms.py
|
||||||
export MAYAN_BROKER_URL=${MAYAN_BROKER_URL:-${MAYAN_DEFAULT_BROKER_URL}}
|
|
||||||
export MAYAN_CELERY_RESULT_BACKEND=${MAYAN_CELERY_RESULT_BACKEND:-${MAYAN_DEFAULT_CELERY_RESULT_BACKEND}}
|
|
||||||
export MAYAN_INSTALL_DIR=/opt/mayan-edms
|
export MAYAN_INSTALL_DIR=/opt/mayan-edms
|
||||||
export MAYAN_PYTHON_BIN_DIR=/opt/mayan-edms/bin/
|
export MAYAN_PYTHON_BIN_DIR=/opt/mayan-edms/bin/
|
||||||
export MAYAN_MEDIA_ROOT=/var/lib/mayan
|
export MAYAN_MEDIA_ROOT=/var/lib/mayan
|
||||||
export MAYAN_SETTINGS_MODULE=${MAYAN_SETTINGS_MODULE:-mayan.settings.production}
|
export MAYAN_SETTINGS_MODULE=${MAYAN_SETTINGS_MODULE:-mayan.settings.production}
|
||||||
|
export DJANGO_SETTINGS_MODULE=${MAYAN_SETTINGS_MODULE}
|
||||||
|
|
||||||
export MAYAN_GUNICORN_BIN=${MAYAN_PYTHON_BIN_DIR}gunicorn
|
export MAYAN_GUNICORN_BIN=${MAYAN_PYTHON_BIN_DIR}gunicorn
|
||||||
export MAYAN_GUNICORN_WORKERS=${MAYAN_GUNICORN_WORKERS:-2}
|
export MAYAN_GUNICORN_WORKERS=${MAYAN_GUNICORN_WORKERS:-2}
|
||||||
@@ -29,8 +28,8 @@ export MAYAN_GUNICORN_TIMEOUT=${MAYAN_GUNICORN_TIMEOUT:-120}
|
|||||||
export MAYAN_PIP_BIN=${MAYAN_PYTHON_BIN_DIR}pip
|
export MAYAN_PIP_BIN=${MAYAN_PYTHON_BIN_DIR}pip
|
||||||
export MAYAN_STATIC_ROOT=${MAYAN_INSTALL_DIR}/static
|
export MAYAN_STATIC_ROOT=${MAYAN_INSTALL_DIR}/static
|
||||||
|
|
||||||
MAYAN_WORKER_FAST_CONCURRENCY=${MAYAN_WORKER_FAST_CONCURRENCY:-1}
|
MAYAN_WORKER_FAST_CONCURRENCY=${MAYAN_WORKER_FAST_CONCURRENCY:-0}
|
||||||
MAYAN_WORKER_MEDIUM_CONCURRENCY=${MAYAN_WORKER_MEDIUM_CONCURRENCY:-1}
|
MAYAN_WORKER_MEDIUM_CONCURRENCY=${MAYAN_WORKER_MEDIUM_CONCURRENCY:-0}
|
||||||
MAYAN_WORKER_SLOW_CONCURRENCY=${MAYAN_WORKER_SLOW_CONCURRENCY:-1}
|
MAYAN_WORKER_SLOW_CONCURRENCY=${MAYAN_WORKER_SLOW_CONCURRENCY:-1}
|
||||||
|
|
||||||
update_uid_gid() {
|
update_uid_gid() {
|
||||||
@@ -40,7 +39,7 @@ update_uid_gid() {
|
|||||||
|
|
||||||
if [ ${MAYAN_USER_UID} -ne ${DEFAULT_USER_UID} ] || [ ${MAYAN_USER_GID} -ne ${DEFAULT_USER_GID} ]; then
|
if [ ${MAYAN_USER_UID} -ne ${DEFAULT_USER_UID} ] || [ ${MAYAN_USER_GID} -ne ${DEFAULT_USER_GID} ]; then
|
||||||
echo "mayan: Updating file ownership. This might take a while if there are many documents."
|
echo "mayan: Updating file ownership. This might take a while if there are many documents."
|
||||||
chown mayan:mayan ${MAYAN_INSTALL_DIR} ${MAYAN_STATIC_ROOT} ${MAYAN_MEDIA_ROOT}
|
chown -R mayan:mayan ${MAYAN_INSTALL_DIR} ${MAYAN_STATIC_ROOT} ${MAYAN_MEDIA_ROOT}
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -67,11 +66,9 @@ else
|
|||||||
fi
|
fi
|
||||||
export MAYAN_WORKER_SLOW_CONCURRENCY
|
export MAYAN_WORKER_SLOW_CONCURRENCY
|
||||||
|
|
||||||
export CELERY_ALWAYS_EAGER=False
|
# Allow importing of user setting modules
|
||||||
export PYTHONPATH=$PYTHONPATH:$MAYAN_MEDIA_ROOT
|
export PYTHONPATH=$PYTHONPATH:$MAYAN_MEDIA_ROOT
|
||||||
|
|
||||||
chown mayan:mayan /var/lib/mayan -R
|
|
||||||
|
|
||||||
apt_get_install() {
|
apt_get_install() {
|
||||||
apt-get -q update
|
apt-get -q update
|
||||||
apt-get install -y --force-yes --no-install-recommends --auto-remove "$@"
|
apt-get install -y --force-yes --no-install-recommends --auto-remove "$@"
|
||||||
@@ -79,9 +76,9 @@ apt_get_install() {
|
|||||||
rm -rf /var/lib/apt/lists/*
|
rm -rf /var/lib/apt/lists/*
|
||||||
}
|
}
|
||||||
|
|
||||||
initialize() {
|
initialsetup() {
|
||||||
echo "mayan: initialize()"
|
echo "mayan: initialsetup()"
|
||||||
su mayan -c "${MAYAN_BIN} initialsetup --force --no-javascript"
|
su mayan -c "${MAYAN_BIN} initialsetup --force --no-dependencies"
|
||||||
}
|
}
|
||||||
|
|
||||||
os_package_installs() {
|
os_package_installs() {
|
||||||
@@ -98,43 +95,71 @@ pip_installs() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
start() {
|
run_all() {
|
||||||
echo "mayan: start()"
|
echo "mayan: start()"
|
||||||
rm -rf /var/run/supervisor.sock
|
rm -rf /var/run/supervisor.sock
|
||||||
exec /usr/bin/supervisord -nc /etc/supervisor/supervisord.conf
|
exec /usr/bin/supervisord -nc /etc/supervisor/supervisord.conf
|
||||||
}
|
}
|
||||||
|
|
||||||
upgrade() {
|
performupgrade() {
|
||||||
echo "mayan: upgrade()"
|
echo "mayan: performupgrade()"
|
||||||
su mayan -c "${MAYAN_BIN} performupgrade --no-javascript"
|
su mayan -c "${MAYAN_BIN} performupgrade --no-dependencies"
|
||||||
|
}
|
||||||
|
|
||||||
|
make_ready() {
|
||||||
|
# Check if this is a new install, otherwise try to upgrade the existing
|
||||||
|
# installation on subsequent starts
|
||||||
|
if [ ! -f $INSTALL_FLAG ]; then
|
||||||
|
initialsetup
|
||||||
|
else
|
||||||
|
performupgrade
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
set_uid_guid() {
|
||||||
|
echo "mayan: changing uid/guid"
|
||||||
|
usermod mayan -u ${MAYAN_USER_UID:-${DEFAULT_USER_UID}}
|
||||||
|
groupmod mayan -g ${MAYAN_USER_GID:-${DEFAULT_USER_GID}}
|
||||||
}
|
}
|
||||||
|
|
||||||
os_package_installs || true
|
os_package_installs || true
|
||||||
pip_installs || true
|
pip_installs || true
|
||||||
|
chown mayan:mayan /var/lib/mayan -R
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
|
||||||
mayan) # Check if this is a new install, otherwise try to upgrade the existing
|
run_initialsetup)
|
||||||
# installation on subsequent starts
|
initialsetup
|
||||||
if [ ! -f $INSTALL_FLAG ]; then
|
;;
|
||||||
initialize
|
|
||||||
else
|
|
||||||
upgrade
|
|
||||||
fi
|
|
||||||
start
|
|
||||||
;;
|
|
||||||
|
|
||||||
run-tests) # Check if this is a new install, otherwise try to upgrade the existing
|
run_performupgrade)
|
||||||
# installation on subsequent starts
|
performupgrade
|
||||||
if [ ! -f $INSTALL_FLAG ]; then
|
;;
|
||||||
initialize
|
|
||||||
else
|
|
||||||
upgrade
|
|
||||||
fi
|
|
||||||
run-tests.sh
|
|
||||||
;;
|
|
||||||
|
|
||||||
*) su mayan -c "$@";
|
run_all)
|
||||||
;;
|
make_ready
|
||||||
|
run_all
|
||||||
|
;;
|
||||||
|
|
||||||
|
run_celery)
|
||||||
|
run_celery.sh "${@:2}"
|
||||||
|
;;
|
||||||
|
|
||||||
|
run_frontend)
|
||||||
|
run_frontend.sh
|
||||||
|
;;
|
||||||
|
|
||||||
|
run_tests)
|
||||||
|
make_ready
|
||||||
|
run_tests.sh
|
||||||
|
;;
|
||||||
|
|
||||||
|
run_worker)
|
||||||
|
run_worker.sh "${@:2}"
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
su mayan -c "$@"
|
||||||
|
;;
|
||||||
|
|
||||||
esac
|
esac
|
||||||
|
|||||||
5
docker/rootfs/usr/local/bin/run_celery.sh
Executable file
5
docker/rootfs/usr/local/bin/run_celery.sh
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Use -A and not --app. Both are the same but behave differently
|
||||||
|
# -A can be located before the command while --app cannot.
|
||||||
|
su mayan -c "${MAYAN_PYTHON_BIN_DIR}celery -A mayan $@"
|
||||||
7
docker/rootfs/usr/local/bin/run_frontend.sh
Executable file
7
docker/rootfs/usr/local/bin/run_frontend.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
MAYAN_GUNICORN_MAX_REQUESTS=${MAYAN_GUNICORN_MAX_REQUESTS:-500}
|
||||||
|
MAYAN_GUNICORN_MAX_REQUESTS_JITTERS=${MAYAN_GUNICORN_MAX_REQUESTS_JITTERS:-50}
|
||||||
|
MAYAN_GUNICORN_WORKER_CLASS=${MAYAN_GUNICORN_WORKER_CLASS:-sync}
|
||||||
|
|
||||||
|
su mayan -c "${MAYAN_PYTHON_BIN_DIR}gunicorn -w ${MAYAN_GUNICORN_WORKERS} mayan.wsgi --max-requests ${MAYAN_GUNICORN_MAX_REQUESTS} --max-requests-jitter ${MAYAN_GUNICORN_MAX_REQUESTS_JITTERS} --worker-class ${MAYAN_GUNICORN_WORKER_CLASS} --bind 0.0.0.0:8000 --timeout ${MAYAN_GUNICORN_TIMEOUT}"
|
||||||
8
docker/rootfs/usr/local/bin/run_worker.sh
Executable file
8
docker/rootfs/usr/local/bin/run_worker.sh
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
QUEUE_LIST=`MAYAN_WORKER_NAME=$1 su mayan -c "${MAYAN_PYTHON_BIN_DIR}mayan-edms.py platformtemplate worker_queues"`
|
||||||
|
|
||||||
|
# Use -A and not --app. Both are the same but behave differently
|
||||||
|
# -A can be located before the command while --app cannot.
|
||||||
|
# Pass ${@:2} to allow overriding the defaults arguments
|
||||||
|
su mayan -c "${MAYAN_PYTHON_BIN_DIR}celery -A mayan worker -Ofair -l ERROR -Q $QUEUE_LIST ${@:2}"
|
||||||
@@ -1 +1 @@
|
|||||||
3.2.7
|
3.3beta1
|
||||||
|
|||||||
@@ -9,24 +9,32 @@ volumes:
|
|||||||
services:
|
services:
|
||||||
|
|
||||||
db:
|
db:
|
||||||
image: postgres
|
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: mayan
|
POSTGRES_DB: mayan
|
||||||
POSTGRES_PASSWORD: mayan-password
|
POSTGRES_PASSWORD: mayandbpass
|
||||||
POSTGRES_USER: mayan
|
POSTGRES_USER: mayan
|
||||||
|
image: postgres
|
||||||
volumes:
|
volumes:
|
||||||
- db:/var/lib/postgresql/data
|
- db:/var/lib/postgresql/data
|
||||||
|
|
||||||
app:
|
app:
|
||||||
|
environment:
|
||||||
|
MAYAN_CELERY_BROKER_URL: redis://redis:6379/1
|
||||||
|
MAYAN_CELERY_RESULT_BACKEND: redis://redis:6379/0
|
||||||
|
MAYAN_DATABASES: "{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayandbpass','USER':'mayan','HOST':'db'}}"
|
||||||
image: mayanedms/mayanedms:latest
|
image: mayanedms/mayanedms:latest
|
||||||
ports:
|
ports:
|
||||||
- 80:8000
|
- 80:8000
|
||||||
environment:
|
|
||||||
MAYAN_DATABASE_ENGINE: django.db.backends.postgresql
|
|
||||||
MAYAN_DATABASE_HOST: db
|
|
||||||
MAYAN_DATABASE_NAME: mayan
|
|
||||||
MAYAN_DATABASE_PASSWORD: mayan-password
|
|
||||||
MAYAN_DATABASE_USER: mayan
|
|
||||||
MAYAN_DATABASE_CONN_MAX_AGE: 0
|
|
||||||
volumes:
|
volumes:
|
||||||
- app:/var/lib/mayan
|
- app:/var/lib/mayan
|
||||||
|
|
||||||
|
redis:
|
||||||
|
command:
|
||||||
|
- redis-server
|
||||||
|
- --databases
|
||||||
|
- "2"
|
||||||
|
- --maxmemory-policy
|
||||||
|
- allkeys-lru
|
||||||
|
- --save
|
||||||
|
- ""
|
||||||
|
image: redis:5.0
|
||||||
|
|||||||
@@ -127,9 +127,8 @@ For another setup that offers more performance and scalability refer to the
|
|||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
sudo -u mayan MAYAN_DATABASE_ENGINE=django.db.backends.postgresql MAYAN_DATABASE_NAME=mayan \
|
sudo -u mayan MAYAN_DATABASES="{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayanuserpass','USER':'mayan','HOST':'127.0.0.1'}}" \
|
||||||
MAYAN_DATABASE_PASSWORD=mayanuserpass MAYAN_DATABASE_USER=mayan \
|
MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
MAYAN_DATABASE_HOST=127.0.0.1 MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
|
||||||
/opt/mayan-edms/bin/mayan-edms.py initialsetup
|
/opt/mayan-edms/bin/mayan-edms.py initialsetup
|
||||||
|
|
||||||
|
|
||||||
@@ -148,9 +147,8 @@ For another setup that offers more performance and scalability refer to the
|
|||||||
------------------------------------------------------------------------
|
------------------------------------------------------------------------
|
||||||
::
|
::
|
||||||
|
|
||||||
sudo MAYAN_DATABASE_ENGINE=django.db.backends.postgresql MAYAN_DATABASE_NAME=mayan \
|
sudo mayan MAYAN_DATABASES="{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayanuserpass','USER':'mayan','HOST':'127.0.0.1'}}" \
|
||||||
MAYAN_DATABASE_PASSWORD=mayanuserpass MAYAN_DATABASE_USER=mayan \
|
MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
MAYAN_DATABASE_HOST=127.0.0.1 MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
|
||||||
/opt/mayan-edms/bin/mayan-edms.py platformtemplate supervisord > /etc/supervisor/conf.d/mayan.conf
|
/opt/mayan-edms/bin/mayan-edms.py platformtemplate supervisord > /etc/supervisor/conf.d/mayan.conf
|
||||||
|
|
||||||
|
|
||||||
@@ -222,11 +220,11 @@ of a restart or power failure. The Gunicorn workers are increased to 3.
|
|||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
Replace (paying attention to the comma at the end)::
|
Replace (paying attention to the comma at the end)::
|
||||||
|
|
||||||
MAYAN_BROKER_URL="redis://127.0.0.1:6379/0",
|
MAYAN_CELERY_BROKER_URL="redis://127.0.0.1:6379/0",
|
||||||
|
|
||||||
with::
|
with::
|
||||||
|
|
||||||
MAYAN_BROKER_URL="amqp://mayan:mayanrabbitmqpassword@localhost:5672/mayan",
|
MAYAN_CELERY_BROKER_URL="amqp://mayan:mayanrabbitmqpassword@localhost:5672/mayan",
|
||||||
|
|
||||||
increase the number of Gunicorn workers to 3 in the line (``-w 2`` section)::
|
increase the number of Gunicorn workers to 3 in the line (``-w 2`` section)::
|
||||||
|
|
||||||
|
|||||||
@@ -226,32 +226,46 @@ Git branch structure
|
|||||||
Mayan EDMS follows a simplified model layout based on Vincent Driessen's
|
Mayan EDMS follows a simplified model layout based on Vincent Driessen's
|
||||||
`Successful Git Branching Model`_ blog post.
|
`Successful Git Branching Model`_ blog post.
|
||||||
|
|
||||||
``development``
|
``/versions/micro``
|
||||||
The "next release" branch, likely unstable, don't use in production.
|
Working branch for the next bugfix release. Micro increment (third digit).
|
||||||
|
Only bug fixes, minor features, back-ported urgent features. This
|
||||||
|
branch is stable and safe for production.
|
||||||
|
``/versions/minor``
|
||||||
|
Working branch for the next minor release (second digit). New features,
|
||||||
|
occasional breakage. Not for production but should run in test
|
||||||
|
environment most of the time. This is the branch you will want to
|
||||||
|
try out if you want to check out new features.
|
||||||
|
``/versions/major``
|
||||||
|
Working branch for the next major release (first digit). New features,
|
||||||
|
incompatible changes to the user facing interfaces. Broken most of the
|
||||||
|
time, not for production and should only be cloned by developers
|
||||||
|
with experience with Mayan's development.
|
||||||
``master``
|
``master``
|
||||||
Current production release (|version|). Points to the latest version of
|
Current production release (|version|). Points to the latest version of
|
||||||
the latest series. Production quality code.
|
the latest series. Production quality code.
|
||||||
``feature/``
|
``features/``
|
||||||
Unfinished/unmerged feature. Likely unstable, don't use in production.
|
Working branches for unfinished and unmerged feature. Likely unstable,
|
||||||
|
don't use in production. Once the feature is complete, it is merged
|
||||||
|
into one of the versions branches and deleted.
|
||||||
|
|
||||||
Special branches:
|
Special branches:
|
||||||
|
|
||||||
``releases/all``
|
``releases/all``
|
||||||
Used by the continuous delivery system to trigger the build and release
|
Pushing code to this branch will trigger the build and release
|
||||||
a new Docker image, Documentation and Python package.
|
a new Docker image, Documentation and Python package.
|
||||||
``releases/docker``
|
``releases/docker``
|
||||||
Used by the continuous delivery system to trigger the build and release
|
Pushing code to this branch will trigger the build and release
|
||||||
of a new Docker image to Docker Hub.
|
of a new Docker image to Docker Hub.
|
||||||
``releases/documentation``
|
``releases/documentation``
|
||||||
Used by the continuous delivery system to trigger the build and release
|
Pushing code to this branch will trigger the build and release
|
||||||
of new documentation.
|
of new documentation.
|
||||||
``releases/python``
|
``releases/python``
|
||||||
Used by the continuous delivery system to trigger the build and release
|
Pushing code to this branch will trigger the build and release
|
||||||
of a new Python package to PyPI.
|
of a new Python package to PyPI.
|
||||||
``nightly``
|
``nightly``
|
||||||
Used by the continuous delivery system to trigger the build and release
|
Pushing code to this branch will trigger the build and release
|
||||||
of a new Docker image based on development code to the GitLab image
|
of a new Docker image based on development code to the GitLab image
|
||||||
repository.
|
repository only. The image will not be published to Docker Hub.
|
||||||
|
|
||||||
Each release is tagged separately using annotated Git tags.
|
Each release is tagged separately using annotated Git tags.
|
||||||
|
|
||||||
@@ -519,7 +533,7 @@ Release using GitLab CI
|
|||||||
::
|
::
|
||||||
|
|
||||||
git checkout releases/all
|
git checkout releases/all
|
||||||
git merge versions/next
|
git merge <corresponding branch>
|
||||||
|
|
||||||
#. Push code to trigger builds:
|
#. Push code to trigger builds:
|
||||||
::
|
::
|
||||||
|
|||||||
@@ -49,12 +49,7 @@ Finally create and run a Mayan EDMS container::
|
|||||||
--name mayan-edms \
|
--name mayan-edms \
|
||||||
--restart=always \
|
--restart=always \
|
||||||
-p 80:8000 \
|
-p 80:8000 \
|
||||||
-e MAYAN_DATABASE_ENGINE=django.db.backends.postgresql \
|
-e MAYAN_DATABASES="{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayanuserpass','USER':'mayan','HOST':'172.17.0.1'}}" \
|
||||||
-e MAYAN_DATABASE_HOST=172.17.0.1 \
|
|
||||||
-e MAYAN_DATABASE_NAME=mayan \
|
|
||||||
-e MAYAN_DATABASE_PASSWORD=mayanuserpass \
|
|
||||||
-e MAYAN_DATABASE_USER=mayan \
|
|
||||||
-e MAYAN_DATABASE_CONN_MAX_AGE=0 \
|
|
||||||
-v /docker-volumes/mayan-edms/media:/var/lib/mayan \
|
-v /docker-volumes/mayan-edms/media:/var/lib/mayan \
|
||||||
mayanedms/mayanedms:<version>
|
mayanedms/mayanedms:<version>
|
||||||
|
|
||||||
@@ -108,12 +103,7 @@ instead of the IP address of the Docker host (``172.17.0.1``)::
|
|||||||
--network=mayan \
|
--network=mayan \
|
||||||
--restart=always \
|
--restart=always \
|
||||||
-p 80:8000 \
|
-p 80:8000 \
|
||||||
-e MAYAN_DATABASE_ENGINE=django.db.backends.postgresql \
|
-e MAYAN_DATABASES="{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayanuserpass','USER':'mayan','HOST':'mayan-edms-postgres'}}" \
|
||||||
-e MAYAN_DATABASE_HOST=mayan-edms-postgres \
|
|
||||||
-e MAYAN_DATABASE_NAME=mayan \
|
|
||||||
-e MAYAN_DATABASE_PASSWORD=mayanuserpass \
|
|
||||||
-e MAYAN_DATABASE_USER=mayan \
|
|
||||||
-e MAYAN_DATABASE_CONN_MAX_AGE=0 \
|
|
||||||
-v /docker-volumes/mayan-edms/media:/var/lib/mayan \
|
-v /docker-volumes/mayan-edms/media:/var/lib/mayan \
|
||||||
mayanedms/mayanedms:<version>
|
mayanedms/mayanedms:<version>
|
||||||
|
|
||||||
@@ -137,101 +127,20 @@ To start the container again::
|
|||||||
Environment Variables
|
Environment Variables
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
The Mayan EDMS image can be configure via environment variables.
|
The common set of settings can also be modified via environment variables when
|
||||||
|
using the Docker image. In addition to the common set of settings, some Docker
|
||||||
``MAYAN_DATABASE_ENGINE``
|
image specific environment variables are available.
|
||||||
|
|
||||||
Defaults to ``None``. This environment variable configures the database
|
|
||||||
backend to use. If left unset, SQLite will be used. The database backends
|
|
||||||
supported by this Docker image are:
|
|
||||||
|
|
||||||
- ``'django.db.backends.postgresql'``
|
|
||||||
- ``'django.db.backends.mysql'``
|
|
||||||
- ``'django.db.backends.sqlite3'``
|
|
||||||
|
|
||||||
When using the SQLite backend, the database file will be saved in the Docker
|
|
||||||
volume. The SQLite database as used by Mayan EDMS is meant only for development
|
|
||||||
or testing, never use it in production.
|
|
||||||
|
|
||||||
``MAYAN_DATABASE_NAME``
|
|
||||||
|
|
||||||
Defaults to 'mayan'. This optional environment variable can be used to define
|
|
||||||
the database name that Mayan EDMS will connect to. For more information read
|
|
||||||
the pertinent Django documentation page:
|
|
||||||
:django-docs:`Connecting to the database <ref/databases/#connecting-to-the-database>`
|
|
||||||
|
|
||||||
``MAYAN_DATABASE_USER``
|
|
||||||
|
|
||||||
Defaults to 'mayan'. This optional environment variable is used to set the
|
|
||||||
username that will be used to connect to the database. For more information
|
|
||||||
read the pertinent Django documentation page:
|
|
||||||
:django-docs:`Settings, USER <ref/settings/#user>`
|
|
||||||
|
|
||||||
``MAYAN_DATABASE_PASSWORD``
|
|
||||||
|
|
||||||
Defaults to ''. This optional environment variable is used to set the
|
|
||||||
password that will be used to connect to the database. For more information
|
|
||||||
read the pertinent Django documentation page:
|
|
||||||
:django-docs:`Settings, PASSWORD <ref/settings/#password>`
|
|
||||||
|
|
||||||
``MAYAN_DATABASE_HOST``
|
|
||||||
|
|
||||||
Defaults to `None`. This optional environment variable is used to set the
|
|
||||||
hostname that will be used to connect to the database. This can be the
|
|
||||||
hostname of another container or an IP address. For more information read
|
|
||||||
the pertinent Django documentation page:
|
|
||||||
:django-docs:`Settings, HOST <ref/settings/#host>`
|
|
||||||
|
|
||||||
``MAYAN_DATABASE_PORT``
|
|
||||||
|
|
||||||
Defaults to `None`. This optional environment variable is used to set the
|
|
||||||
port number to use when connecting to the database. An empty string means
|
|
||||||
the default port. Not used with SQLite. For more information read the
|
|
||||||
pertinent Django documentation page:
|
|
||||||
:django-docs:`Settings, PORT <ref/settings/#port>`
|
|
||||||
|
|
||||||
``MAYAN_BROKER_URL``
|
|
||||||
|
|
||||||
This optional environment variable determines the broker that Celery will use
|
|
||||||
to relay task messages between the frontend code and the background workers.
|
|
||||||
For more information read the pertinent Celery Kombu documentation page: `Broker URL`_
|
|
||||||
|
|
||||||
.. _Broker URL: http://kombu.readthedocs.io/en/latest/userguide/connections.html#connection-urls
|
|
||||||
|
|
||||||
This Docker image supports using Redis and RabbitMQ as brokers.
|
|
||||||
|
|
||||||
Caveat: If the `MAYAN_BROKER_URL` and `MAYAN_CELERY_RESULT_BACKEND` environment
|
|
||||||
variables are specified, the built-in Redis server inside the container will
|
|
||||||
be disabled.
|
|
||||||
|
|
||||||
``MAYAN_CELERY_RESULT_BACKEND``
|
|
||||||
|
|
||||||
This optional environment variable determines the results backend that Celery
|
|
||||||
will use to relay result messages from the background workers to the frontend
|
|
||||||
code. For more information read the pertinent Celery Kombu documentation page:
|
|
||||||
`Task result backend settings`_
|
|
||||||
|
|
||||||
.. _Task result backend settings: http://docs.celeryproject.org/en/3.1/configuration.html#celery-result-backend
|
|
||||||
|
|
||||||
This Docker image supports using Redis and RabbitMQ as result backends.
|
|
||||||
|
|
||||||
Caveat: If the `MAYAN_BROKER_URL` and `MAYAN_CELERY_RESULT_BACKEND` environment
|
|
||||||
variables are specified, the built-in Redis server inside the container will
|
|
||||||
be disabled.
|
|
||||||
|
|
||||||
``MAYAN_SETTINGS_MODULE``
|
``MAYAN_SETTINGS_MODULE``
|
||||||
|
|
||||||
Optional. Allows loading an alternate settings file.
|
Optional. Allows loading an alternate settings file.
|
||||||
|
|
||||||
``MAYAN_DATABASE_CONN_MAX_AGE``
|
|
||||||
|
|
||||||
Amount in seconds to keep a database connection alive. Allow reuse of database
|
``MAYAN_GUNICORN_TIMEOUT``
|
||||||
connections. For more information read the pertinent Django documentation
|
|
||||||
page: :django-docs:`Settings, CONN_MAX_AGE <ref/settings/#conn-max-age>`
|
Optional. Changes the amount of time the frontend worker will wait for a
|
||||||
According to new information Gunicorn's microthreads don't share connections
|
request to finish before raising a timeout error. The default is 120
|
||||||
and will exhaust the available Postgres connections available if a number
|
seconds.
|
||||||
other than 0 is used. Reference: https://serverfault.com/questions/635100/django-conn-max-age-persists-connections-but-doesnt-reuse-them-with-postgresq
|
|
||||||
and https://github.com/benoitc/gunicorn/issues/996
|
|
||||||
|
|
||||||
``MAYAN_GUNICORN_WORKERS``
|
``MAYAN_GUNICORN_WORKERS``
|
||||||
|
|
||||||
@@ -275,6 +184,15 @@ Optional. Changes the GID of the ``mayan`` user internal to the Docker
|
|||||||
container. Defaults to 1000.
|
container. Defaults to 1000.
|
||||||
|
|
||||||
|
|
||||||
|
Included drivers
|
||||||
|
----------------
|
||||||
|
|
||||||
|
The Docker image supports using Redis and RabbitMQ as result backends. For
|
||||||
|
databases, the image includes support for PostgreSQL and MySQL/MariaDB.
|
||||||
|
Support for additional brokers or databases may be added using the
|
||||||
|
``MAYAN_APT_INSTALL`` environment variable.
|
||||||
|
|
||||||
|
|
||||||
.. _docker-accessing-outside-data:
|
.. _docker-accessing-outside-data:
|
||||||
|
|
||||||
Accessing outside data
|
Accessing outside data
|
||||||
@@ -442,6 +360,7 @@ These are:
|
|||||||
|
|
||||||
Nightly images
|
Nightly images
|
||||||
==============
|
==============
|
||||||
|
|
||||||
The continuous integration pipeline used for testing development builds also
|
The continuous integration pipeline used for testing development builds also
|
||||||
produces a resulting Docker image. These are build automatically and their
|
produces a resulting Docker image. These are build automatically and their
|
||||||
stability is not guaranteed. They should never be used in production.
|
stability is not guaranteed. They should never be used in production.
|
||||||
|
|||||||
@@ -94,11 +94,11 @@ For the Docker image, launch a separate RabbitMQ container
|
|||||||
|
|
||||||
docker run -d --name mayan-edms-rabbitmq -e RABBITMQ_DEFAULT_USER=mayan -e RABBITMQ_DEFAULT_PASS=mayanrabbitmqpassword -e RABBITMQ_DEFAULT_VHOST=mayan rabbitmq:3
|
docker run -d --name mayan-edms-rabbitmq -e RABBITMQ_DEFAULT_USER=mayan -e RABBITMQ_DEFAULT_PASS=mayanrabbitmqpassword -e RABBITMQ_DEFAULT_VHOST=mayan rabbitmq:3
|
||||||
|
|
||||||
Pass the MAYAN_BROKER_URL environment variable (https://kombu.readthedocs.io/en/latest/userguide/connections.html#connection-urls)
|
Pass the MAYAN_CELERY_BROKER_URL environment variable (https://kombu.readthedocs.io/en/latest/userguide/connections.html#connection-urls)
|
||||||
to the Mayan EDMS container so that it uses the RabbitMQ container the
|
to the Mayan EDMS container so that it uses the RabbitMQ container the
|
||||||
message broker::
|
message broker::
|
||||||
|
|
||||||
-e MAYAN_BROKER_URL="amqp://mayan:mayanrabbitmqpassword@localhost:5672/mayan",
|
-e MAYAN_CELERY_BROKER_URL="amqp://mayan:mayanrabbitmqpassword@localhost:5672/mayan",
|
||||||
|
|
||||||
When tasks finish, they leave behind a return status or the result of a
|
When tasks finish, they leave behind a return status or the result of a
|
||||||
calculation, these are stored for a while so that whoever requested the
|
calculation, these are stored for a while so that whoever requested the
|
||||||
|
|||||||
161
docs/releases/3.2.8.rst
Normal file
161
docs/releases/3.2.8.rst
Normal file
@@ -0,0 +1,161 @@
|
|||||||
|
Version 3.2.8
|
||||||
|
=============
|
||||||
|
|
||||||
|
Released: October 1, 2019
|
||||||
|
|
||||||
|
|
||||||
|
Changes
|
||||||
|
-------
|
||||||
|
|
||||||
|
|
||||||
|
API
|
||||||
|
^^^
|
||||||
|
|
||||||
|
Fix an error when accessing some API entry points without
|
||||||
|
being authenticated. Accessing API endpoints without being authenticated
|
||||||
|
will now always return empty results.
|
||||||
|
|
||||||
|
|
||||||
|
Cabinets
|
||||||
|
^^^^^^^^
|
||||||
|
|
||||||
|
Tweaked the jstree component's appearance to cope with long labels.
|
||||||
|
Added a scrollbar, reduced the font size, switched to a sans serif font,
|
||||||
|
and reduced padding. Thanks for forum user @briboe for the report.
|
||||||
|
|
||||||
|
Workflow actions to add and remove documents from cabinets was added.
|
||||||
|
|
||||||
|
|
||||||
|
Dependencies
|
||||||
|
^^^^^^^^^^^^
|
||||||
|
|
||||||
|
The Django version used was updated to version 1.11.24. The jQuery version
|
||||||
|
used was updated to version 3.4.1. Both as fully backwards compatible with
|
||||||
|
their previous versions.
|
||||||
|
|
||||||
|
|
||||||
|
OCR
|
||||||
|
^^^
|
||||||
|
|
||||||
|
Support was added to delete the content of document's OCR or parsed content.
|
||||||
|
Events for both situations was added allowing content deletion to be used
|
||||||
|
as workflow transition triggers.
|
||||||
|
|
||||||
|
|
||||||
|
Docker
|
||||||
|
^^^^^^
|
||||||
|
|
||||||
|
A missing recursive option was added to the Docker entrypoint
|
||||||
|
command "chown" to change the ownership of files when specifying a custom
|
||||||
|
UID or GID. Closes GitLab issue #668. Thanks to John Wice (@brilthor)
|
||||||
|
for the report.
|
||||||
|
|
||||||
|
Two fonts were added to the Docker image to support rendering Chinese office
|
||||||
|
documents. Closes GitLab issue #666. Thanks to javawcy (@javawcy) and forum
|
||||||
|
user @leoliu for the report and help closing this issue.
|
||||||
|
|
||||||
|
|
||||||
|
Usability
|
||||||
|
^^^^^^^^^
|
||||||
|
|
||||||
|
Descriptions for screenreaders was added via image alt tag. The user interface
|
||||||
|
will also now allow scaling.
|
||||||
|
|
||||||
|
|
||||||
|
Removals
|
||||||
|
--------
|
||||||
|
|
||||||
|
- None
|
||||||
|
|
||||||
|
|
||||||
|
Upgrading from a previous version
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
If installed via Python's PIP
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Remove deprecated requirements::
|
||||||
|
|
||||||
|
sudo -u mayan curl https://gitlab.com/mayan-edms/mayan-edms/raw/master/removals.txt -o /tmp/removals.txt && sudo -u mayan /opt/mayan-edms/bin/pip uninstall -y -r /tmp/removals.txt
|
||||||
|
|
||||||
|
Type in the console::
|
||||||
|
|
||||||
|
sudo -u mayan /opt/mayan-edms/bin/pip install mayan-edms==3.2.8
|
||||||
|
|
||||||
|
the requirements will also be updated automatically.
|
||||||
|
|
||||||
|
|
||||||
|
Using Git
|
||||||
|
^^^^^^^^^
|
||||||
|
|
||||||
|
If you installed Mayan EDMS by cloning the Git repository issue the commands::
|
||||||
|
|
||||||
|
$ git reset --hard HEAD
|
||||||
|
$ git pull
|
||||||
|
|
||||||
|
otherwise download the compressed archived and uncompress it overriding the
|
||||||
|
existing installation.
|
||||||
|
|
||||||
|
Remove deprecated requirements::
|
||||||
|
|
||||||
|
$ pip uninstall -y -r removals.txt
|
||||||
|
|
||||||
|
Next upgrade/add the new requirements::
|
||||||
|
|
||||||
|
$ pip install --upgrade -r requirements.txt
|
||||||
|
|
||||||
|
|
||||||
|
Common steps
|
||||||
|
^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Perform these steps after updating the code from either step above.
|
||||||
|
|
||||||
|
Make a backup of your supervisord file::
|
||||||
|
|
||||||
|
sudo cp /etc/supervisor/conf.d/mayan.conf /etc/supervisor/conf.d/mayan.conf.bck
|
||||||
|
|
||||||
|
Update the supervisord configuration file. Replace the environment
|
||||||
|
variables values show here with your respective settings. This step will refresh
|
||||||
|
the supervisord configuration file with the new queues and the latest
|
||||||
|
recommended layout::
|
||||||
|
|
||||||
|
sudo MAYAN_DATABASE_ENGINE=django.db.backends.postgresql MAYAN_DATABASE_NAME=mayan \
|
||||||
|
MAYAN_DATABASE_PASSWORD=mayanuserpass MAYAN_DATABASE_USER=mayan \
|
||||||
|
MAYAN_DATABASE_HOST=127.0.0.1 MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
|
/opt/mayan-edms/bin/mayan-edms.py platformtemplate supervisord > /etc/supervisor/conf.d/mayan.conf
|
||||||
|
|
||||||
|
Edit the supervisord configuration file and update any setting the template
|
||||||
|
generator missed::
|
||||||
|
|
||||||
|
sudo vi /etc/supervisor/conf.d/mayan.conf
|
||||||
|
|
||||||
|
Migrate existing database schema with::
|
||||||
|
|
||||||
|
sudo -u mayan MAYAN_DATABASE_ENGINE=django.db.backends.postgresql MAYAN_DATABASE_NAME=mayan \
|
||||||
|
MAYAN_DATABASE_PASSWORD=mayanuserpass MAYAN_DATABASE_USER=mayan \
|
||||||
|
MAYAN_DATABASE_HOST=127.0.0.1 MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
|
/opt/mayan-edms/bin/mayan-edms.py performupgrade
|
||||||
|
|
||||||
|
Add new static media::
|
||||||
|
|
||||||
|
sudo -u mayan MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
|
/opt/mayan-edms/bin/mayan-edms.py preparestatic --noinput
|
||||||
|
|
||||||
|
The upgrade procedure is now complete.
|
||||||
|
|
||||||
|
|
||||||
|
Backward incompatible changes
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
- None
|
||||||
|
|
||||||
|
|
||||||
|
Bugs fixed or issues closed
|
||||||
|
---------------------------
|
||||||
|
|
||||||
|
- :gitlab-issue:`666` Chinese document such as .doc can't display well.
|
||||||
|
- :gitlab-issue:`668` Permission denied errors with custom uid persist (650 needs re-open)
|
||||||
|
- :forum-topic:`1120` Cabinet Presentation
|
||||||
|
- :forum-topic:`2202` Cannot display Chinese character and cannot identify Excel files
|
||||||
|
|
||||||
|
.. _PyPI: https://pypi.python.org/pypi/mayan-edms/
|
||||||
213
docs/releases/3.3.rst
Normal file
213
docs/releases/3.3.rst
Normal file
@@ -0,0 +1,213 @@
|
|||||||
|
Version 3.3
|
||||||
|
===========
|
||||||
|
|
||||||
|
Released: XX XX, 2019
|
||||||
|
|
||||||
|
|
||||||
|
Changes
|
||||||
|
-------
|
||||||
|
|
||||||
|
- Add support for icon shadows.
|
||||||
|
- Add icons and no-result template to the object error log view and
|
||||||
|
links.
|
||||||
|
- Use Select2 widget for the document type selection form.
|
||||||
|
- Backport the vertical main menu update. This update splits the previous
|
||||||
|
main menu into a new menu in the same location as the previous one
|
||||||
|
now called the top bar, and a new vertical main menu on the left side.
|
||||||
|
The vertical menu remain open even when clicking on items and upon
|
||||||
|
a browser refresh will also restore its state to match the selected
|
||||||
|
view.
|
||||||
|
- Backport workflow preview refactor. GitLab issue #532.
|
||||||
|
- Add support for source column inheritance.
|
||||||
|
- Add support for source column exclusion.
|
||||||
|
- Backport workflow context support.
|
||||||
|
- Backport workflow transitions field support.
|
||||||
|
- Backport workflow email action.
|
||||||
|
- Backport individual index rebuild support.
|
||||||
|
- Rename the installjavascript command to installdependencies.
|
||||||
|
- Remove database conversion command.
|
||||||
|
- Remove support for quoted configuration entries. Support unquoted,
|
||||||
|
nested dictionaries in the configuration. Requires manual
|
||||||
|
update of existing config.yml files.
|
||||||
|
- Support user specified locations for the configuration file with the
|
||||||
|
CONFIGURATION_FILEPATH (MAYAN_CONFIGURATION_FILEPATH environment variable), and
|
||||||
|
CONFIGURATION_LAST_GOOD_FILEPATH
|
||||||
|
(MAYAN_CONFIGURATION_LAST_GOOD_FILEPATH environment variable) settings.
|
||||||
|
- Move bootstrapped settings code to their own module in the smart_settings apps.
|
||||||
|
- Remove individual database configuration options. All database configuration
|
||||||
|
is now done using MAYAN_DATABASES to mirror Django way of doing database setup.
|
||||||
|
- Added support for YAML encoded environment variables to the platform
|
||||||
|
templates apps.
|
||||||
|
- Move YAML code to its own module. Code now resides in common.serialization
|
||||||
|
in the form of two new functions: yaml_load and yaml_dump.
|
||||||
|
- Move Django and Celery settings. Django settings now reside in the smart
|
||||||
|
settings app. Celery settings now reside in the task manager app.
|
||||||
|
- Backport FakeStorageSubclass from versions/next. Placeholder class to allow
|
||||||
|
serializing the real storage subclass to support migrations.
|
||||||
|
Used by all configurable storages.
|
||||||
|
- Support checking in and out multiple documents.
|
||||||
|
- Remove encapsulate helper.
|
||||||
|
- Add support for menu inheritance.
|
||||||
|
- Emphasize source column labels.
|
||||||
|
- Backport file cache manager app.
|
||||||
|
- Convert document image cache to use file cache manager app.
|
||||||
|
Add setting DOCUMENTS_CACHE_MAXIMUM_SIZE defaults to 500 MB.
|
||||||
|
- Update Celery to version 4.3.0. Settings changed:
|
||||||
|
MAYAN_BROKER_URL to MAYAN_CELERY_BROKER_URL,
|
||||||
|
MAYAN_CELERY_ALWAYS_EAGER to MAYAN_CELERY_TASK_ALWAYS_EAGER.
|
||||||
|
- Replace djcelery and replace it with django-celery-beat.
|
||||||
|
- Update Celery to version 4.3.0 with 55e9b2263cbdb9b449361412fd18d8ee0a442dd3
|
||||||
|
from versions/next, code from GitLab issue #594 and GitLab merge request !55.
|
||||||
|
Thanks to Jakob Haufe (@sur5r) and Jesaja Everling (@jeverling)
|
||||||
|
for much of the research and code updates.
|
||||||
|
- Support wildcard MIME type associations for the file metadata drivers.
|
||||||
|
- Rename MAYAN_GUID to MAYAN_GID
|
||||||
|
- Update Gunicorn to use sync workers.
|
||||||
|
- Include devpi-server as a development dependency.
|
||||||
|
- Update default Docker stack file.
|
||||||
|
- Remove Redis from the Docker image.
|
||||||
|
- Add Celery flower to the Docker image.
|
||||||
|
- Allow PIP proxying to the Docker image during build.
|
||||||
|
- Default Celery worker concurrency to 0 (auto).
|
||||||
|
- Set DJANGO_SETTINGS_MODULE environment variable to make it
|
||||||
|
available to sub processes.
|
||||||
|
- Add entrypoint commands to run single workers, single gunicorn
|
||||||
|
or single celery commands like "flower".
|
||||||
|
- Add platform template to return queues for a worker.
|
||||||
|
- Remove task inspection from task manager app.
|
||||||
|
- Move pagination navigation inside the toolbar.
|
||||||
|
- Remove document image clear link and view.
|
||||||
|
This is now handled by the file caching app.
|
||||||
|
- Add web links app.
|
||||||
|
- Add support to display column help text
|
||||||
|
as a tooltip.
|
||||||
|
- Update numeric dashboard widget to display
|
||||||
|
thousand commas.
|
||||||
|
- Add support for disabling document pages.
|
||||||
|
- Add support for converter layers.
|
||||||
|
- Add redactions app.
|
||||||
|
- Unify all line endings to be Linux style.
|
||||||
|
- Add support for changing the system messages position.
|
||||||
|
GitLab issue #640. Thanks to Matthias Urhahn (@d4rken).
|
||||||
|
|
||||||
|
Removals
|
||||||
|
--------
|
||||||
|
|
||||||
|
- Database conversion. Reason for removal: The database conversions support
|
||||||
|
provided by this feature (SQLite to PostgreSQL) was being confused with
|
||||||
|
database migrations and upgrades.
|
||||||
|
|
||||||
|
Database upgrades are the responsibility of the app and the framework.
|
||||||
|
Database conversions however are not the responsibility of the app (Mayan),
|
||||||
|
they are the responsibility of the framework.
|
||||||
|
|
||||||
|
Database conversion is outside the scope of what Mayan does but we added
|
||||||
|
the code, management command, instructions and testing setup to provide
|
||||||
|
this to our users until the framework (Django) decided to add this
|
||||||
|
themselves (like they did with migrations).
|
||||||
|
|
||||||
|
Continued confusion about the purpose of the feature and confusion about
|
||||||
|
how errors with this feature were a reflexion of the code quality of
|
||||||
|
Mayan necessitated the removal of the database conversion feature.
|
||||||
|
|
||||||
|
- Django environ
|
||||||
|
|
||||||
|
|
||||||
|
Upgrading from a previous version
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
If installed via Python's PIP
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Remove deprecated requirements::
|
||||||
|
|
||||||
|
sudo -u mayan curl https://gitlab.com/mayan-edms/mayan-edms/raw/master/removals.txt -o /tmp/removals.txt && sudo -u mayan /opt/mayan-edms/bin/pip uninstall -y -r /tmp/removals.txt
|
||||||
|
|
||||||
|
Type in the console::
|
||||||
|
|
||||||
|
/opt/mayan-edms/bin/pip install mayan-edms==3.3
|
||||||
|
|
||||||
|
the requirements will also be updated automatically.
|
||||||
|
|
||||||
|
|
||||||
|
Using Git
|
||||||
|
^^^^^^^^^
|
||||||
|
|
||||||
|
If you installed Mayan EDMS by cloning the Git repository issue the commands::
|
||||||
|
|
||||||
|
git reset --hard HEAD
|
||||||
|
git pull
|
||||||
|
|
||||||
|
otherwise download the compressed archived and uncompress it overriding the
|
||||||
|
existing installation.
|
||||||
|
|
||||||
|
Remove deprecated requirements::
|
||||||
|
|
||||||
|
pip uninstall -y -r removals.txt
|
||||||
|
|
||||||
|
Next upgrade/add the new requirements::
|
||||||
|
|
||||||
|
pip install --upgrade -r requirements.txt
|
||||||
|
|
||||||
|
|
||||||
|
Common steps
|
||||||
|
^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Perform these steps after updating the code from either step above.
|
||||||
|
|
||||||
|
Make a backup of your supervisord file::
|
||||||
|
|
||||||
|
sudo cp /etc/supervisor/conf.d/mayan.conf /etc/supervisor/conf.d/mayan.conf.bck
|
||||||
|
|
||||||
|
Update the supervisord configuration file. Replace the environment
|
||||||
|
variables values show here with your respective settings. This step will refresh
|
||||||
|
the supervisord configuration file with the new queues and the latest
|
||||||
|
recommended layout::
|
||||||
|
|
||||||
|
sudo MAYAN_DATABASES="{'default':{'ENGINE':'django.db.backends.postgresql','NAME':'mayan','PASSWORD':'mayanuserpass','USER':'mayan','HOST':'127.0.0.1'}}" \
|
||||||
|
MAYAN_MEDIA_ROOT=/opt/mayan-edms/media \
|
||||||
|
/opt/mayan-edms/bin/mayan-edms.py platformtemplate supervisord > /etc/supervisor/conf.d/mayan.conf
|
||||||
|
|
||||||
|
Edit the supervisord configuration file and update any setting the template
|
||||||
|
generator missed::
|
||||||
|
|
||||||
|
sudo vi /etc/supervisor/conf.d/mayan.conf
|
||||||
|
|
||||||
|
Migrate existing database schema with::
|
||||||
|
|
||||||
|
sudo -u mayan MAYAN_MEDIA_ROOT=/opt/mayan-edms/media /opt/mayan-edms/bin/mayan-edms.py performupgrade
|
||||||
|
|
||||||
|
Add new static media::
|
||||||
|
|
||||||
|
sudo -u mayan MAYAN_MEDIA_ROOT=/opt/mayan-edms/media /opt/mayan-edms/bin/mayan-edms.py preparestatic --noinput
|
||||||
|
|
||||||
|
The upgrade procedure is now complete.
|
||||||
|
|
||||||
|
|
||||||
|
Backward incompatible changes
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
- Update quoted settings to be unquoted:
|
||||||
|
|
||||||
|
- COMMON_SHARED_STORAGE_ARGUMENTS
|
||||||
|
- CONVERTER_GRAPHICS_BACKEND_ARGUMENTS
|
||||||
|
- DOCUMENTS_CACHE_STORAGE_BACKEND_ARGUMENTS
|
||||||
|
- DOCUMENTS_STORAGE_BACKEND_ARGUMENTS
|
||||||
|
- FILE_METADATA_DRIVERS_ARGUMENTS
|
||||||
|
- SIGNATURES_STORAGE_BACKEND_ARGUMENTS
|
||||||
|
|
||||||
|
|
||||||
|
Bugs fixed or issues closed
|
||||||
|
---------------------------
|
||||||
|
|
||||||
|
- :gitlab-issue:`526` RuntimeWarning: Never call result.get() within a task!
|
||||||
|
- :gitlab-issue:`532` Workflow preview isn't updated right after transitions are modified
|
||||||
|
- :gitlab-issue:`540` hint-outdated/update documentation
|
||||||
|
- :gitlab-issue:`594` 3.2b1: Unable to install/run under Python 3.5/3.6/3.7
|
||||||
|
- :gitlab-issue:`634` Failing docker entrypoint when using secret config
|
||||||
|
- :gitlab-issue:`635` Build a docker image for Python3
|
||||||
|
- :gitlab-issue:`640` UX: "Toast" Popup position prevents access to actions
|
||||||
|
- :gitlab-issue:`644` Update sane-utils package in docker image.
|
||||||
|
|
||||||
|
|
||||||
|
.. _PyPI: https://pypi.python.org/pypi/mayan-edms/
|
||||||
@@ -20,6 +20,8 @@ versions of the documentation contain the release notes for any later releases.
|
|||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
|
3.3
|
||||||
|
3.2.8
|
||||||
3.2.7
|
3.2.7
|
||||||
3.2.6
|
3.2.6
|
||||||
3.2.5
|
3.2.5
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
__title__ = 'Mayan EDMS'
|
__title__ = 'Mayan EDMS'
|
||||||
__version__ = '3.2.7'
|
__version__ = '3.3beta1'
|
||||||
__build__ = 0x030207
|
__build__ = 0x030300
|
||||||
__build_string__ = 'v3.2.7_Wed Aug 28 17:31:08 2019 -0400'
|
__build_string__ = 'v3.3beta1-9-g1b327b99f0_Tue Oct 8 15:15:08 2019 -0400'
|
||||||
__django_version__ = '1.11'
|
__django_version__ = '1.11'
|
||||||
__author__ = 'Roberto Rosario'
|
__author__ = 'Roberto Rosario'
|
||||||
__author_email__ = 'roberto.rosario@mayan-edms.com'
|
__author_email__ = 'roberto.rosario@mayan-edms.com'
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ logger = logging.getLogger(__name__)
|
|||||||
class ModelPermission(object):
|
class ModelPermission(object):
|
||||||
_functions = {}
|
_functions = {}
|
||||||
_inheritances = {}
|
_inheritances = {}
|
||||||
|
_manager_names = {}
|
||||||
_registry = {}
|
_registry = {}
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
@@ -20,22 +21,6 @@ class ModelPermission(object):
|
|||||||
# TODO: Find method to revert the add_to_class('acls'...)
|
# TODO: Find method to revert the add_to_class('acls'...)
|
||||||
# delattr doesn't work.
|
# delattr doesn't work.
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def register(cls, model, permissions):
|
|
||||||
from django.contrib.contenttypes.fields import GenericRelation
|
|
||||||
|
|
||||||
cls._registry.setdefault(model, [])
|
|
||||||
for permission in permissions:
|
|
||||||
cls._registry[model].append(permission)
|
|
||||||
|
|
||||||
AccessControlList = apps.get_model(
|
|
||||||
app_label='acls', model_name='AccessControlList'
|
|
||||||
)
|
|
||||||
|
|
||||||
model.add_to_class(
|
|
||||||
name='acls', value=GenericRelation(AccessControlList)
|
|
||||||
)
|
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_classes(cls, as_content_type=False):
|
def get_classes(cls, as_content_type=False):
|
||||||
ContentType = apps.get_model(
|
ContentType = apps.get_model(
|
||||||
@@ -97,6 +82,40 @@ class ModelPermission(object):
|
|||||||
def get_inheritance(cls, model):
|
def get_inheritance(cls, model):
|
||||||
return cls._inheritances[model]
|
return cls._inheritances[model]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_manager(cls, model):
|
||||||
|
try:
|
||||||
|
manager_name = cls.get_manager_name(model=model)
|
||||||
|
except KeyError:
|
||||||
|
manager_name = None
|
||||||
|
|
||||||
|
if manager_name:
|
||||||
|
manager = getattr(model, manager_name)
|
||||||
|
else:
|
||||||
|
manager = model._meta.default_manager
|
||||||
|
|
||||||
|
return manager
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_manager_name(cls, model):
|
||||||
|
return cls._manager_names[model]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def register(cls, model, permissions):
|
||||||
|
from django.contrib.contenttypes.fields import GenericRelation
|
||||||
|
|
||||||
|
cls._registry.setdefault(model, [])
|
||||||
|
for permission in permissions:
|
||||||
|
cls._registry[model].append(permission)
|
||||||
|
|
||||||
|
AccessControlList = apps.get_model(
|
||||||
|
app_label='acls', model_name='AccessControlList'
|
||||||
|
)
|
||||||
|
|
||||||
|
model.add_to_class(
|
||||||
|
name='acls', value=GenericRelation(AccessControlList)
|
||||||
|
)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def register_function(cls, model, function):
|
def register_function(cls, model, function):
|
||||||
cls._functions[model] = function
|
cls._functions[model] = function
|
||||||
@@ -104,3 +123,7 @@ class ModelPermission(object):
|
|||||||
@classmethod
|
@classmethod
|
||||||
def register_inheritance(cls, model, related):
|
def register_inheritance(cls, model, related):
|
||||||
cls._inheritances[model] = related
|
cls._inheritances[model] = related
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def register_manager(cls, model, manager_name):
|
||||||
|
cls._manager_names[model] = manager_name
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Arabic (http://www.transifex.com/rosarior/mayan-edms/language/ar/)\n"
|
"Language-Team: Arabic (http://www.transifex.com/rosarior/mayan-edms/language/ar/)\n"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Bulgarian (http://www.transifex.com/rosarior/mayan-edms/language/bg/)\n"
|
"Language-Team: Bulgarian (http://www.transifex.com/rosarior/mayan-edms/language/bg/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Bosnian (Bosnia and Herzegovina) (http://www.transifex.com/rosarior/mayan-edms/language/bs_BA/)\n"
|
"Language-Team: Bosnian (Bosnia and Herzegovina) (http://www.transifex.com/rosarior/mayan-edms/language/bs_BA/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Czech (http://www.transifex.com/rosarior/mayan-edms/language/cs/)\n"
|
"Language-Team: Czech (http://www.transifex.com/rosarior/mayan-edms/language/cs/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Danish (Denmark) (http://www.transifex.com/rosarior/mayan-edms/language/da_DK/)\n"
|
"Language-Team: Danish (Denmark) (http://www.transifex.com/rosarior/mayan-edms/language/da_DK/)\n"
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: German (Germany) (http://www.transifex.com/rosarior/mayan-edms/language/de_DE/)\n"
|
"Language-Team: German (Germany) (http://www.transifex.com/rosarior/mayan-edms/language/de_DE/)\n"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Greek (http://www.transifex.com/rosarior/mayan-edms/language/el/)\n"
|
"Language-Team: Greek (http://www.transifex.com/rosarior/mayan-edms/language/el/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: PACKAGE VERSION\n"
|
"Project-Id-Version: PACKAGE VERSION\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:51+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:51+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Spanish (http://www.transifex.com/rosarior/mayan-edms/language/es/)\n"
|
"Language-Team: Spanish (http://www.transifex.com/rosarior/mayan-edms/language/es/)\n"
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Persian (http://www.transifex.com/rosarior/mayan-edms/language/fa/)\n"
|
"Language-Team: Persian (http://www.transifex.com/rosarior/mayan-edms/language/fa/)\n"
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: French (http://www.transifex.com/rosarior/mayan-edms/language/fr/)\n"
|
"Language-Team: French (http://www.transifex.com/rosarior/mayan-edms/language/fr/)\n"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Hungarian (http://www.transifex.com/rosarior/mayan-edms/language/hu/)\n"
|
"Language-Team: Hungarian (http://www.transifex.com/rosarior/mayan-edms/language/hu/)\n"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Indonesian (http://www.transifex.com/rosarior/mayan-edms/language/id/)\n"
|
"Language-Team: Indonesian (http://www.transifex.com/rosarior/mayan-edms/language/id/)\n"
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-08-28 11:33+0000\n"
|
"PO-Revision-Date: 2019-08-28 11:33+0000\n"
|
||||||
"Last-Translator: Daniele Bortoluzzi <daniele@elkos.it>\n"
|
"Last-Translator: Daniele Bortoluzzi <daniele@elkos.it>\n"
|
||||||
"Language-Team: Italian (http://www.transifex.com/rosarior/mayan-edms/language/it/)\n"
|
"Language-Team: Italian (http://www.transifex.com/rosarior/mayan-edms/language/it/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-28 11:16+0000\n"
|
"PO-Revision-Date: 2019-06-28 11:16+0000\n"
|
||||||
"Last-Translator: Māris Teivāns <maris.teivans@gmail.com>\n"
|
"Last-Translator: Māris Teivāns <maris.teivans@gmail.com>\n"
|
||||||
"Language-Team: Latvian (http://www.transifex.com/rosarior/mayan-edms/language/lv/)\n"
|
"Language-Team: Latvian (http://www.transifex.com/rosarior/mayan-edms/language/lv/)\n"
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Dutch (Netherlands) (http://www.transifex.com/rosarior/mayan-edms/language/nl_NL/)\n"
|
"Language-Team: Dutch (Netherlands) (http://www.transifex.com/rosarior/mayan-edms/language/nl_NL/)\n"
|
||||||
|
|||||||
Binary file not shown.
@@ -5,15 +5,16 @@
|
|||||||
# Translators:
|
# Translators:
|
||||||
# Daniel Winiarski <daniel.winiarski.dw@gmail.com>, 2017
|
# Daniel Winiarski <daniel.winiarski.dw@gmail.com>, 2017
|
||||||
# Marcin Lozynski <mlozynski@wp.pl>, 2019
|
# Marcin Lozynski <mlozynski@wp.pl>, 2019
|
||||||
|
# Tomasz Szymanowicz <alakdae@gmail.com>, 2019
|
||||||
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016
|
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016
|
||||||
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2017-2018
|
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2017-2018
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-08-30 21:41+0000\n"
|
"PO-Revision-Date: 2019-09-23 09:33+0000\n"
|
||||||
"Last-Translator: Marcin Lozynski <mlozynski@wp.pl>\n"
|
"Last-Translator: Tomasz Szymanowicz <alakdae@gmail.com>\n"
|
||||||
"Language-Team: Polish (http://www.transifex.com/rosarior/mayan-edms/language/pl/)\n"
|
"Language-Team: Polish (http://www.transifex.com/rosarior/mayan-edms/language/pl/)\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
@@ -27,7 +28,7 @@ msgstr "Listy ACL"
|
|||||||
|
|
||||||
#: events.py:8 permissions.py:7
|
#: events.py:8 permissions.py:7
|
||||||
msgid "Access control lists"
|
msgid "Access control lists"
|
||||||
msgstr "Listy ACL"
|
msgstr "Listy kontroli dostępu"
|
||||||
|
|
||||||
#: events.py:12
|
#: events.py:12
|
||||||
msgid "ACL created"
|
msgid "ACL created"
|
||||||
@@ -56,7 +57,7 @@ msgstr "Uprawnienia"
|
|||||||
#: managers.py:216
|
#: managers.py:216
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "Object \"%s\" is not a model and cannot be checked for access."
|
msgid "Object \"%s\" is not a model and cannot be checked for access."
|
||||||
msgstr ""
|
msgstr "Obiekt \"%s\" nie jest modelem i nie może być sprawdzony pod kątem dostępu."
|
||||||
|
|
||||||
#: managers.py:236
|
#: managers.py:236
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -158,7 +159,7 @@ msgid ""
|
|||||||
"to the role and can't be removed from this view. Inherited permissions need "
|
"to the role and can't be removed from this view. Inherited permissions need "
|
||||||
"to be removed from the parent object's ACL or from them role via the Setup "
|
"to be removed from the parent object's ACL or from them role via the Setup "
|
||||||
"menu."
|
"menu."
|
||||||
msgstr ""
|
msgstr "Wyłączone prawa są dziedziczone z obiektu rodzica lub bezpośrednio nadane dla roli i nie mogą być usunięte w tym widoku. Dziedziczone prawa muszą być usunięte z listy ACL obiektu rodzica lub z roli w menu Ustawień."
|
||||||
|
|
||||||
#: workflow_actions.py:26
|
#: workflow_actions.py:26
|
||||||
msgid "Object type"
|
msgid "Object type"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Portuguese (http://www.transifex.com/rosarior/mayan-edms/language/pt/)\n"
|
"Language-Team: Portuguese (http://www.transifex.com/rosarior/mayan-edms/language/pt/)\n"
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Portuguese (Brazil) (http://www.transifex.com/rosarior/mayan-edms/language/pt_BR/)\n"
|
"Language-Team: Portuguese (Brazil) (http://www.transifex.com/rosarior/mayan-edms/language/pt_BR/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-18 15:35+0000\n"
|
"PO-Revision-Date: 2019-06-18 15:35+0000\n"
|
||||||
"Last-Translator: Harald Ersch\n"
|
"Last-Translator: Harald Ersch\n"
|
||||||
"Language-Team: Romanian (Romania) (http://www.transifex.com/rosarior/mayan-edms/language/ro_RO/)\n"
|
"Language-Team: Romanian (Romania) (http://www.transifex.com/rosarior/mayan-edms/language/ro_RO/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Russian (http://www.transifex.com/rosarior/mayan-edms/language/ru/)\n"
|
"Language-Team: Russian (http://www.transifex.com/rosarior/mayan-edms/language/ru/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Slovenian (Slovenia) (http://www.transifex.com/rosarior/mayan-edms/language/sl_SI/)\n"
|
"Language-Team: Slovenian (Slovenia) (http://www.transifex.com/rosarior/mayan-edms/language/sl_SI/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Turkish (Turkey) (http://www.transifex.com/rosarior/mayan-edms/language/tr_TR/)\n"
|
"Language-Team: Turkish (Turkey) (http://www.transifex.com/rosarior/mayan-edms/language/tr_TR/)\n"
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Vietnamese (Viet Nam) (http://www.transifex.com/rosarior/mayan-edms/language/vi_VN/)\n"
|
"Language-Team: Vietnamese (Viet Nam) (http://www.transifex.com/rosarior/mayan-edms/language/vi_VN/)\n"
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
"PO-Revision-Date: 2019-06-15 07:48+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Chinese (http://www.transifex.com/rosarior/mayan-edms/language/zh/)\n"
|
"Language-Team: Chinese (http://www.transifex.com/rosarior/mayan-edms/language/zh/)\n"
|
||||||
|
|||||||
@@ -45,8 +45,8 @@ class AccessControlListManager(models.Manager):
|
|||||||
# 4: No related field, but has an inherited related field, solved by
|
# 4: No related field, but has an inherited related field, solved by
|
||||||
# recursion, branches to #2 or #3.
|
# recursion, branches to #2 or #3.
|
||||||
# 5: Inherited field of a related field
|
# 5: Inherited field of a related field
|
||||||
# -- Not addressed yet --
|
|
||||||
# 6: Inherited field of a related field that is Generic Foreign Key
|
# 6: Inherited field of a related field that is Generic Foreign Key
|
||||||
|
# -- Not addressed yet --
|
||||||
# 7: Has a related function
|
# 7: Has a related function
|
||||||
result = []
|
result = []
|
||||||
|
|
||||||
@@ -58,10 +58,28 @@ class AccessControlListManager(models.Manager):
|
|||||||
if isinstance(related_field, GenericForeignKey):
|
if isinstance(related_field, GenericForeignKey):
|
||||||
# Case 3: Generic Foreign Key, multiple ContentTypes + object
|
# Case 3: Generic Foreign Key, multiple ContentTypes + object
|
||||||
# id combinations
|
# id combinations
|
||||||
|
# Also handles case #6 using the parent related field
|
||||||
|
# reference template.
|
||||||
|
|
||||||
|
# Craft a double underscore reference to a previous related
|
||||||
|
# field in the case where multiple related fields are
|
||||||
|
# associated.
|
||||||
|
# Example: object_layer__content_type
|
||||||
|
recuisive_related_reference = '__'.join(related_field_name.split('__')[0:-1])
|
||||||
|
|
||||||
|
# If there is at least one parent related field we add a
|
||||||
|
# double underscore to make it a valid filter template.
|
||||||
|
if recuisive_related_reference:
|
||||||
|
recuisive_related_reference = '{}__'.format(recuisive_related_reference)
|
||||||
|
|
||||||
content_type_object_id_queryset = queryset.annotate(
|
content_type_object_id_queryset = queryset.annotate(
|
||||||
ct_fk_combination=Concat(
|
ct_fk_combination=Concat(
|
||||||
related_field.ct_field, Value('-'),
|
'{}{}'.format(
|
||||||
related_field.fk_field, output_field=CharField()
|
recuisive_related_reference, related_field.ct_field
|
||||||
|
), Value('-'),
|
||||||
|
'{}{}'.format(
|
||||||
|
recuisive_related_reference, related_field.fk_field
|
||||||
|
), output_field=CharField()
|
||||||
)
|
)
|
||||||
).values('ct_fk_combination')
|
).values('ct_fk_combination')
|
||||||
|
|
||||||
@@ -75,8 +93,7 @@ class AccessControlListManager(models.Manager):
|
|||||||
ct_fk_combination__in=content_type_object_id_queryset
|
ct_fk_combination__in=content_type_object_id_queryset
|
||||||
).values('object_id')
|
).values('object_id')
|
||||||
|
|
||||||
field_lookup = 'object_id__in'
|
field_lookup = '{}object_id__in'.format(recuisive_related_reference)
|
||||||
|
|
||||||
result.append(Q(**{field_lookup: acl_filter}))
|
result.append(Q(**{field_lookup: acl_filter}))
|
||||||
else:
|
else:
|
||||||
# Case 2: Related field of a single type, single ContentType,
|
# Case 2: Related field of a single type, single ContentType,
|
||||||
@@ -97,6 +114,7 @@ class AccessControlListManager(models.Manager):
|
|||||||
|
|
||||||
# Case 5: Related field, has an inherited related field itself
|
# Case 5: Related field, has an inherited related field itself
|
||||||
# Bubble up permssion check
|
# Bubble up permssion check
|
||||||
|
# Recurse and reduce
|
||||||
# TODO: Add relationship support: OR or AND
|
# TODO: Add relationship support: OR or AND
|
||||||
# TODO: OR for document pages, version, doc, and types
|
# TODO: OR for document pages, version, doc, and types
|
||||||
# TODO: AND for new cabinet levels ACLs
|
# TODO: AND for new cabinet levels ACLs
|
||||||
@@ -200,28 +218,26 @@ class AccessControlListManager(models.Manager):
|
|||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def check_access(self, obj, permissions, user, manager=None):
|
def check_access(self, obj, permissions, user):
|
||||||
# Allow specific managers for models that have more than one
|
# Allow specific managers for models that have more than one
|
||||||
# for example the Document model when checking for access for a trashed
|
# for example the Document model when checking for access for a trashed
|
||||||
# document.
|
# document.
|
||||||
|
|
||||||
if manager:
|
meta = getattr(obj, '_meta', None)
|
||||||
source_queryset = manager.all()
|
|
||||||
|
if not meta:
|
||||||
|
logger.debug(
|
||||||
|
ugettext(
|
||||||
|
'Object "%s" is not a model and cannot be checked for '
|
||||||
|
'access.'
|
||||||
|
) % force_text(obj)
|
||||||
|
)
|
||||||
|
return True
|
||||||
else:
|
else:
|
||||||
meta = getattr(obj, '_meta', None)
|
manager = ModelPermission.get_manager(model=obj._meta.model)
|
||||||
|
source_queryset = manager.all()
|
||||||
|
|
||||||
if not meta:
|
restricted_queryset = manager.none()
|
||||||
logger.debug(
|
|
||||||
ugettext(
|
|
||||||
'Object "%s" is not a model and cannot be checked for '
|
|
||||||
'access.'
|
|
||||||
) % force_text(obj)
|
|
||||||
)
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
source_queryset = obj._meta.default_manager.all()
|
|
||||||
|
|
||||||
restricted_queryset = obj._meta.default_manager.none()
|
|
||||||
for permission in permissions:
|
for permission in permissions:
|
||||||
# Default relationship betweens permissions is OR
|
# Default relationship betweens permissions is OR
|
||||||
# TODO: Add support for AND relationship
|
# TODO: Add support for AND relationship
|
||||||
@@ -239,6 +255,9 @@ class AccessControlListManager(models.Manager):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def restrict_queryset(self, permission, queryset, user):
|
def restrict_queryset(self, permission, queryset, user):
|
||||||
|
if not user.is_authenticated():
|
||||||
|
return queryset.none()
|
||||||
|
|
||||||
# Check directly granted permission via a role
|
# Check directly granted permission via a role
|
||||||
try:
|
try:
|
||||||
Permission.check_user_permissions(
|
Permission.check_user_permissions(
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ from __future__ import absolute_import, unicode_literals
|
|||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
|
|
||||||
from mayan.apps.permissions.tests.literals import TEST_ROLE_LABEL
|
from mayan.apps.permissions.tests.literals import TEST_ROLE_LABEL
|
||||||
from mayan.apps.rest_api.tests import BaseAPITestCase
|
from mayan.apps.rest_api.tests.base import BaseAPITestCase
|
||||||
|
|
||||||
from ..models import AccessControlList
|
from ..models import AccessControlList
|
||||||
from ..permissions import permission_acl_edit, permission_acl_view
|
from ..permissions import permission_acl_edit, permission_acl_view
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
from __future__ import absolute_import, unicode_literals
|
from __future__ import absolute_import, unicode_literals
|
||||||
|
|
||||||
from mayan.apps.common.tests import BaseTestCase
|
from mayan.apps.common.tests.base import BaseTestCase
|
||||||
|
|
||||||
from ..classes import ModelPermission
|
from ..classes import ModelPermission
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ from __future__ import unicode_literals
|
|||||||
|
|
||||||
from django.urls import reverse
|
from django.urls import reverse
|
||||||
|
|
||||||
from mayan.apps.common.tests import GenericViewTestCase
|
from mayan.apps.common.tests.base import GenericViewTestCase
|
||||||
|
|
||||||
from ..links import (
|
from ..links import (
|
||||||
link_acl_delete, link_acl_list, link_acl_create, link_acl_permissions
|
link_acl_delete, link_acl_list, link_acl_create, link_acl_permissions
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ from __future__ import absolute_import, unicode_literals
|
|||||||
from django.core.exceptions import PermissionDenied
|
from django.core.exceptions import PermissionDenied
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
from mayan.apps.common.tests import BaseTestCase
|
from mayan.apps.common.tests.base import BaseTestCase
|
||||||
|
|
||||||
from ..classes import ModelPermission
|
from ..classes import ModelPermission
|
||||||
from ..models import AccessControlList
|
from ..models import AccessControlList
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
from __future__ import absolute_import, unicode_literals
|
from __future__ import absolute_import, unicode_literals
|
||||||
|
|
||||||
from mayan.apps.common.tests import GenericViewTestCase
|
from mayan.apps.common.tests.base import GenericViewTestCase
|
||||||
|
|
||||||
from ..models import AccessControlList
|
from ..models import AccessControlList
|
||||||
from ..permissions import permission_acl_edit, permission_acl_view
|
from ..permissions import permission_acl_edit, permission_acl_view
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ from __future__ import unicode_literals
|
|||||||
|
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
|
||||||
from mayan.apps.document_states.tests.test_actions import ActionTestCase
|
from mayan.apps.document_states.tests.test_workflow_actions import ActionTestCase
|
||||||
from mayan.apps.documents.permissions import permission_document_view
|
from mayan.apps.documents.permissions import permission_document_view
|
||||||
|
|
||||||
from ..workflow_actions import (
|
from ..workflow_actions import (
|
||||||
@@ -16,7 +16,6 @@ from mayan.apps.permissions.models import Role
|
|||||||
from .classes import ModelPermission
|
from .classes import ModelPermission
|
||||||
from .permissions import permission_acl_edit
|
from .permissions import permission_acl_edit
|
||||||
|
|
||||||
__all__ = ('GrantAccessAction', 'RevokeAccessAction')
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
@@ -57,7 +56,7 @@ class GrantAccessAction(WorkflowAction):
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
field_order = ('content_type', 'object_id', 'roles', 'permissions')
|
field_order = ('content_type', 'object_id', 'roles', 'permissions')
|
||||||
label = _('Grant access')
|
label = _('Grant object access')
|
||||||
widgets = {
|
widgets = {
|
||||||
'content_type': {
|
'content_type': {
|
||||||
'class': 'django.forms.widgets.Select', 'kwargs': {
|
'class': 'django.forms.widgets.Select', 'kwargs': {
|
||||||
@@ -140,7 +139,7 @@ class GrantAccessAction(WorkflowAction):
|
|||||||
|
|
||||||
|
|
||||||
class RevokeAccessAction(GrantAccessAction):
|
class RevokeAccessAction(GrantAccessAction):
|
||||||
label = _('Revoke access')
|
label = _('Revoke object access')
|
||||||
|
|
||||||
def execute(self, context):
|
def execute(self, context):
|
||||||
self.get_execute_data()
|
self.get_execute_data()
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ from django.template.loader import get_template
|
|||||||
|
|
||||||
|
|
||||||
class IconDriver(object):
|
class IconDriver(object):
|
||||||
|
context = {}
|
||||||
_registry = {}
|
_registry = {}
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
@@ -14,6 +15,17 @@ class IconDriver(object):
|
|||||||
def register(cls, driver_class):
|
def register(cls, driver_class):
|
||||||
cls._registry[driver_class.name] = driver_class
|
cls._registry[driver_class.name] = driver_class
|
||||||
|
|
||||||
|
def get_context(self):
|
||||||
|
return self.context
|
||||||
|
|
||||||
|
def render(self, extra_context=None):
|
||||||
|
context = self.get_context()
|
||||||
|
if extra_context:
|
||||||
|
context.update(extra_context)
|
||||||
|
return get_template(template_name=self.template_name).render(
|
||||||
|
context=context
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class FontAwesomeDriver(IconDriver):
|
class FontAwesomeDriver(IconDriver):
|
||||||
name = 'fontawesome'
|
name = 'fontawesome'
|
||||||
@@ -22,10 +34,8 @@ class FontAwesomeDriver(IconDriver):
|
|||||||
def __init__(self, symbol):
|
def __init__(self, symbol):
|
||||||
self.symbol = symbol
|
self.symbol = symbol
|
||||||
|
|
||||||
def render(self):
|
def get_context(self):
|
||||||
return get_template(template_name=self.template_name).render(
|
return {'symbol': self.symbol}
|
||||||
context={'symbol': self.symbol}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FontAwesomeDualDriver(IconDriver):
|
class FontAwesomeDualDriver(IconDriver):
|
||||||
@@ -36,23 +46,21 @@ class FontAwesomeDualDriver(IconDriver):
|
|||||||
self.primary_symbol = primary_symbol
|
self.primary_symbol = primary_symbol
|
||||||
self.secondary_symbol = secondary_symbol
|
self.secondary_symbol = secondary_symbol
|
||||||
|
|
||||||
def render(self):
|
def get_context(self):
|
||||||
return get_template(template_name=self.template_name).render(
|
return {
|
||||||
context={
|
'data': (
|
||||||
'data': (
|
{
|
||||||
{
|
'class': 'fas fa-circle',
|
||||||
'class': 'fas fa-circle',
|
'transform': 'down-3 right-10',
|
||||||
'transform': 'down-3 right-10',
|
'mask': 'fas fa-{}'.format(self.primary_symbol)
|
||||||
'mask': 'fas fa-{}'.format(self.primary_symbol)
|
},
|
||||||
},
|
{'class': 'far fa-circle', 'transform': 'down-3 right-10'},
|
||||||
{'class': 'far fa-circle', 'transform': 'down-3 right-10'},
|
{
|
||||||
{
|
'class': 'fas fa-{}'.format(self.secondary_symbol),
|
||||||
'class': 'fas fa-{}'.format(self.secondary_symbol),
|
'transform': 'shrink-4 down-3 right-10'
|
||||||
'transform': 'shrink-4 down-3 right-10'
|
},
|
||||||
},
|
)
|
||||||
)
|
}
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FontAwesomeCSSDriver(IconDriver):
|
class FontAwesomeCSSDriver(IconDriver):
|
||||||
@@ -62,10 +70,8 @@ class FontAwesomeCSSDriver(IconDriver):
|
|||||||
def __init__(self, css_classes):
|
def __init__(self, css_classes):
|
||||||
self.css_classes = css_classes
|
self.css_classes = css_classes
|
||||||
|
|
||||||
def render(self):
|
def get_context(self):
|
||||||
return get_template(template_name=self.template_name).render(
|
return {'css_classes': self.css_classes}
|
||||||
context={'css_classes': self.css_classes}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FontAwesomeMasksDriver(IconDriver):
|
class FontAwesomeMasksDriver(IconDriver):
|
||||||
@@ -75,23 +81,23 @@ class FontAwesomeMasksDriver(IconDriver):
|
|||||||
def __init__(self, data):
|
def __init__(self, data):
|
||||||
self.data = data
|
self.data = data
|
||||||
|
|
||||||
def render(self):
|
def get_context(self):
|
||||||
return get_template(template_name=self.template_name).render(
|
return {'data': self.data}
|
||||||
context={'data': self.data}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FontAwesomeLayersDriver(IconDriver):
|
class FontAwesomeLayersDriver(IconDriver):
|
||||||
name = 'fontawesome-layers'
|
name = 'fontawesome-layers'
|
||||||
template_name = 'appearance/icons/font_awesome_layers.html'
|
template_name = 'appearance/icons/font_awesome_layers.html'
|
||||||
|
|
||||||
def __init__(self, data):
|
def __init__(self, data, shadow_class=None):
|
||||||
self.data = data
|
self.data = data
|
||||||
|
self.shadow_class = shadow_class
|
||||||
|
|
||||||
def render(self):
|
def get_context(self):
|
||||||
return get_template(template_name=self.template_name).render(
|
return {
|
||||||
context={'data': self.data}
|
'data': self.data,
|
||||||
)
|
'shadow_class': self.shadow_class,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
class Icon(object):
|
class Icon(object):
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ JavaScriptDependency(
|
|||||||
name='@fortawesome/fontawesome-free', version_string='=5.6.3'
|
name='@fortawesome/fontawesome-free', version_string='=5.6.3'
|
||||||
)
|
)
|
||||||
JavaScriptDependency(
|
JavaScriptDependency(
|
||||||
label=_('jQuery'), module=__name__, name='jquery', version_string='=3.3.1'
|
label=_('jQuery'), module=__name__, name='jquery', version_string='=3.4.1'
|
||||||
)
|
)
|
||||||
JavaScriptDependency(
|
JavaScriptDependency(
|
||||||
label=_('JQuery Form'), module=__name__, name='jquery-form',
|
label=_('JQuery Form'), module=__name__, name='jquery-form',
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
DEFAULT_MAXIMUM_TITLE_LENGTH = 120
|
DEFAULT_MAXIMUM_TITLE_LENGTH = 120
|
||||||
|
DEFAULT_MESSAGE_POSITION = 'top-right'
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Arabic (http://www.transifex.com/rosarior/mayan-edms/language/ar/)\n"
|
"Language-Team: Arabic (http://www.transifex.com/rosarior/mayan-edms/language/ar/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr "لم يتم العثور على الصفحة"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "عفواً، لا يمكن العثور على الصفحة المطلوبة."
|
msgstr "عفواً، لا يمكن العثور على الصفحة المطلوبة."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Bulgarian (http://www.transifex.com/rosarior/mayan-edms/language/bg/)\n"
|
"Language-Team: Bulgarian (http://www.transifex.com/rosarior/mayan-edms/language/bg/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr "Страницата не е намерена"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Bosnian (Bosnia and Herzegovina) (http://www.transifex.com/rosarior/mayan-edms/language/bs_BA/)\n"
|
"Language-Team: Bosnian (Bosnia and Herzegovina) (http://www.transifex.com/rosarior/mayan-edms/language/bs_BA/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Stranica nije pronađena"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Žao nam je, ali tražena stranica ne može biti pronađena."
|
msgstr "Žao nam je, ali tražena stranica ne može biti pronađena."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Greška u serveru"
|
msgstr "Greška u serveru"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr "Prebacite navigaciju"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Nema rezultata"
|
msgstr "Nema rezultata"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Zatvori"
|
msgstr "Zatvori"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Problem u komunikaciji sa serverom"
|
msgstr "Problem u komunikaciji sa serverom"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Proverite mrežnu vezu i pokušajte ponovo za nekoliko trenutaka."
|
msgstr "Proverite mrežnu vezu i pokušajte ponovo za nekoliko trenutaka."
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Czech (http://www.transifex.com/rosarior/mayan-edms/language/cs/)\n"
|
"Language-Team: Czech (http://www.transifex.com/rosarior/mayan-edms/language/cs/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr ""
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Danish (Denmark) (http://www.transifex.com/rosarior/mayan-edms/language/da_DK/)\n"
|
"Language-Team: Danish (Denmark) (http://www.transifex.com/rosarior/mayan-edms/language/da_DK/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Side ikke fundet"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Beklager, men den ønskede side kunne ikke findes"
|
msgstr "Beklager, men den ønskede side kunne ikke findes"
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Server fejl"
|
msgstr "Server fejl"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Ingen resultater"
|
msgstr "Ingen resultater"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Luk"
|
msgstr "Luk"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: German (Germany) (http://www.transifex.com/rosarior/mayan-edms/language/de_DE/)\n"
|
"Language-Team: German (Germany) (http://www.transifex.com/rosarior/mayan-edms/language/de_DE/)\n"
|
||||||
@@ -93,7 +93,7 @@ msgstr "Seite nicht gefunden"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Die angeforderte Seite konnte leider nicht gefunden werden"
|
msgstr "Die angeforderte Seite konnte leider nicht gefunden werden"
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Serverfehler"
|
msgstr "Serverfehler"
|
||||||
|
|
||||||
@@ -296,15 +296,15 @@ msgstr "Navigation ein-/ausschalten"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Kein Ergebnis"
|
msgstr "Kein Ergebnis"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Schließen"
|
msgstr "Schließen"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Fehler bei der Verbindung zum Server"
|
msgstr "Fehler bei der Verbindung zum Server"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Prüfen Sie Ihre Netzwerkeinstellungen und versuchen Sie es nochmals."
|
msgstr "Prüfen Sie Ihre Netzwerkeinstellungen und versuchen Sie es nochmals."
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Greek (http://www.transifex.com/rosarior/mayan-edms/language/el/)\n"
|
"Language-Team: Greek (http://www.transifex.com/rosarior/mayan-edms/language/el/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr "Η σελίδα δεν βρέθηκε"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Λυπάμαι, η ζητούμενη σελίδα δεν βρέθηκε."
|
msgstr "Λυπάμαι, η ζητούμενη σελίδα δεν βρέθηκε."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Σφάλμα διακομηστή"
|
msgstr "Σφάλμα διακομηστή"
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr "Εναλλαγή πλοήγησης"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Κανένα αποτέλεσμα"
|
msgstr "Κανένα αποτέλεσμα"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: PACKAGE VERSION\n"
|
"Project-Id-Version: PACKAGE VERSION\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr ""
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -319,15 +319,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
@@ -8,8 +8,8 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-24 21:04+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Spanish (http://www.transifex.com/rosarior/mayan-edms/language/es/)\n"
|
"Language-Team: Spanish (http://www.transifex.com/rosarior/mayan-edms/language/es/)\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Página no encontrada"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Lo sentimos, pero no se pudo encontrar la página solicitada."
|
msgstr "Lo sentimos, pero no se pudo encontrar la página solicitada."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Error de servidor"
|
msgstr "Error de servidor"
|
||||||
|
|
||||||
@@ -155,14 +155,14 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nTambién puede <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donar directamente al creador y desarrollador principal. %(icon_social_paypal)s</a>"
|
||||||
|
|
||||||
#: templates/appearance/about.html:127
|
#: templates/appearance/about.html:127
|
||||||
msgid ""
|
msgid ""
|
||||||
"\n"
|
"\n"
|
||||||
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nAdemás de las donaciones, también puede apoyar el proyecto <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">comprando una copia del libro \"Exploring Mayan EDMS\" de Roberto Rosario</a> . <br> El libro está disponible en formato de prelanzamiento a un precio con descuento por tiempo limitado."
|
||||||
|
|
||||||
#: templates/appearance/about.html:133
|
#: templates/appearance/about.html:133
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -293,15 +293,15 @@ msgstr "Activar/Desactivar navegación"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Ningún resultado"
|
msgstr "Ningún resultado"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Cerrar"
|
msgstr "Cerrar"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Error de comunicación del servidor"
|
msgstr "Error de comunicación del servidor"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Verifique su conexión de red y vuelva a intentarlo en unos momentos."
|
msgstr "Verifique su conexión de red y vuelva a intentarlo en unos momentos."
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Persian (http://www.transifex.com/rosarior/mayan-edms/language/fa/)\n"
|
"Language-Team: Persian (http://www.transifex.com/rosarior/mayan-edms/language/fa/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "صفحه پیدا نشد."
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "متاسفانه صفحه درخواستی پیدا نشد."
|
msgstr "متاسفانه صفحه درخواستی پیدا نشد."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "خطای سرور"
|
msgstr "خطای سرور"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr "تغییر ناوبری"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "بی جواب و یا بی جواب"
|
msgstr "بی جواب و یا بی جواب"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: French (http://www.transifex.com/rosarior/mayan-edms/language/fr/)\n"
|
"Language-Team: French (http://www.transifex.com/rosarior/mayan-edms/language/fr/)\n"
|
||||||
@@ -95,7 +95,7 @@ msgstr "Page non trouvée"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Désolé, la page demandée n'a pu être trouvée."
|
msgstr "Désolé, la page demandée n'a pu être trouvée."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Erreur du serveur"
|
msgstr "Erreur du serveur"
|
||||||
|
|
||||||
@@ -298,15 +298,15 @@ msgstr "Activer la navigation"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Pas de résultats"
|
msgstr "Pas de résultats"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Fermer"
|
msgstr "Fermer"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Erreur de communication serveur"
|
msgstr "Erreur de communication serveur"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Vérifiez votre connexion réseau et réessayez dans quelques instants."
|
msgstr "Vérifiez votre connexion réseau et réessayez dans quelques instants."
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Hungarian (http://www.transifex.com/rosarior/mayan-edms/language/hu/)\n"
|
"Language-Team: Hungarian (http://www.transifex.com/rosarior/mayan-edms/language/hu/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Oldal nem található"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Indonesian (http://www.transifex.com/rosarior/mayan-edms/language/id/)\n"
|
"Language-Team: Indonesian (http://www.transifex.com/rosarior/mayan-edms/language/id/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr ""
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Italian (http://www.transifex.com/rosarior/mayan-edms/language/it/)\n"
|
"Language-Team: Italian (http://www.transifex.com/rosarior/mayan-edms/language/it/)\n"
|
||||||
@@ -92,7 +92,7 @@ msgstr "Pagina non trovata"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Scusa ma la pagina richiesta non è disponibile"
|
msgstr "Scusa ma la pagina richiesta non è disponibile"
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Errore del server"
|
msgstr "Errore del server"
|
||||||
|
|
||||||
@@ -295,15 +295,15 @@ msgstr "Cambia navigazione"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Nessun risultato"
|
msgstr "Nessun risultato"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Chiudi"
|
msgstr "Chiudi"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Errore di comunicazione del Server"
|
msgstr "Errore di comunicazione del Server"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Controlla la connessione di rete e riprova"
|
msgstr "Controlla la connessione di rete e riprova"
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Latvian (http://www.transifex.com/rosarior/mayan-edms/language/lv/)\n"
|
"Language-Team: Latvian (http://www.transifex.com/rosarior/mayan-edms/language/lv/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Lapa nav atrasta"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Diemžēl pieprasīto lapu nevarēja atrast."
|
msgstr "Diemžēl pieprasīto lapu nevarēja atrast."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Servera kļūda"
|
msgstr "Servera kļūda"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr "Pārslēgt navigāciju"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Nav rezultātu"
|
msgstr "Nav rezultātu"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Aizvērt"
|
msgstr "Aizvērt"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Servera sakaru kļūda"
|
msgstr "Servera sakaru kļūda"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Pārbaudiet tīkla savienojumu un pēc brīža mēģiniet vēlreiz."
|
msgstr "Pārbaudiet tīkla savienojumu un pēc brīža mēģiniet vēlreiz."
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Dutch (Netherlands) (http://www.transifex.com/rosarior/mayan-edms/language/nl_NL/)\n"
|
"Language-Team: Dutch (Netherlands) (http://www.transifex.com/rosarior/mayan-edms/language/nl_NL/)\n"
|
||||||
@@ -92,7 +92,7 @@ msgstr "Pagina niet gevonden"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Excuses, maar de opgevraagde pagina kan niet worden gevonden."
|
msgstr "Excuses, maar de opgevraagde pagina kan niet worden gevonden."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Server fout"
|
msgstr "Server fout"
|
||||||
|
|
||||||
@@ -295,15 +295,15 @@ msgstr "Toggle navigatie"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Geen resultaten"
|
msgstr "Geen resultaten"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Sluiten"
|
msgstr "Sluiten"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Server communicatie probleem"
|
msgstr "Server communicatie probleem"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Controleer uw netwerkverbinding en probeer nog eens een beetje later."
|
msgstr "Controleer uw netwerkverbinding en probeer nog eens een beetje later."
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
@@ -4,6 +4,7 @@
|
|||||||
#
|
#
|
||||||
# Translators:
|
# Translators:
|
||||||
# Marcin Lozynski <mlozynski@wp.pl>, 2019
|
# Marcin Lozynski <mlozynski@wp.pl>, 2019
|
||||||
|
# Tomasz Szymanowicz <alakdae@gmail.com>, 2019
|
||||||
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016,2018
|
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016,2018
|
||||||
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2017
|
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2017
|
||||||
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016
|
# Wojciech Warczakowski <w.warczakowski@gmail.com>, 2016
|
||||||
@@ -11,9 +12,9 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-23 09:49+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Tomasz Szymanowicz <alakdae@gmail.com>\n"
|
||||||
"Language-Team: Polish (http://www.transifex.com/rosarior/mayan-edms/language/pl/)\n"
|
"Language-Team: Polish (http://www.transifex.com/rosarior/mayan-edms/language/pl/)\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
@@ -27,23 +28,23 @@ msgstr "Wygląd"
|
|||||||
|
|
||||||
#: dependencies.py:10
|
#: dependencies.py:10
|
||||||
msgid "Lato font"
|
msgid "Lato font"
|
||||||
msgstr ""
|
msgstr "Czcionka Lato"
|
||||||
|
|
||||||
#: dependencies.py:14
|
#: dependencies.py:14
|
||||||
msgid "Bootstrap"
|
msgid "Bootstrap"
|
||||||
msgstr ""
|
msgstr "Bootstrap"
|
||||||
|
|
||||||
#: dependencies.py:18
|
#: dependencies.py:18
|
||||||
msgid "Bootswatch"
|
msgid "Bootswatch"
|
||||||
msgstr ""
|
msgstr "Bootswatch"
|
||||||
|
|
||||||
#: dependencies.py:32
|
#: dependencies.py:32
|
||||||
msgid "Fancybox"
|
msgid "Fancybox"
|
||||||
msgstr ""
|
msgstr "Fancybox"
|
||||||
|
|
||||||
#: dependencies.py:36
|
#: dependencies.py:36
|
||||||
msgid "FontAwesome"
|
msgid "FontAwesome"
|
||||||
msgstr ""
|
msgstr "FontAwesome"
|
||||||
|
|
||||||
#: dependencies.py:40
|
#: dependencies.py:40
|
||||||
msgid "jQuery"
|
msgid "jQuery"
|
||||||
@@ -55,11 +56,11 @@ msgstr "Formularz JQuery"
|
|||||||
|
|
||||||
#: dependencies.py:47
|
#: dependencies.py:47
|
||||||
msgid "jQuery Lazy Load"
|
msgid "jQuery Lazy Load"
|
||||||
msgstr ""
|
msgstr "jQuery Opóźnione Ładowanie"
|
||||||
|
|
||||||
#: dependencies.py:51
|
#: dependencies.py:51
|
||||||
msgid "JQuery Match Height"
|
msgid "JQuery Match Height"
|
||||||
msgstr ""
|
msgstr "JQuery Wyrównaj Wysokość"
|
||||||
|
|
||||||
#: dependencies.py:55
|
#: dependencies.py:55
|
||||||
msgid "Select 2"
|
msgid "Select 2"
|
||||||
@@ -67,11 +68,11 @@ msgstr "Wybierz 2"
|
|||||||
|
|
||||||
#: dependencies.py:59
|
#: dependencies.py:59
|
||||||
msgid "Toastr"
|
msgid "Toastr"
|
||||||
msgstr ""
|
msgstr "Toastr"
|
||||||
|
|
||||||
#: dependencies.py:62
|
#: dependencies.py:62
|
||||||
msgid "URI.js"
|
msgid "URI.js"
|
||||||
msgstr ""
|
msgstr "URI.js"
|
||||||
|
|
||||||
#: settings.py:14
|
#: settings.py:14
|
||||||
msgid "Maximum number of characters that will be displayed as the view title."
|
msgid "Maximum number of characters that will be displayed as the view title."
|
||||||
@@ -93,7 +94,7 @@ msgstr "Nie znaleziono strony"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Niestety, żądana strona nie została znaleziona."
|
msgstr "Niestety, żądana strona nie została znaleziona."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Błąd serwera"
|
msgstr "Błąd serwera"
|
||||||
|
|
||||||
@@ -134,7 +135,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" %(project_title)s is a free and open-source software brought to you with <i class=\"fa fa-heart text-danger\" style=\"transform: rotate(10deg);\"></i> by Roberto Rosario and contributors.\n"
|
" %(project_title)s is a free and open-source software brought to you with <i class=\"fa fa-heart text-danger\" style=\"transform: rotate(10deg);\"></i> by Roberto Rosario and contributors.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\n%(project_title)s jest darmowym oprogramowaniem typu open source dostarczonym z <i class=\"fa fa-heart text-danger\" style=\"transform: rotate(10deg);\"></i> przez Roberto Rosario i współpracowników."
|
||||||
|
|
||||||
#: templates/appearance/about.html:109
|
#: templates/appearance/about.html:109
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -142,7 +143,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" It takes great effort to make %(project_title)s as feature-rich as it is. We need all the help we can get!\n"
|
" It takes great effort to make %(project_title)s as feature-rich as it is. We need all the help we can get!\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nAby %(project_title)s był tak bogaty w funkcje wymaga wiele pracy. Każda pomoc jest mile widziana!"
|
||||||
|
|
||||||
#: templates/appearance/about.html:115
|
#: templates/appearance/about.html:115
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -150,7 +151,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" If you use %(project_title)s please <a class=\"new_window\" href=\"https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=3PXN336XFXQNN\">consider making a donation %(icon_social_paypal)s</a>\n"
|
" If you use %(project_title)s please <a class=\"new_window\" href=\"https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=3PXN336XFXQNN\">consider making a donation %(icon_social_paypal)s</a>\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nJeśli używasz %(project_title)s, <a class=\"new_window\" href=\"https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=3PXN336XFXQNN\">rozważ darowiznę %(icon_social_paypal)s</a>"
|
||||||
|
|
||||||
#: templates/appearance/about.html:121
|
#: templates/appearance/about.html:121
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -158,14 +159,14 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nMożesz także <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">przekazać darowiznę bezpośrednio twórcy i głównemu deweloperowi. %(icon_social_paypal)s</a>"
|
||||||
|
|
||||||
#: templates/appearance/about.html:127
|
#: templates/appearance/about.html:127
|
||||||
msgid ""
|
msgid ""
|
||||||
"\n"
|
"\n"
|
||||||
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nOprócz darowizn możesz również wesprzeć projekt <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">kupując książkę „Exploring Mayan EDMS” autorstwa Roberto Rosario</a> . <br> Książka jest dostępna w formacie przedpremierowym po obniżonej cenie przez ograniczony czas."
|
||||||
|
|
||||||
#: templates/appearance/about.html:133
|
#: templates/appearance/about.html:133
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -173,7 +174,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" The complete list of changes is available via the <a class=\"new_window\" href=\"https://docs.mayan-edms.com/releases/index.html\">Release notes %(icon_documentation)s</a> or the short version <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms/blob/master/HISTORY.rst\">Changelog %(icon_documentation)s</a>.\n"
|
" The complete list of changes is available via the <a class=\"new_window\" href=\"https://docs.mayan-edms.com/releases/index.html\">Release notes %(icon_documentation)s</a> or the short version <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms/blob/master/HISTORY.rst\">Changelog %(icon_documentation)s</a>.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nPełna lista zmian jest dostępna w <a class=\"new_window\" href=\"https://docs.mayan-edms.com/releases/index.html\">informacjach o wersji %(icon_documentation)s</a> lub w krótkiej wersji <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms/blob/master/HISTORY.rst\">Dziennik zmian %(icon_documentation)s</a> ."
|
||||||
|
|
||||||
#: templates/appearance/about.html:139
|
#: templates/appearance/about.html:139
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -181,7 +182,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" For questions check the <a class=\"new_window\" href=\"https://docs.mayan-edms.com\">Documentation %(icon_documentation)s</a> or the <a class=\"new_window\" href=\"https://wiki.mayan-edms.com\">Wiki %(icon_wiki)s</a>.\n"
|
" For questions check the <a class=\"new_window\" href=\"https://docs.mayan-edms.com\">Documentation %(icon_documentation)s</a> or the <a class=\"new_window\" href=\"https://wiki.mayan-edms.com\">Wiki %(icon_wiki)s</a>.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nW razie pytań sprawdź <a class=\"new_window\" href=\"https://docs.mayan-edms.com\">dokumentację %(icon_documentation)s</a> lub <a class=\"new_window\" href=\"https://wiki.mayan-edms.com\">Wiki %(icon_wiki)s</a> ."
|
||||||
|
|
||||||
#: templates/appearance/about.html:145
|
#: templates/appearance/about.html:145
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -189,7 +190,7 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" If you found a bug or have a feature idea, visit the <a class=\"new_window\" href=\"https://forum.mayan-edms.com\">Forum %(icon_forum)s</a> or open a ticket in the <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms\">Source code repository %(icon_source_code)s</a>.\n"
|
" If you found a bug or have a feature idea, visit the <a class=\"new_window\" href=\"https://forum.mayan-edms.com\">Forum %(icon_forum)s</a> or open a ticket in the <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms\">Source code repository %(icon_source_code)s</a>.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nJeśli znalazłeś błąd lub masz pomysł na funkcję, odwiedź <a class=\"new_window\" href=\"https://forum.mayan-edms.com\">forum %(icon_forum)s</a> lub otwórz zgłoszenie w <a class=\"new_window\" href=\"https://gitlab.com/mayan-edms/mayan-edms\">repozytorium kodu źródłowego %(icon_source_code)s</a> ."
|
||||||
|
|
||||||
#: templates/appearance/about.html:150
|
#: templates/appearance/about.html:150
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -198,7 +199,7 @@ msgid ""
|
|||||||
" Spread the word. Talk to your friends and colleagues about how awesome %(project_title)s is!\n"
|
" Spread the word. Talk to your friends and colleagues about how awesome %(project_title)s is!\n"
|
||||||
" Follow us on <a class=\"new_window\" href=\"https://twitter.com/mayanedms\">Twitter %(icon_social_twitter)s</a>, <a class=\"new_window\" href=\"https://www.facebook.com/MayanEDMS/\">Facebook %(icon_social_facebook)s</a>, or <a class=\"new_window\" href=\"https://www.instagram.com/mayan_edms/\">Instagram %(icon_social_instagram)s</a>\n"
|
" Follow us on <a class=\"new_window\" href=\"https://twitter.com/mayanedms\">Twitter %(icon_social_twitter)s</a>, <a class=\"new_window\" href=\"https://www.facebook.com/MayanEDMS/\">Facebook %(icon_social_facebook)s</a>, or <a class=\"new_window\" href=\"https://www.instagram.com/mayan_edms/\">Instagram %(icon_social_instagram)s</a>\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nPrzekaż innym. Porozmawiaj ze znajomymi i kolegami o tym, jak niesamowity jest %(project_title)s! Śledź nas na <a class=\"new_window\" href=\"https://twitter.com/mayanedms\">Twitterze %(icon_social_twitter)s</a> , <a class=\"new_window\" href=\"https://www.facebook.com/MayanEDMS/\">Facebooku %(icon_social_facebook)s</a> lub <a class=\"new_window\" href=\"https://www.instagram.com/mayan_edms/\">Instagramie %(icon_social_instagram)s</a>"
|
||||||
|
|
||||||
#: templates/appearance/base.html:36 templates/appearance/base.html:46
|
#: templates/appearance/base.html:36 templates/appearance/base.html:46
|
||||||
msgid "Warning"
|
msgid "Warning"
|
||||||
@@ -296,15 +297,15 @@ msgstr "Rozwiń nawigację"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Brak wyników"
|
msgstr "Brak wyników"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Zamknij"
|
msgstr "Zamknij"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Błąd komunikacji z serwerem"
|
msgstr "Błąd komunikacji z serwerem"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Sprawdź połączenie z siecią i spróbuj za chwilę."
|
msgstr "Sprawdź połączenie z siecią i spróbuj za chwilę."
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Portuguese (http://www.transifex.com/rosarior/mayan-edms/language/pt/)\n"
|
"Language-Team: Portuguese (http://www.transifex.com/rosarior/mayan-edms/language/pt/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr "Página não encontrada"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Desculpe, mas a página solicitada não foi encontrada."
|
msgstr "Desculpe, mas a página solicitada não foi encontrada."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Sem resultados"
|
msgstr "Sem resultados"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Portuguese (Brazil) (http://www.transifex.com/rosarior/mayan-edms/language/pt_BR/)\n"
|
"Language-Team: Portuguese (Brazil) (http://www.transifex.com/rosarior/mayan-edms/language/pt_BR/)\n"
|
||||||
@@ -92,7 +92,7 @@ msgstr "Página não encontrada"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Desculpe, mas a página solicitada não pôde ser encontrada."
|
msgstr "Desculpe, mas a página solicitada não pôde ser encontrada."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Erro de servidor"
|
msgstr "Erro de servidor"
|
||||||
|
|
||||||
@@ -295,15 +295,15 @@ msgstr "Ativar/desativar navegação"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Nenhum resultado"
|
msgstr "Nenhum resultado"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Fechar"
|
msgstr "Fechar"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Erro na comunicação com o servidor"
|
msgstr "Erro na comunicação com o servidor"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Verifique sua conexão de rede e tente novamente em alguns instantes. "
|
msgstr "Verifique sua conexão de rede e tente novamente em alguns instantes. "
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
@@ -9,9 +9,9 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-21 05:30+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Harald Ersch\n"
|
||||||
"Language-Team: Romanian (Romania) (http://www.transifex.com/rosarior/mayan-edms/language/ro_RO/)\n"
|
"Language-Team: Romanian (Romania) (http://www.transifex.com/rosarior/mayan-edms/language/ro_RO/)\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
@@ -91,7 +91,7 @@ msgstr "Pagina nu a fost gasită"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Ne pare rău, dar pagina solicitată nu a putut fi găsit."
|
msgstr "Ne pare rău, dar pagina solicitată nu a putut fi găsit."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Eroare la server"
|
msgstr "Eroare la server"
|
||||||
|
|
||||||
@@ -156,14 +156,14 @@ msgid ""
|
|||||||
"\n"
|
"\n"
|
||||||
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
" You can also <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">donate directly to the creator and lead developer. %(icon_social_paypal)s</a>\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nPuteți <a class=\"new_window\" href=\"https://www.paypal.com/paypalme2/RobertoRosario\">dona direct creatorului și dezvoltatorului principal. %(icon_social_paypal)s</a>"
|
||||||
|
|
||||||
#: templates/appearance/about.html:127
|
#: templates/appearance/about.html:127
|
||||||
msgid ""
|
msgid ""
|
||||||
"\n"
|
"\n"
|
||||||
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
" Besides donations you can also support the project by <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">purchasing a copy of the book \"Exploring Mayan EDMS\" by Roberto Rosario</a>. <br>The book is available on pre-release format at a discounted price for a limited time.\n"
|
||||||
" "
|
" "
|
||||||
msgstr ""
|
msgstr "\nPe lângă donații, puteți susține și proiectul <a class=\"new_window\" href=\"https://sellfy.com/p/um2fkx/\">achiziționând o copie a cărții „Exploring Mayan EDMS” de Roberto Rosario</a> . <br> Cartea este disponibilă în format pre-lansare la un preț redus pentru o perioadă limitată de timp.\n "
|
||||||
|
|
||||||
#: templates/appearance/about.html:133
|
#: templates/appearance/about.html:133
|
||||||
#, python-format
|
#, python-format
|
||||||
@@ -294,15 +294,15 @@ msgstr "Comutare navigare"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Fără rezultate"
|
msgstr "Fără rezultate"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Închide"
|
msgstr "Închide"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Eroare de comunicare cu server-ul"
|
msgstr "Eroare de comunicare cu server-ul"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Verificați conexiunea la rețea și încercați din nou în câteva momente."
|
msgstr "Verificați conexiunea la rețea și încercați din nou în câteva momente."
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Russian (http://www.transifex.com/rosarior/mayan-edms/language/ru/)\n"
|
"Language-Team: Russian (http://www.transifex.com/rosarior/mayan-edms/language/ru/)\n"
|
||||||
@@ -91,7 +91,7 @@ msgstr "Страница не найдена"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Извините, но запрашиваемая страница не найдена."
|
msgstr "Извините, но запрашиваемая страница не найдена."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Ошибка сервера"
|
msgstr "Ошибка сервера"
|
||||||
|
|
||||||
@@ -294,15 +294,15 @@ msgstr "Переключение навигации"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Нет результатов"
|
msgstr "Нет результатов"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Закрыть"
|
msgstr "Закрыть"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "Ошибка соединения с сервером"
|
msgstr "Ошибка соединения с сервером"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "Проверьте ваше соединение с сетью и попробуйте еще раз через некоторое время."
|
msgstr "Проверьте ваше соединение с сетью и попробуйте еще раз через некоторое время."
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Slovenian (Slovenia) (http://www.transifex.com/rosarior/mayan-edms/language/sl_SI/)\n"
|
"Language-Team: Slovenian (Slovenia) (http://www.transifex.com/rosarior/mayan-edms/language/sl_SI/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "Stran ni najdena"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Žal, toda zahtevane strani ni bilo mogoče najti."
|
msgstr "Žal, toda zahtevane strani ni bilo mogoče najti."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Napaka strežnika"
|
msgstr "Napaka strežnika"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr "Preklopi navigacijo"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Ni rezultatov"
|
msgstr "Ni rezultatov"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Turkish (Turkey) (http://www.transifex.com/rosarior/mayan-edms/language/tr_TR/)\n"
|
"Language-Team: Turkish (Turkey) (http://www.transifex.com/rosarior/mayan-edms/language/tr_TR/)\n"
|
||||||
@@ -91,7 +91,7 @@ msgstr "sayfa bulunamadı"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "Üzgünüz, ancak istenen sayfa bulunamadı."
|
msgstr "Üzgünüz, ancak istenen sayfa bulunamadı."
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "Server hatası"
|
msgstr "Server hatası"
|
||||||
|
|
||||||
@@ -294,15 +294,15 @@ msgstr "Gezinmeyi aç / kapat"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "Sonuç yok"
|
msgstr "Sonuç yok"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Vietnamese (Viet Nam) (http://www.transifex.com/rosarior/mayan-edms/language/vi_VN/)\n"
|
"Language-Team: Vietnamese (Viet Nam) (http://www.transifex.com/rosarior/mayan-edms/language/vi_VN/)\n"
|
||||||
@@ -89,7 +89,7 @@ msgstr "Không tìm thấy trang"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
@@ -292,15 +292,15 @@ msgstr ""
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Mayan EDMS\n"
|
"Project-Id-Version: Mayan EDMS\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2019-09-03 23:14-0400\n"
|
"POT-Creation-Date: 2019-09-24 23:06-0400\n"
|
||||||
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
"PO-Revision-Date: 2019-09-04 03:25+0000\n"
|
||||||
"Last-Translator: Roberto Rosario\n"
|
"Last-Translator: Roberto Rosario\n"
|
||||||
"Language-Team: Chinese (http://www.transifex.com/rosarior/mayan-edms/language/zh/)\n"
|
"Language-Team: Chinese (http://www.transifex.com/rosarior/mayan-edms/language/zh/)\n"
|
||||||
@@ -90,7 +90,7 @@ msgstr "页面未找到"
|
|||||||
msgid "Sorry, but the requested page could not be found."
|
msgid "Sorry, but the requested page could not be found."
|
||||||
msgstr "抱歉,找不到请求的页面。"
|
msgstr "抱歉,找不到请求的页面。"
|
||||||
|
|
||||||
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:53
|
#: templates/500.html:5 templates/500.html:9 templates/appearance/root.html:52
|
||||||
msgid "Server error"
|
msgid "Server error"
|
||||||
msgstr "服务器错误"
|
msgstr "服务器错误"
|
||||||
|
|
||||||
@@ -293,15 +293,15 @@ msgstr "切换导航"
|
|||||||
msgid "No results"
|
msgid "No results"
|
||||||
msgstr "没有结果"
|
msgstr "没有结果"
|
||||||
|
|
||||||
#: templates/appearance/root.html:58
|
#: templates/appearance/root.html:57
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "关闭"
|
msgstr "关闭"
|
||||||
|
|
||||||
#: templates/appearance/root.html:66
|
#: templates/appearance/root.html:65
|
||||||
msgid "Server communication error"
|
msgid "Server communication error"
|
||||||
msgstr "服务器通信错误"
|
msgstr "服务器通信错误"
|
||||||
|
|
||||||
#: templates/appearance/root.html:68
|
#: templates/appearance/root.html:67
|
||||||
msgid "Check you network connection and try again in a few moments."
|
msgid "Check you network connection and try again in a few moments."
|
||||||
msgstr "检查网络连接,并稍后再试。"
|
msgstr "检查网络连接,并稍后再试。"
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
|
|
||||||
from mayan.apps.smart_settings.classes import Namespace
|
from mayan.apps.smart_settings.classes import Namespace
|
||||||
|
|
||||||
from .literals import DEFAULT_MAXIMUM_TITLE_LENGTH
|
from .literals import DEFAULT_MAXIMUM_TITLE_LENGTH, DEFAULT_MESSAGE_POSITION
|
||||||
|
|
||||||
namespace = Namespace(label=_('Appearance'), name='appearance')
|
namespace = Namespace(label=_('Appearance'), name='appearance')
|
||||||
|
|
||||||
@@ -15,3 +15,11 @@ setting_max_title_length = namespace.add_setting(
|
|||||||
'title.'
|
'title.'
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
setting_message_position = namespace.add_setting(
|
||||||
|
default=DEFAULT_MESSAGE_POSITION,
|
||||||
|
global_name='APPEARANCE_MESSAGE_POSITION', help_text=_(
|
||||||
|
'Position where the system message will be displayed. Options are: '
|
||||||
|
'top-left, top-center, top-right, bottom-left, bottom-center, '
|
||||||
|
'bottom-right.'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
padding-top: 70px;
|
padding-top: 60px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar-brand {
|
.navbar-brand {
|
||||||
@@ -70,7 +70,8 @@ img.lazy-load-carousel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.label-tag {
|
.label-tag {
|
||||||
text-shadow: 0px 0px 2px #000
|
text-shadow: 0px 0px 2px #000;
|
||||||
|
box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.5);
|
||||||
}
|
}
|
||||||
|
|
||||||
.fancybox-nav span {
|
.fancybox-nav span {
|
||||||
@@ -88,19 +89,17 @@ hr {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.btn-block {
|
.btn-block {
|
||||||
|
border-top: 2px solid rgba(255, 255, 255, 0.7);
|
||||||
|
border-left: 2px solid rgba(255, 255, 255, 0.7);
|
||||||
|
border-right: 2px solid rgba(0, 0, 0, 0.7);
|
||||||
|
border-bottom: 2px solid rgba(0, 0, 0, 0.7);
|
||||||
|
box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5);
|
||||||
margin-bottom: 15px;
|
margin-bottom: 15px;
|
||||||
white-space: normal;
|
|
||||||
min-height: 120px;
|
min-height: 120px;
|
||||||
padding-top: 20px;
|
|
||||||
padding-bottom: 1px;
|
padding-bottom: 1px;
|
||||||
}
|
padding-top: 20px;
|
||||||
|
text-shadow: 1px 1px 3px rgba(0, 0, 0, 1);
|
||||||
.btn-block .fa {
|
white-space: normal;
|
||||||
text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.3);
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-block {
|
|
||||||
text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.3);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.radio ul li {
|
.radio ul li {
|
||||||
@@ -112,14 +111,10 @@ a i {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.dashboard-widget {
|
.dashboard-widget {
|
||||||
box-shadow: 1px 1px 1px rgba(0,0,0,0.3);
|
box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.7);
|
||||||
border: 1px solid black;
|
border: 1px solid black;
|
||||||
}
|
}
|
||||||
|
|
||||||
.dashboard-widget .panel-heading i {
|
|
||||||
text-shadow: 1px 1px 1px rgba(0,0,0,0.3);
|
|
||||||
}
|
|
||||||
|
|
||||||
.dashboard-widget-icon {
|
.dashboard-widget-icon {
|
||||||
font-size: 200%;
|
font-size: 200%;
|
||||||
}
|
}
|
||||||
@@ -170,7 +165,7 @@ a i {
|
|||||||
}
|
}
|
||||||
.navbar-collapse {
|
.navbar-collapse {
|
||||||
border-top: 1px solid transparent;
|
border-top: 1px solid transparent;
|
||||||
box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
|
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
|
||||||
}
|
}
|
||||||
.navbar-fixed-top {
|
.navbar-fixed-top {
|
||||||
top: 0;
|
top: 0;
|
||||||
@@ -213,6 +208,22 @@ a i {
|
|||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.source-column-label {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-highlighted {
|
||||||
|
box-shadow: 0px 0px 3px #18bc9c, 10px 10px 20px #000000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-highlighted:hover {
|
||||||
|
box-shadow: 0px 0px 3px #18bc9c, 10px 10px 20px #000000, 0px 0px 8px #000000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-item:not(.panel-highlighted):hover {
|
||||||
|
box-shadow: 0px 0px 8px #000000;
|
||||||
|
}
|
||||||
|
|
||||||
/* Content */
|
/* Content */
|
||||||
@media (min-width:1200px) {
|
@media (min-width:1200px) {
|
||||||
.container-fluid {
|
.container-fluid {
|
||||||
@@ -242,14 +253,6 @@ a i {
|
|||||||
margin: auto;
|
margin: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.thin_border {
|
|
||||||
border: 1px solid black;
|
|
||||||
display: block;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.thin_border-thumbnail {
|
.thin_border-thumbnail {
|
||||||
display: block;
|
display: block;
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
@@ -259,10 +262,18 @@ a i {
|
|||||||
margin: auto;
|
margin: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Must go after .thin_border-thumbnail */
|
||||||
|
.thin_border {
|
||||||
|
border: 1px solid black;
|
||||||
|
display: inline;
|
||||||
|
margin-left: 0px;
|
||||||
|
margin-right: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
#ajax-spinner {
|
#ajax-spinner {
|
||||||
position: fixed;
|
position: fixed;
|
||||||
top: 12px;
|
top: 16px;
|
||||||
right: 10px;
|
left: 10px;
|
||||||
z-index: 9999;
|
z-index: 9999;
|
||||||
width: 25px;
|
width: 25px;
|
||||||
height: 25px;
|
height: 25px;
|
||||||
@@ -328,7 +339,7 @@ a i {
|
|||||||
.main {
|
.main {
|
||||||
padding-right: 0px;
|
padding-right: 0px;
|
||||||
padding-left: 0px;
|
padding-left: 0px;
|
||||||
/*margin-left: 210px;*/
|
margin-left: 210px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -410,3 +421,147 @@ a i {
|
|||||||
.btn-list {
|
.btn-list {
|
||||||
margin-bottom: 2px;
|
margin-bottom: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Top navigation
|
||||||
|
* Hide default border to remove 1px line.
|
||||||
|
*/
|
||||||
|
.navbar-fixed-top {
|
||||||
|
border: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* menu_main */
|
||||||
|
/* Hide for mobile, show later */
|
||||||
|
|
||||||
|
#menu-main {
|
||||||
|
display: none;
|
||||||
|
background-color: #2c3e50;
|
||||||
|
border-right: 1px solid #18bc9c;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
overflow-x: hidden;
|
||||||
|
overflow-y: auto;
|
||||||
|
padding-top: 10px;
|
||||||
|
position: fixed;
|
||||||
|
top: 51px;
|
||||||
|
width: 210px;
|
||||||
|
z-index: 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
#menu-main {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-brand {
|
||||||
|
text-align: center;
|
||||||
|
width: 210px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.main .page-header {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-brand {
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-brand {
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container-fluid {
|
||||||
|
margin-right: 0px;
|
||||||
|
margin-left: 0px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar a {
|
||||||
|
padding: 10px 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar a[aria-expanded="true"] {
|
||||||
|
background: #1a242f;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel {
|
||||||
|
border: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar a {
|
||||||
|
text-decoration: none;
|
||||||
|
outline: none;
|
||||||
|
position: relative;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-heading {
|
||||||
|
background-color: #2c3e50;
|
||||||
|
color: white;
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-heading:hover {
|
||||||
|
background-color: #517394;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar > .panel > div > .panel-body > ul > li > a:hover {
|
||||||
|
background-color: #517394;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar > .panel > div > .panel-body > ul > li.active {
|
||||||
|
background: #1a242f;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-title {
|
||||||
|
font-size: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-body {
|
||||||
|
font-size: 13px;
|
||||||
|
border: 0px;
|
||||||
|
background-color: #2c3e50;
|
||||||
|
padding-top: 5px;
|
||||||
|
padding-left: 20px;
|
||||||
|
padding-right: 0px;
|
||||||
|
padding-bottom: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-body li {
|
||||||
|
padding: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#accordion-sidebar .panel-body a {
|
||||||
|
color: white;
|
||||||
|
text-decoration: none;
|
||||||
|
padding: 9px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-fixed-top {
|
||||||
|
box-shadow: 0px 3px 3px rgba(0, 0, 0, 0.4);
|
||||||
|
}
|
||||||
|
|
||||||
|
.toolbar {
|
||||||
|
border: 1px solid rgba(0, 0, 0, 0.1);
|
||||||
|
box-shadow: 1px 1px 2px rgba(0, 0, 0, .3);
|
||||||
|
margin-bottom: 10px;
|
||||||
|
padding-bottom: 8px;
|
||||||
|
padding-left: 12px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-top: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#body-plain {
|
||||||
|
padding-top: 0px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* jstree - cabinets */
|
||||||
|
#jstree {
|
||||||
|
max-width: 100%;
|
||||||
|
overflow: auto;
|
||||||
|
font: 11px Verdana, sans-serif;
|
||||||
|
padding: 0px;
|
||||||
|
padding-bottom: 10px; /* Padding for scrollbar */
|
||||||
|
}
|
||||||
|
|||||||
@@ -6,7 +6,8 @@ var MayanAppClass = MayanApp;
|
|||||||
|
|
||||||
var partialNavigation = new PartialNavigation({
|
var partialNavigation = new PartialNavigation({
|
||||||
initialURL: initialURL,
|
initialURL: initialURL,
|
||||||
disabledAnchorClasses: ['disabled'],
|
disabledAnchorClasses: [
|
||||||
|
'btn-multi-item-action', 'disabled', 'pagination-disabled'
|
||||||
|
],
|
||||||
excludeAnchorClasses: ['fancybox', 'new_window', 'non-ajax'],
|
excludeAnchorClasses: ['fancybox', 'new_window', 'non-ajax'],
|
||||||
formBeforeSerializeCallbacks: [MayanApp.MultiObjectFormProcess],
|
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ class MayanApp {
|
|||||||
constructor (options) {
|
constructor (options) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
options = options || {
|
this.options = options || {
|
||||||
ajaxMenusOptions: []
|
ajaxMenusOptions: []
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -17,28 +17,44 @@ class MayanApp {
|
|||||||
|
|
||||||
// Class methods and variables
|
// Class methods and variables
|
||||||
|
|
||||||
static MultiObjectFormProcess ($form, options) {
|
static countChecked() {
|
||||||
/*
|
var checkCount = $('.check-all-slave:checked').length;
|
||||||
* ajaxForm callback to add the external item checkboxes to the
|
|
||||||
* submitted form
|
|
||||||
*/
|
|
||||||
|
|
||||||
if ($form.hasClass('form-multi-object-action')) {
|
if (checkCount) {
|
||||||
// Turn form data into an object
|
$('#multi-item-title').hide();
|
||||||
var formArray = $form.serializeArray().reduce(function (obj, item) {
|
$('#multi-item-actions').show();
|
||||||
obj[item.name] = item.value;
|
} else {
|
||||||
return obj;
|
$('#multi-item-title').show();
|
||||||
}, {});
|
$('#multi-item-actions').hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Add all checked checkboxes to the form data
|
static setupMultiItemActions () {
|
||||||
$('.form-multi-object-action-checkbox:checked').each(function() {
|
$('body').on('change', '.check-all-slave', function () {
|
||||||
var $this = $(this);
|
MayanApp.countChecked();
|
||||||
formArray[$this.attr('name')] = $this.attr('value');
|
});
|
||||||
|
|
||||||
|
$('body').on('click', '.btn-multi-item-action', function (event) {
|
||||||
|
var id_list = [];
|
||||||
|
$('.check-all-slave:checked').each(function (index, value) {
|
||||||
|
//Split the name (ie:"pk_200") and extract only the ID
|
||||||
|
id_list.push(value.name.split('_')[1]);
|
||||||
|
});
|
||||||
|
event.preventDefault();
|
||||||
|
partialNavigation.setLocation(
|
||||||
|
$(this).attr('href') + '?id_list=' + id_list.join(',')
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
static setupNavBarState () {
|
||||||
|
$('body').on('click', '.a-main-menu-accordion-link', function (event) {
|
||||||
|
$('.a-main-menu-accordion-link').each(function (index, value) {
|
||||||
|
$(this).parent().removeClass('active');
|
||||||
});
|
});
|
||||||
|
|
||||||
// Set the form data as the data to send
|
$(this).parent().addClass('active');
|
||||||
options.data = formArray;
|
});
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static updateNavbarState () {
|
static updateNavbarState () {
|
||||||
@@ -46,8 +62,10 @@ class MayanApp {
|
|||||||
var uriFragment = uri.fragment();
|
var uriFragment = uri.fragment();
|
||||||
$('.a-main-menu-accordion-link').each(function (index, value) {
|
$('.a-main-menu-accordion-link').each(function (index, value) {
|
||||||
if (value.pathname === uriFragment) {
|
if (value.pathname === uriFragment) {
|
||||||
$(this).closest('.collapse').addClass('in').parent().find('.collapsed').removeClass('collapsed').attr('aria-expanded', 'true');
|
var $this = $(this);
|
||||||
$(this).parent().addClass('active');
|
|
||||||
|
$this.closest('.collapse').addClass('in').parent().find('.collapsed').removeClass('collapsed').attr('aria-expanded', 'true');
|
||||||
|
$this.parent().addClass('active');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -92,7 +110,7 @@ class MayanApp {
|
|||||||
'closeButton': true,
|
'closeButton': true,
|
||||||
'debug': false,
|
'debug': false,
|
||||||
'newestOnTop': true,
|
'newestOnTop': true,
|
||||||
'positionClass': 'toast-top-right',
|
'positionClass': 'toast-' + this.options.messagePosition,
|
||||||
'preventDuplicates': false,
|
'preventDuplicates': false,
|
||||||
'onclick': null,
|
'onclick': null,
|
||||||
'showDuration': '300',
|
'showDuration': '300',
|
||||||
@@ -162,17 +180,19 @@ class MayanApp {
|
|||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
this.setupAJAXSpinner();
|
this.setupAJAXSpinner();
|
||||||
this.setupAutoSubmit();
|
|
||||||
this.setupBodyAdjust();
|
this.setupBodyAdjust();
|
||||||
this.setupFormHotkeys();
|
this.setupFormHotkeys();
|
||||||
this.setupFullHeightResizing();
|
this.setupFullHeightResizing();
|
||||||
this.setupItemsSelector();
|
this.setupItemsSelector();
|
||||||
|
MayanApp.setupMultiItemActions();
|
||||||
this.setupNavbarCollapse();
|
this.setupNavbarCollapse();
|
||||||
|
MayanApp.setupNavBarState();
|
||||||
this.setupNewWindowAnchor();
|
this.setupNewWindowAnchor();
|
||||||
$.each(this.ajaxMenusOptions, function(index, value) {
|
$.each(this.ajaxMenusOptions, function(index, value) {
|
||||||
value.app = self;
|
value.app = self;
|
||||||
app.doRefreshAJAXMenu(value);
|
app.doRefreshAJAXMenu(value);
|
||||||
});
|
});
|
||||||
|
this.setupPanelSelection();
|
||||||
partialNavigation.initialize();
|
partialNavigation.initialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -196,14 +216,6 @@ class MayanApp {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
setupAutoSubmit () {
|
|
||||||
$('body').on('change', '.select-auto-submit', function () {
|
|
||||||
if ($(this).val()) {
|
|
||||||
$(this.form).trigger('submit');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
setupBodyAdjust () {
|
setupBodyAdjust () {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
@@ -242,9 +254,22 @@ class MayanApp {
|
|||||||
app.lastChecked = null;
|
app.lastChecked = null;
|
||||||
|
|
||||||
$('body').on('click', '.check-all', function (event) {
|
$('body').on('click', '.check-all', function (event) {
|
||||||
|
var $this = $(this);
|
||||||
var checked = $(event.target).prop('checked');
|
var checked = $(event.target).prop('checked');
|
||||||
var $checkBoxes = $('.check-all-slave');
|
var $checkBoxes = $('.check-all-slave');
|
||||||
|
|
||||||
|
if (checked === undefined) {
|
||||||
|
checked = $this.data('checked');
|
||||||
|
checked = !checked;
|
||||||
|
$this.data('checked', checked);
|
||||||
|
|
||||||
|
if (checked) {
|
||||||
|
$this.find('[data-fa-i2svg]').addClass($this.data('icon-checked')).removeClass($this.data('icon-unchecked'));
|
||||||
|
} else {
|
||||||
|
$this.find('[data-fa-i2svg]').addClass($this.data('icon-unchecked')).removeClass($this.data('icon-checked'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$checkBoxes.prop('checked', checked);
|
$checkBoxes.prop('checked', checked);
|
||||||
$checkBoxes.trigger('change');
|
$checkBoxes.trigger('change');
|
||||||
});
|
});
|
||||||
@@ -290,6 +315,58 @@ class MayanApp {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setupPanelSelection () {
|
||||||
|
var app = this;
|
||||||
|
|
||||||
|
// Setup panel highlighting on check
|
||||||
|
$('body').on('change', '.check-all-slave', function (event) {
|
||||||
|
var checked = $(event.target).prop('checked');
|
||||||
|
if (checked) {
|
||||||
|
$(this).closest('.panel-item').addClass('panel-highlighted');
|
||||||
|
} else {
|
||||||
|
$(this).closest('.panel-item').removeClass('panel-highlighted');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('body').on('click', '.panel-item', function (event) {
|
||||||
|
var $this = $(this);
|
||||||
|
var targetSrc = $(event.target).prop('src');
|
||||||
|
var targetHref = $(event.target).prop('href');
|
||||||
|
var targetIsButton = event.target.tagName === 'BUTTON';
|
||||||
|
var lastChecked = null;
|
||||||
|
|
||||||
|
if ((targetSrc === undefined) && (targetHref === undefined) && (targetIsButton === false)) {
|
||||||
|
var $checkbox = $this.find('.check-all-slave');
|
||||||
|
var checked = $checkbox.prop('checked');
|
||||||
|
|
||||||
|
if (checked) {
|
||||||
|
$checkbox.prop('checked', '');
|
||||||
|
$checkbox.trigger('change');
|
||||||
|
} else {
|
||||||
|
$checkbox.prop('checked', 'checked');
|
||||||
|
$checkbox.trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!app.lastChecked) {
|
||||||
|
app.lastChecked = $checkbox;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (event.shiftKey) {
|
||||||
|
var $checkBoxes = $('.check-all-slave');
|
||||||
|
|
||||||
|
var start = $checkBoxes.index($checkbox);
|
||||||
|
var end = $checkBoxes.index(app.lastChecked);
|
||||||
|
|
||||||
|
$checkBoxes.slice(
|
||||||
|
Math.min(start, end), Math.max(start, end) + 1
|
||||||
|
).prop('checked', app.lastChecked.prop('checked')).trigger('change');
|
||||||
|
}
|
||||||
|
app.lastChecked = $checkbox;
|
||||||
|
window.getSelection().removeAllRanges();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
setupScrollView () {
|
setupScrollView () {
|
||||||
$('.scrollable').scrollview();
|
$('.scrollable').scrollview();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,6 +23,7 @@
|
|||||||
{% block content_plain %}{% endblock %}
|
{% block content_plain %}{% endblock %}
|
||||||
{% else %}
|
{% else %}
|
||||||
<div class="">
|
<div class="">
|
||||||
|
|
||||||
{% navigation_resolve_menus names='facet,list facet' sort_results=True as facet_menus_link_results %}
|
{% navigation_resolve_menus names='facet,list facet' sort_results=True as facet_menus_link_results %}
|
||||||
|
|
||||||
<div class="row zero-margin">
|
<div class="row zero-margin">
|
||||||
@@ -43,7 +44,7 @@
|
|||||||
{% if settings_changed %}
|
{% if settings_changed %}
|
||||||
<div class="alert alert-dismissible alert-warning">
|
<div class="alert alert-dismissible alert-warning">
|
||||||
<button type="button" class="close" data-dismiss="alert">×</button>
|
<button type="button" class="close" data-dismiss="alert">×</button>
|
||||||
<p><strong>{% trans 'Warning' %}</strong> {% trans 'Settings updated, restart your installation for changes to take proper effect.' %}</p>
|
<p><strong>{% trans 'Warning' %}</strong> {% trans 'Settings updated, restart your installation and refresh your browser for changes to take effect.' %}</p>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
@@ -138,6 +139,9 @@
|
|||||||
},
|
},
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
];
|
];
|
||||||
|
$(function () {
|
||||||
|
$('[data-toggle="tooltip"]').tooltip();
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
{% block javascript %}{% endblock %}
|
{% block javascript %}{% endblock %}
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user