Compare commits
236 Commits
ext-jscons
...
propagate/
Author | SHA1 | Date | |
---|---|---|---|
29a71867f2 | |||
1929c94880 | |||
c6c8b06331 | |||
6e862151cc | |||
7590f2d390 | |||
2d91d8bc08 | |||
1bd9da2339 | |||
4afb1f3e20 | |||
f0fe828a44 | |||
0a834c839f | |||
0ab7ab7a49 | |||
575aff046e | |||
18d337ffa0 | |||
|
e86f9b6237 | ||
f90a541ec2 | |||
942bce286d | |||
d75bdbc5c2 | |||
7d3d00edb2 | |||
33035fb718 | |||
ce372ad731 | |||
75476c4d4e | |||
|
d15d9d291c | ||
|
ec79404d1c | ||
|
84feaff8e3 | ||
|
3b7770e16d | ||
|
f52aee275e | ||
|
c2c340f61e | ||
c9d1646933 | |||
|
26adfeee1c | ||
|
68d0eeab49 | ||
|
a50c3da468 | ||
|
f8638e7a26 | ||
|
4d584785ff | ||
|
96987b7ff1 | ||
|
456950f31d | ||
|
6740f23779 | ||
|
880221a953 | ||
|
398d6692f8 | ||
|
b6f2befafb | ||
|
c11990900c | ||
|
e07cea5ffa | ||
|
6e09a9c0c9 | ||
|
29f4ca7c54 | ||
|
73fea3d13d | ||
|
910cc2e2cb | ||
|
99d39fa7f7 | ||
|
1778fd04a4 | ||
|
d616b9ef3a | ||
|
a72d43a6af | ||
|
5a16e389c4 | ||
|
f10722dec9 | ||
|
ec00d1a445 | ||
|
8b7ec4654e | ||
|
f23cda3fd1 | ||
39928d09fc | |||
9859e68fe8 | |||
4dccd7892f | |||
6e0c055222 | |||
192bd41c1a | |||
|
c76e745e2d | ||
|
fd79be4aed | ||
b4be2e251c | |||
dc236b7550 | |||
d87935cd44 | |||
0be038fe07 | |||
25d0633fdb | |||
44b6f26f4f | |||
a388c1d2fb | |||
ca420b43e2 | |||
8be7673ad3 | |||
b124cd027c | |||
af39f367b6 | |||
|
c5f2448cf9 | ||
6471292c34 | |||
7114bb5de1 | |||
5ea48c405f | |||
|
00335f5795 | ||
|
806601c800 | ||
|
e9542dbc96 | ||
|
e222fc3fba | ||
|
eaa6f1025d | ||
3b5fc8c096 | |||
8aa7067286 | |||
77f2c5e0f1 | |||
919d842d61 | |||
|
9dd046ad51 | ||
20b41bbcb1 | |||
89348916a5 | |||
a2619fac7b | |||
3a47c43a88 | |||
16aa444b19 | |||
deb6bf058c | |||
8a0ccc61a5 | |||
695e3b3dc0 | |||
2b7755222b | |||
237a8abd62 | |||
f28c16c4fe | |||
|
75afb1580b | ||
41858ebddb | |||
6aa7c2229d | |||
5788051f22 | |||
b534456065 | |||
f977291894 | |||
cc4ed62159 | |||
e8a8d088f4 | |||
c9075398cd | |||
128a289ac3 | |||
ac7e691100 | |||
15ccb5642b | |||
4349851dd9 | |||
de8920ba0b | |||
4f5a939b71 | |||
22b2583505 | |||
9b3ba22ca1 | |||
69531bde6d | |||
766b2ebfd0 | |||
0999563353 | |||
078b2ae35c | |||
5ff71f0e3c | |||
2878298644 | |||
11bb8c62ed | |||
30f3420ee5 | |||
677a3e1dc8 | |||
76dc8c7ad9 | |||
b024fd8d7e | |||
8a36f91d06 | |||
2ec11a1135 | |||
962817ba63 | |||
a56556b596 | |||
0a0cb15580 | |||
d3b41dcc46 | |||
37de03317b | |||
dc9fb0abfa | |||
68dc071342 | |||
78ec9c2a94 | |||
cafee75cdc | |||
d70efc6943 | |||
9e2ce6b967 | |||
295b0711b0 | |||
e660d79ef1 | |||
f036e13180 | |||
83db2b08dc | |||
40207d43ff | |||
a3cb815dd1 | |||
a0c6074358 | |||
bc6a8539f3 | |||
b3001c56ff | |||
d4f4b6217e | |||
41b87a9e5e | |||
86ad2bc409 | |||
2a56247aa1 | |||
efb9210c5a | |||
48d46aa70c | |||
b47583a716 | |||
fc9c26eac5 | |||
2715b3afea | |||
55b70f1a36 | |||
253b7fd3f2 | |||
9f75b4439d | |||
3ac57ce7d1 | |||
573ab3d2cb | |||
c2795cd76c | |||
17f70ea253 | |||
2173a9eb5b | |||
8e1a7f11ca | |||
ca1eaa8bff | |||
520e211c11 | |||
1635445cba | |||
6ec4a797ca | |||
b1f3b14846 | |||
04f44ef280 | |||
32ad6d8195 | |||
0ed77985f0 | |||
56492a45c8 | |||
ce9b143fb5 | |||
ce899a9480 | |||
701489665a | |||
0976a3975f | |||
22d1220a14 | |||
0ad2cdf9ad | |||
1d0aa0c91e | |||
7a005d16d7 | |||
60b5a8989b | |||
eb11f51348 | |||
7bb62f421e | |||
f02d4ff427 | |||
1e09466e78 | |||
b762ba0ce1 | |||
c22af67a06 | |||
0b507962fa | |||
f73fdbb5ea | |||
1216469feb | |||
6a6dbdc798 | |||
2ac3d013c9 | |||
80a938d674 | |||
ddb535ab14 | |||
8be9a0749a | |||
0bd09b8cbd | |||
a7cacf8edc | |||
43d5686407 | |||
e29e80b650 | |||
331eda62fc | |||
fbf7ca3678 | |||
f239550be7 | |||
3b631bcd87 | |||
e5824d17e1 | |||
5cd3530ef0 | |||
d6f1c99c79 | |||
6d35ffa551 | |||
6c739c5795 | |||
055119eeb5 | |||
75df5099e9 | |||
69974eaeea | |||
82d6fd5c8a | |||
90e935a49e | |||
6e32209824 | |||
0bb3b7bb28 | |||
f97b6b973b | |||
63d1ee7ef9 | |||
a081d5b5c8 | |||
b9fb8971dd | |||
487a677f6f | |||
0608045c1b | |||
8296a96294 | |||
79ef1f5868 | |||
8c480402ed | |||
8a5004ed74 | |||
3fea801d26 | |||
d0a62bfd24 | |||
7cedfa4fa2 | |||
4f036e530b | |||
6858d201c2 | |||
723f3ec954 | |||
dcb88c42ea | |||
89626fcd1d | |||
c1323a8171 |
6
.env
6
.env
@@ -4,8 +4,4 @@ ALFRESCO_LICENSE_DIR=~/alfresco/license
|
||||
PROXY_PROTOCOL=http
|
||||
PROXY_HOST=localhost
|
||||
PROXY_PORT=8080
|
||||
|
||||
ACS_TAG=7.4.1.1
|
||||
AAMQ_TAG=latest
|
||||
POSTGRES_TAG=13
|
||||
ACS_SHARE_TAG=7.4.1.2
|
||||
IDENTITY_SERVICE_BASEURL=http://auth.example.org:8080
|
||||
|
@@ -1,17 +0,0 @@
|
||||
ARG ACS_TAG=inject-it
|
||||
FROM alfresco/alfresco-content-repository-community:${ACS_TAG}
|
||||
|
||||
ARG USERNAME=alfresco
|
||||
ARG TOMCAT_DIR=/usr/local/tomcat
|
||||
|
||||
USER root
|
||||
|
||||
COPY catalina.policy /tmp/catalina.policy.ext
|
||||
COPY tomcat-platform-context.xml ${TOMCAT_DIR}/conf/Catalina/localhost/alfresco.xml
|
||||
COPY *.amp ${TOMCAT_DIR}/amps/
|
||||
|
||||
RUN java -jar ${TOMCAT_DIR}/alfresco-mmt/alfresco-mmt*.jar install ${TOMCAT_DIR}/amps ${TOMCAT_DIR}/webapps/alfresco -nobackup -directory && \
|
||||
mkdir -p ${TOMCAT_DIR}/modules/platform && \
|
||||
cat /tmp/catalina.policy.ext >> ${TOMCAT_DIR}/conf/catalina.policy
|
||||
|
||||
USER ${USERNAME}
|
@@ -1,3 +0,0 @@
|
||||
## Usage
|
||||
|
||||
Download all AMP files needed into this directory. All of them will be copied into a new Docker image and installed into the Alfresco Platform web application.
|
@@ -1,4 +0,0 @@
|
||||
grant codeBase "file:${catalina.base}/modules/-" {
|
||||
permission java.security.AllPermission;
|
||||
};
|
||||
|
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Context>
|
||||
<Resources>
|
||||
<PreResources base="${catalina.base}/modules/platform" className="org.apache.catalina.webresources.DirResourceSet" webAppMount="/WEB-INF/lib" readOnly="true" />
|
||||
</Resources>
|
||||
</Context>
|
@@ -1,3 +0,0 @@
|
||||
## Usage
|
||||
|
||||
Download all JAR module files needed into this directory. All of them will be dynamically loaded into the Docker container and loaded into the Alfresco Platform web application.
|
@@ -1,11 +0,0 @@
|
||||
ARG ACS_SHARE_TAG=inject-it
|
||||
FROM alfresco/alfresco-share:${ACS_SHARE_TAG}
|
||||
|
||||
ARG TOMCAT_DIR=/usr/local/tomcat
|
||||
|
||||
COPY tomcat-share-context.xml ${TOMCAT_DIR}/conf/Catalina/localhost/share.xml
|
||||
COPY *.amp ${TOMCAT_DIR}/amps_share/
|
||||
|
||||
RUN java -jar ${TOMCAT_DIR}/alfresco-mmt/alfresco-mmt*.jar install ${TOMCAT_DIR}/amps_share ${TOMCAT_DIR}/webapps/share -nobackup -directory && \
|
||||
mkdir -p ${TOMCAT_DIR}/modules/share
|
||||
|
@@ -1,3 +0,0 @@
|
||||
## Usage
|
||||
|
||||
Download all AMP files needed into this directory. All of them will be copied into a new Docker image and installed into the Alfresco Share web application.
|
@@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Context>
|
||||
<Resources>
|
||||
<PreResources base="${catalina.base}/modules/share" className="org.apache.catalina.webresources.DirResourceSet" webAppMount="/WEB-INF/lib" readOnly="true" />
|
||||
</Resources>
|
||||
</Context>
|
@@ -1,3 +0,0 @@
|
||||
## Usage
|
||||
|
||||
Download all JAR module files needed into this directory. All of them will be dynamically loaded into the Docker container and loaded into the Alfresco Share web application.
|
@@ -1,48 +1,95 @@
|
||||
# Originally sourced from https://github.com/Alfresco/acs-deployment/blob/4.0.3/docker-compose/docker-compose.yml
|
||||
# Sourced from https://github.com/Alfresco/acs-deployment/blob/4.0.3/docker-compose/docker-compose.yml
|
||||
#
|
||||
version: "3"
|
||||
# Using version 2 as 3 does not support resource constraint options (cpu_*, mem_* limits) for non swarm mode in Compose
|
||||
version: "2"
|
||||
|
||||
services:
|
||||
|
||||
platform:
|
||||
build:
|
||||
context: ./alfresco-content-repository/docker
|
||||
args:
|
||||
ACS_TAG: ${ACS_TAG}
|
||||
image: local/alfresco-content-repository:latest
|
||||
image: quay.io/alfresco/alfresco-governance-repository-enterprise:V3.4-latest
|
||||
mem_limit: 1700m
|
||||
environment:
|
||||
JAVA_TOOL_OPTIONS: "
|
||||
-Dencryption.keystore.type=JCEKS
|
||||
-Dencryption.cipherAlgorithm=DESede/CBC/PKCS5Padding
|
||||
-Dencryption.keyAlgorithm=DESede
|
||||
-Dencryption.keystore.location=/usr/local/tomcat/shared/classes/alfresco/extension/keystore/keystore
|
||||
-Dmetadata-keystore.password=mp6yc0UD9e
|
||||
-Dmetadata-keystore.aliases=metadata
|
||||
-Dmetadata-keystore.metadata.password=oKIWzVdEdA
|
||||
-Dmetadata-keystore.metadata.algorithm=DESede"
|
||||
JAVA_OPTS: "
|
||||
-Ddb.driver=org.postgresql.Driver
|
||||
-Ddb.username=alfresco
|
||||
-Ddb.password=alfresco
|
||||
-Ddb.url=jdbc:postgresql://postgres-acs:5432/alfresco
|
||||
-Dindex.subsystem.name=solr6
|
||||
-Dsolr.host=search
|
||||
-Dsolr.port=8983
|
||||
-Dsolr.secureComms=none
|
||||
-Dshare.host=${PROXY_HOST}
|
||||
-Dshare.port=${PROXY_PORT}
|
||||
-Dshare.protocol=${PROXY_PROTOCOL}
|
||||
-Dalfresco.host=${PROXY_HOST}
|
||||
-Dalfresco.port=${PROXY_PORT}
|
||||
-Dalfresco.protocol=${PROXY_PROTOCOL}
|
||||
-Daos.baseUrlOverwrite=${PROXY_PROTOCOL}://${PROXY_HOST}:${PROXY_PORT}/alfresco/aos
|
||||
-Dmessaging.broker.url=\"failover:(nio://activemq:61616)?timeout=3000&jms.useCompression=true\"
|
||||
-Ddeployment.method=DOCKER_COMPOSE
|
||||
-DlocalTransform.core-aio.url=http://transform-core-aio:8090/
|
||||
-Dalfresco-pdf-renderer.url=http://transform-core-aio:8090/
|
||||
-Djodconverter.url=http://transform-core-aio:8090/
|
||||
-Dimg.url=http://transform-core-aio:8090/
|
||||
-Dtika.url=http://transform-core-aio:8090/
|
||||
-Dtransform.misc.url=http://transform-core-aio:8090/
|
||||
-Dcsrf.filter.enabled=false
|
||||
-XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=80
|
||||
|
||||
-Dtransform.service.enabled=true
|
||||
-Dlocal.transform.service.enabled=false
|
||||
|
||||
-Dtransform.service.url=http://transform-router:8095
|
||||
-Dsfs.url=http://shared-file-store:8099
|
||||
-Dalfresco-pdf-renderer.url=http://transform-engine-aio:8090
|
||||
-Djodconverter.url=http://transform-engine-aio:8090
|
||||
-Dimg.url=http://transform-engine-aio:8090
|
||||
-Dtika.url=http://transform-engine-aio:8090
|
||||
-Dtransform.misc.url=http://transform-engine-aio:8090
|
||||
|
||||
-Ddsync.service.uris=${PROXY_PROTOCOL}://${PROXY_HOST}:${PROXY_PORT}/sync
|
||||
|
||||
-Dauthentication.chain=aims:identity-service,builtin:alfrescoNtlm
|
||||
-Didentity-service.authentication.defaultAdministratorUserNames=admin.1
|
||||
-Didentity-service.auth-server-url=${IDENTITY_SERVICE_BASEURL}/auth
|
||||
|
||||
-Dsystem.content.eagerOrphanCleanup=true
|
||||
-Dsystem.content.orphanProtectDays=0
|
||||
-Djodconverter.enabled=false
|
||||
"
|
||||
depends_on:
|
||||
- postgres-acs
|
||||
- activemq
|
||||
- shared-file-store
|
||||
volumes:
|
||||
- "./alfresco-content-repository/modules:/usr/local/tomcat/modules/platform:ro"
|
||||
- "$ALFRESCO_LICENSE_DIR/acs:/usr/local/tomcat/shared/classes/alfresco/extension/license:ro"
|
||||
|
||||
transform-router:
|
||||
image: quay.io/alfresco/alfresco-transform-router:1.3.1
|
||||
environment:
|
||||
ACTIVEMQ_URL: "nio://activemq:61616"
|
||||
CORE_AIO_URL : "http://transform-core-aio:8090"
|
||||
FILE_STORE_URL: "http://shared-file-store:8099/alfresco/api/-default-/private/sfs/versions/1/file"
|
||||
depends_on:
|
||||
- activemq
|
||||
- shared-file-store
|
||||
|
||||
transform-core-aio:
|
||||
image: alfresco/alfresco-transform-core-aio:2.3.6
|
||||
environment:
|
||||
ACTIVEMQ_URL: "nio://activemq:61616"
|
||||
FILE_STORE_URL: "http://shared-file-store:8099/alfresco/api/-default-/private/sfs/versions/1/file"
|
||||
depends_on:
|
||||
- activemq
|
||||
- shared-file-store
|
||||
|
||||
shared-file-store:
|
||||
image: alfresco/alfresco-shared-file-store:0.10.0
|
||||
volumes:
|
||||
- shared-file-store-volume:/tmp/Alfresco/sfs
|
||||
|
||||
share:
|
||||
build:
|
||||
context: ./alfresco-share/docker
|
||||
args:
|
||||
ACS_SHARE_TAG: ${ACS_SHARE_TAG}
|
||||
image: local/alfresco-share:latest
|
||||
image: quay.io/alfresco/alfresco-governance-share-enterprise:V3.4-latest
|
||||
mem_limit: 512m
|
||||
environment:
|
||||
REPO_HOST: "platform"
|
||||
CSRF_FILTER_REFERER: "${PROXY_PROTOCOL}://${PROXY_HOST}(:${PROXY_PORT})?/?.*"
|
||||
@@ -54,21 +101,177 @@ services:
|
||||
-Dalfresco.host=${PROXY_HOST}
|
||||
-Dalfresco.port=${PROXY_PORT}
|
||||
-Dalfresco.protocol=${PROXY_PROTOCOL}
|
||||
-Daims.enabled=true
|
||||
-Daims.realm=alfresco
|
||||
-Daims.resource=acs-share
|
||||
-Daims.authServerUrl=${IDENTITY_SERVICE_BASEURL}/auth
|
||||
-Daims.sslRequired=none
|
||||
-Daims.publicClient=true
|
||||
-Daims.autodetectBearerOnly=true
|
||||
-Daims.alwaysRefreshToken=true
|
||||
-Daims.principalAttribute=preferred_username
|
||||
-Daims.enableBasicAuth=true
|
||||
"
|
||||
volumes:
|
||||
- "./alfresco-share/modules:/usr/local/tomcat/modules/share:ro"
|
||||
|
||||
postgres-acs:
|
||||
image: postgres:${POSTGRES_TAG}
|
||||
image: postgres:11.7
|
||||
mem_limit: 512m
|
||||
environment:
|
||||
- POSTGRES_PASSWORD=alfresco
|
||||
- POSTGRES_USER=alfresco
|
||||
- POSTGRES_DB=alfresco
|
||||
command: postgres -c max_connections=300 -c log_min_messages=LOG
|
||||
|
||||
search:
|
||||
image: alfresco/alfresco-search-services:2.0.1
|
||||
mem_limit: 2g
|
||||
environment:
|
||||
- SOLR_ALFRESCO_HOST=platform
|
||||
- SOLR_ALFRESCO_PORT=8080
|
||||
- SOLR_SOLR_HOST=search
|
||||
- SOLR_SOLR_PORT=8983
|
||||
- SOLR_CREATE_ALFRESCO_DEFAULTS=alfresco,archive
|
||||
- ALFRESCO_SECURE_COMMS=none
|
||||
|
||||
activemq:
|
||||
image: alfresco/alfresco-activemq:${AAMQ_TAG}
|
||||
image: alfresco/alfresco-activemq:5.15.8
|
||||
mem_limit: 256m
|
||||
|
||||
sync:
|
||||
image: quay.io/alfresco/service-sync:3.3.3.1
|
||||
mem_limit: 512m
|
||||
environment:
|
||||
JAVA_OPTS : "
|
||||
-Dsql.db.driver=org.postgresql.Driver
|
||||
-Dsql.db.url=jdbc:postgresql://postgres-acs:5432/alfresco
|
||||
-Dsql.db.username=alfresco
|
||||
-Dsql.db.password=alfresco
|
||||
-Dmessaging.broker.host=activemq
|
||||
-Drepo.hostname=platform
|
||||
-Drepo.port=8080
|
||||
-Ddw.server.applicationConnectors[0].type=http
|
||||
-XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=80
|
||||
-Didentity-service.auth-server-url=${IDENTITY_SERVICE_BASEURL}/auth
|
||||
-Didentity-service.resource=acs-sync
|
||||
"
|
||||
depends_on:
|
||||
- postgres-acs
|
||||
- activemq
|
||||
|
||||
digital-workspace:
|
||||
image: quay.io/alfresco/alfresco-digital-workspace:2.0.0-adw
|
||||
mem_limit: 128m
|
||||
environment:
|
||||
BASE_PATH: ./
|
||||
APP_CONFIG_ECM_HOST: "${PROXY_PROTOCOL}://${PROXY_HOST}:${PROXY_PORT}"
|
||||
APP_BASE_SHARE_URL: "${PROXY_PROTOCOL}://${PROXY_HOST}:${PROXY_PORT}/#/preview/s"
|
||||
APP_CONFIG_AUTH_TYPE: OAUTH
|
||||
APP_CONFIG_OAUTH2_HOST: "${IDENTITY_SERVICE_BASEURL}/auth/realms/alfresco"
|
||||
APP_CONFIG_OAUTH2_CLIENTID: alfresco
|
||||
APP_CONFIG_OAUTH2_IMPLICIT_FLOW: "true"
|
||||
APP_CONFIG_OAUTH2_REDIRECT_LOGIN: "/workspace/"
|
||||
APP_CONFIG_OAUTH2_REDIRECT_LOGOUT: "/workspace/logout"
|
||||
|
||||
activiti-app:
|
||||
image: alfresco/process-services:1.11.1.1
|
||||
mem_limit: 512m
|
||||
environment:
|
||||
ACTIVITI_DATASOURCE_USERNAME: alfresco
|
||||
ACTIVITI_DATASOURCE_PASSWORD: alfresco
|
||||
ACTIVITI_DATASOURCE_DRIVER: org.postgresql.Driver
|
||||
ACTIVITI_HIBERNATE_DIALECT: org.hibernate.dialect.PostgreSQLDialect
|
||||
ACTIVITI_DATASOURCE_URL: 'jdbc:postgresql://postgres-aps:5432/activiti?characterEncoding=UTF-8'
|
||||
ACTIVITI_ES_SERVER_TYPE: rest
|
||||
ACTIVITI_ES_REST_CLIENT_ADDRESS: search-aps
|
||||
ACTIVITI_ES_REST_CLIENT_PORT: 9200
|
||||
ACTIVITI_ES_REST_CLIENT_SCHEMA: http
|
||||
IDENTITY_SERVICE_ENABLED: "true"
|
||||
IDENTITY_SERVICE_AUTH: $IDENTITY_SERVICE_BASEURL/auth
|
||||
JAVA_OPTS: "-XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=80"
|
||||
depends_on:
|
||||
- postgres-aps
|
||||
volumes:
|
||||
- "$ALFRESCO_LICENSE_DIR/aps:/root/.activiti/enterprise-license:ro"
|
||||
|
||||
activiti-admin:
|
||||
image: alfresco/process-services-admin:1.11.1.1
|
||||
mem_limit: 256m
|
||||
environment:
|
||||
ACTIVITI_ADMIN_DATASOURCE_USERNAME: alfresco
|
||||
ACTIVITI_ADMIN_DATASOURCE_PASSWORD: alfresco
|
||||
ACTIVITI_ADMIN_DATASOURCE_DRIVER: org.postgresql.Driver
|
||||
ACTIVITI_ADMIN_HIBERNATE_DIALECT: org.hibernate.dialect.PostgreSQLDialect
|
||||
ACTIVITI_ADMIN_DATASOURCE_URL: 'jdbc:postgresql://postgres-aps-admin:5432/activiti-admin?characterEncoding=UTF-8'
|
||||
ACTIVITI_ADMIN_REST_APP_HOST: http://activiti-app
|
||||
ACTIVITI_ADMIN_REST_APP_PORT: 8080
|
||||
JAVA_OPTS: "-XX:MinRAMPercentage=50 -XX:MaxRAMPercentage=80"
|
||||
depends_on:
|
||||
- postgres-aps-admin
|
||||
- activiti-app
|
||||
|
||||
postgres-aps:
|
||||
image: postgres:11.6
|
||||
mem_limit: 256m
|
||||
environment:
|
||||
POSTGRES_DB: activiti
|
||||
POSTGRES_USER: alfresco
|
||||
POSTGRES_PASSWORD: alfresco
|
||||
command: postgres -c max_connections=300 -c log_min_messages=LOG
|
||||
|
||||
postgres-aps-admin:
|
||||
image: postgres:11.6
|
||||
mem_limit: 128m
|
||||
environment:
|
||||
POSTGRES_DB: activiti-admin
|
||||
POSTGRES_USER: alfresco
|
||||
POSTGRES_PASSWORD: alfresco
|
||||
command: postgres -c max_connections=50 -c log_min_messages=LOG
|
||||
|
||||
search-aps:
|
||||
image: elasticsearch:7.6.0
|
||||
mem_limit: 512m
|
||||
environment:
|
||||
discovery.type: single-node
|
||||
ES_JAVA_OPTS: "-Xms128m -Xmx256m"
|
||||
ulimits:
|
||||
memlock:
|
||||
soft: -1
|
||||
hard: -1
|
||||
depends_on:
|
||||
- activiti-app
|
||||
|
||||
identity:
|
||||
image: alfresco/alfresco-identity-service:1.3
|
||||
user: jboss
|
||||
environment:
|
||||
KEYCLOAK_USER: admin
|
||||
KEYCLOAK_PASSWORD: admin
|
||||
KEYCLOAK_HOSTNAME: auth.example.org
|
||||
KEYCLOAK_IMPORT: /tmp/keycloak-alfresco-realm.json
|
||||
KEYCLOAK_STATISTICS: enabled
|
||||
networks:
|
||||
default:
|
||||
aliases:
|
||||
- "auth.example.org"
|
||||
volumes:
|
||||
- ./keycloak-alfresco-realm.json:/tmp/keycloak-alfresco-realm.json:ro
|
||||
|
||||
proxy:
|
||||
build: ./nginx-ingress
|
||||
image: local/nginx-ingress:acs-share
|
||||
image: local/nginx-ingress:acs-sync-share-adw-aps-aims
|
||||
ports:
|
||||
- 8080:8080
|
||||
depends_on:
|
||||
- platform
|
||||
- sync
|
||||
- share
|
||||
- digital-workspace
|
||||
- activiti-app
|
||||
- activiti-admin
|
||||
- identity
|
||||
|
||||
volumes:
|
||||
shared-file-store-volume:
|
||||
driver_opts:
|
||||
type: tmpfs
|
||||
device: tmpfs
|
||||
|
@@ -1,16 +0,0 @@
|
||||
# Usage: .\download-jsconsole.ps1
|
||||
$THISDIR=$PSScriptRoot
|
||||
|
||||
$GITHUB_TAG="v0.6.0-rc1"
|
||||
$MAVEN_VERSION="0.6.0"
|
||||
$BASEURL="https://github.com/share-extras/js-console/releases/download"
|
||||
|
||||
$FILENAME="javascript-console-repo-${MAVEN_VERSION}.amp"
|
||||
$URL="${BASEURL}/${GITHUB_TAG}/${FILENAME}"
|
||||
$PATH="${THISDIR}/alfresco-content-repository/docker/${FILENAME}"
|
||||
Invoke-Expression "& '${THISDIR}\scripts\download-url.ps1' '${URL}' '${PATH}'"
|
||||
|
||||
$FILENAME="javascript-console-share-${MAVEN_VERSION}.amp"
|
||||
$URL="${BASEURL}/${GITHUB_TAG}/${FILENAME}"
|
||||
$PATH="${THISDIR}/alfresco-share/docker/${FILENAME}"
|
||||
Invoke-Expression "& '${THISDIR}\scripts\download-url.ps1' '${URL}' '${PATH}'"
|
@@ -1,17 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-jsconsole.sh
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
GITHUB_TAG=v0.6.0-rc1
|
||||
MAVEN_VERSION=0.6.0
|
||||
BASEURL=https://github.com/share-extras/js-console/releases/download
|
||||
|
||||
FILENAME=javascript-console-repo-${MAVEN_VERSION}.amp
|
||||
URL=${BASEURL}/${GITHUB_TAG}/${FILENAME}
|
||||
PATH=${THISDIR}/alfresco-content-repository/docker/${FILENAME}
|
||||
${THISDIR}/scripts/download-url.sh "${URL}" "${PATH}"
|
||||
|
||||
FILENAME=javascript-console-share-${MAVEN_VERSION}.amp
|
||||
URL=${BASEURL}/${GITHUB_TAG}/${FILENAME}
|
||||
PATH=${THISDIR}/alfresco-share/docker/${FILENAME}
|
||||
${THISDIR}/scripts/download-url.sh "${URL}" "${PATH}"
|
80
keycloak-alfresco-realm.json
Normal file
80
keycloak-alfresco-realm.json
Normal file
@@ -0,0 +1,80 @@
|
||||
{
|
||||
"realm": "alfresco",
|
||||
"enabled": true,
|
||||
"sslRequired": "external",
|
||||
"registrationAllowed": false,
|
||||
"roles": {
|
||||
"realm": [ {
|
||||
"name": "user",
|
||||
"description": "User privileges"
|
||||
}, {
|
||||
"name": "admin",
|
||||
"description": "Administrator privileges"
|
||||
} ]
|
||||
},
|
||||
"clients": [
|
||||
{
|
||||
"clientId": "alfresco",
|
||||
"name": "Alfresco Products",
|
||||
"enabled": true,
|
||||
"alwaysDisplayInConsole": false,
|
||||
"redirectUris": [ "*" ],
|
||||
"standardFlowEnabled": true,
|
||||
"implicitFlowEnabled": true,
|
||||
"directAccessGrantsEnabled": false,
|
||||
"publicClient": true,
|
||||
"protocol": "openid-connect",
|
||||
"attributes": {
|
||||
"login_theme": "alfresco"
|
||||
}
|
||||
},
|
||||
{
|
||||
"clientId": "acs-share",
|
||||
"name": "ACS Share",
|
||||
"enabled": true,
|
||||
"alwaysDisplayInConsole": false,
|
||||
"redirectUris": [ "*" ],
|
||||
"standardFlowEnabled": true,
|
||||
"implicitFlowEnabled": false,
|
||||
"directAccessGrantsEnabled": false,
|
||||
"publicClient": true,
|
||||
"protocol": "openid-connect",
|
||||
"attributes": {
|
||||
"login_theme": "alfresco"
|
||||
}
|
||||
},
|
||||
{
|
||||
"clientId": "acs-sync",
|
||||
"name": "Alfresco Sync Service Clients",
|
||||
"enabled": true,
|
||||
"alwaysDisplayInConsole": false,
|
||||
"redirectUris": [
|
||||
"http://127.0.0.1*",
|
||||
"http://localhost*"
|
||||
],
|
||||
"standardFlowEnabled": true,
|
||||
"implicitFlowEnabled": false,
|
||||
"directAccessGrantsEnabled": false,
|
||||
"publicClient": true,
|
||||
"protocol": "openid-connect",
|
||||
"attributes": {
|
||||
"login_theme": "alfresco"
|
||||
}
|
||||
}
|
||||
],
|
||||
"requiredCredentials": [ "password" ],
|
||||
"users": [
|
||||
{
|
||||
"username": "admin",
|
||||
"email": "admin@app.activiti.com",
|
||||
"enabled": true,
|
||||
"credentials" : [
|
||||
{
|
||||
"type" : "password",
|
||||
"value" : "admin"
|
||||
}
|
||||
],
|
||||
"realmRoles": [ "user", "admin" ]
|
||||
}
|
||||
]
|
||||
}
|
@@ -4,10 +4,30 @@ if [[ $ACS_PLATFORM_URL ]]; then
|
||||
sed -i s%http:\/\/platform:8080%"$ACS_PLATFORM_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $ACS_SYNC_URL ]]; then
|
||||
sed -i s%http:\/\/sync:9090%"$ACS_SYNC_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $ACS_SHARE_URL ]]; then
|
||||
sed -i s%http:\/\/share:8080%"$ACS_SHARE_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $ADW_URL ]]; then
|
||||
sed -i s%http:\/\/digital-workspace:8080%"$ADW_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $APS_APP_URL ]]; then
|
||||
sed -i s%http:\/\/activiti-app:8080%"$APS_APP_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $APS_ADMIN_URL ]]; then
|
||||
sed -i s%http:\/\/activiti-admin:8080%"$APS_ADMIN_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $AIMS_URL ]]; then
|
||||
sed -i s%http:\/\/identity:8080%"$AIMS_URL"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
||||
if [[ $ACCESS_LOG ]]; then
|
||||
sed -i s%\#ENV_ACCESS_LOG%"access_log $ACCESS_LOG;"%g /etc/nginx/nginx.conf
|
||||
fi
|
||||
|
@@ -19,7 +19,10 @@ http {
|
||||
|
||||
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
|
||||
proxy_redirect off;
|
||||
proxy_buffering off;
|
||||
# proxy_buffering off;
|
||||
proxy_buffer_size 64k;
|
||||
proxy_buffers 4 256k;
|
||||
proxy_busy_buffers_size 256k;
|
||||
proxy_set_header Host $http_host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
@@ -48,9 +51,38 @@ http {
|
||||
# If using external proxy / load balancer (for initial redirect if no trailing slash)
|
||||
absolute_redirect off;
|
||||
}
|
||||
|
||||
location /sync/ {
|
||||
proxy_pass http://sync:9090/alfresco/;
|
||||
}
|
||||
|
||||
location /activiti-app/ {
|
||||
proxy_pass http://activiti-app:8080;
|
||||
|
||||
# If using external proxy / load balancer (for initial redirect if no trailing slash)
|
||||
absolute_redirect off;
|
||||
}
|
||||
|
||||
location /activiti-admin/ {
|
||||
proxy_pass http://activiti-admin:8080;
|
||||
|
||||
# If using external proxy / load balancer (for initial redirect if no trailing slash)
|
||||
absolute_redirect off;
|
||||
}
|
||||
|
||||
location /share/ {
|
||||
proxy_pass http://share:8080;
|
||||
}
|
||||
|
||||
location /workspace/ {
|
||||
proxy_pass http://digital-workspace:8080/;
|
||||
|
||||
# If using external proxy / load balancer (for initial redirect if no trailing slash)
|
||||
absolute_redirect off;
|
||||
}
|
||||
|
||||
location /auth/ {
|
||||
proxy_pass http://identity:8080;
|
||||
|
||||
# If using external proxy / load balancer (for initial redirect if no trailing slash)
|
||||
absolute_redirect off;
|
||||
|
@@ -1,8 +0,0 @@
|
||||
REM Usage: .\download-maven-alfresco-private.bat org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
@echo off
|
||||
set THISDIR_REL=%~dp0
|
||||
set THISDIR=%THISDIR_REL:~0,-1%
|
||||
|
||||
set MAVEN_BASEURL=https://artifacts.alfresco.com/nexus/content/groups/private
|
||||
|
||||
call "%THISDIR%\download-maven.bat" %MAVEN_BASEURL% %*
|
@@ -1,6 +0,0 @@
|
||||
# Usage: .\download-maven-alfresco-private.ps1 org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
$THISDIR=$PSScriptRoot
|
||||
|
||||
$MAVEN_BASEURL="https://artifacts.alfresco.com/nexus/content/groups/private"
|
||||
|
||||
Invoke-Expression "& '${THISDIR}\download-maven.ps1' '${MAVEN_BASEURL}' $args"
|
@@ -1,7 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-maven-alfresco-private.sh org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
MAVEN_BASEDIR="https://artifacts.alfresco.com/nexus/content/groups/private"
|
||||
|
||||
${THISDIR}/download-maven.sh "${MAVEN_BASEDIR}" $*
|
@@ -1,8 +0,0 @@
|
||||
REM Usage: .\download-maven-alfresco-public.bat org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
@echo off
|
||||
set THISDIR_REL=%~dp0
|
||||
set THISDIR=%THISDIR_REL:~0,-1%
|
||||
|
||||
set MAVEN_BASEURL=https://artifacts.alfresco.com/nexus/content/groups/public
|
||||
|
||||
call "%THISDIR%\download-maven.bat" %MAVEN_BASEURL% %*
|
@@ -1,6 +0,0 @@
|
||||
# Usage: .\download-maven-alfresco-public.ps1 org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
$THISDIR=$PSScriptRoot
|
||||
|
||||
$MAVEN_BASEURL="https://artifacts.alfresco.com/nexus/content/groups/public"
|
||||
|
||||
Invoke-Expression "& '${THISDIR}\download-maven.ps1' '${MAVEN_BASEURL}' $args"
|
@@ -1,7 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-maven-alfresco-public.sh org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
MAVEN_BASEDIR="https://artifacts.alfresco.com/nexus/content/groups/public"
|
||||
|
||||
${THISDIR}/download-maven.sh "${MAVEN_BASEDIR}" $*
|
@@ -1,7 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-maven-inteligr8-private.sh org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
MAVEN_BASEURL="http://repos.yateslong.us/nexus/repository/inteligr8"
|
||||
|
||||
${THISDIR}/download-maven.sh "${MAVEN_BASEURL}" $*
|
@@ -1,7 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-maven-inteligr8-public.sh org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
MAVEN_BASEURL="http://repos.yateslong.us/nexus/repositories/inteligr8-public"
|
||||
|
||||
${THISDIR}/download-maven.sh "${MAVEN_BASEURL}" $*
|
@@ -1,18 +0,0 @@
|
||||
REM Usage: .\download-maven.bat https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
REM Usage: .\download-maven.bat https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
@echo off
|
||||
set THISDIR_REL=%~dp0
|
||||
set THISDIR=%THISDIR_REL:~0,-1%
|
||||
|
||||
set MAVEN_BASEURL=%1
|
||||
set MAVEN_GROUP_PATH=%2
|
||||
set MAVEN_ARTIFACT_ID=%3
|
||||
set MAVEN_ARTIFACT_VERSION=%4
|
||||
set MAVEN_PACKAGING=%5
|
||||
set HTTP_USERNAME=%6
|
||||
set HTTP_PASSWORD=%7
|
||||
|
||||
set MAVEN_ARTIFACT_FILENAME=%MAVEN_ARTIFACT_ID%-%MAVEN_ARTIFACT_VERSION%.%MAVEN_PACKAGING%
|
||||
set MAVEN_URL=%MAVEN_BASEURL%/%MAVEN_GROUP_PATH%/%MAVEN_ARTIFACT_ID%/%MAVEN_ARTIFACT_VERSION%/%MAVEN_ARTIFACT_FILENAME%
|
||||
|
||||
call "%THISDIR%\download-url.bat" %MAVEN_URL% %MAVEN_ARTIFACT_FILENAME% %HTTP_USERNAME% %HTTP_PASSWORD%
|
@@ -1,16 +0,0 @@
|
||||
# Usage: .\download-maven.ps1 https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
# Usage: .\download-maven.ps1 https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
$THISDIR=$PSScriptRoot
|
||||
|
||||
$MAVEN_BASEURL=$args[0]
|
||||
$MAVEN_GROUP_PATH=$args[1]
|
||||
$MAVEN_ARTIFACT_ID=$args[2]
|
||||
$MAVEN_ARTIFACT_VERSION=$args[3]
|
||||
$MAVEN_PACKAGING=$args[4]
|
||||
$HTTP_USERNAME=$args[5]
|
||||
$HTTP_PASSWORD=$args[6]
|
||||
|
||||
$MAVEN_ARTIFACT_FILENAME="${MAVEN_ARTIFACT_ID}-${MAVEN_ARTIFACT_VERSION}.${MAVEN_PACKAGING}"
|
||||
$MAVEN_URL="${MAVEN_BASEURL}/${MAVEN_GROUP_PATH}/${MAVEN_ARTIFACT_ID}/${MAVEN_ARTIFACT_VERSION}/${MAVEN_ARTIFACT_FILENAME}"
|
||||
|
||||
Invoke-Expression "& '${THISDIR}\download-url.ps1' '${MAVEN_URL}' '${MAVEN_ARTIFACT_FILENAME}' '${HTTP_USERNAME}' '${HTTP_PASSWORD}'"
|
@@ -1,18 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download-maven.sh https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar
|
||||
# Usage: ./download-maven.sh https://repo1.maven.org/maven2 org/maven/group/path maven-artifact-id 1.2.3 jar a_username a_password
|
||||
THISDIR=`dirname "$(readlink -f "$0")"`
|
||||
|
||||
MAVEN_BASEURL=$1
|
||||
MAVEN_GROUP_PATH=$2
|
||||
MAVEN_ARTIFACT_ID=$3
|
||||
MAVEN_ARTIFACT_VERSION=$4
|
||||
MAVEN_PACKAGING=$5
|
||||
HTTP_USERNAME=$6
|
||||
HTTP_PASSWORD=$7
|
||||
|
||||
MAVEN_ARTIFACT_FILENAME=${MAVEN_ARTIFACT_ID}-${MAVEN_ARTIFACT_VERSION}.${MAVEN_PACKAGING}
|
||||
MAVEN_URL=${MAVEN_BASEURL}/${MAVEN_GROUP_PATH}/${MAVEN_ARTIFACT_ID}/${MAVEN_ARTIFACT_VERSION}/${MAVEN_ARTIFACT_FILENAME}
|
||||
echo $MAVEN_URL
|
||||
|
||||
${THISDIR}/download-url.sh "${MAVEN_URL}" "${MAVEN_ARTIFACT_FILENAME}" "${HTTP_USERNAME}" "${HTTP_PASSWORD}"
|
@@ -1,13 +0,0 @@
|
||||
REM Usage: .\download.bat https://www.a.url/to/download filename_for_downloaded.file
|
||||
REM Usage: .\download.bat https://www.a.url/to/download filename_for_downloaded.file a_username a_password
|
||||
@echo off
|
||||
set URL=%1
|
||||
set FILENAME=%2
|
||||
|
||||
if NOT "%~3" == "" (
|
||||
set USERNAME=%3
|
||||
set PASSWORD=%4
|
||||
curl -L -o %FILENAME% -u %USERNAME%:%PASSWORD% %URL%
|
||||
) else (
|
||||
curl -L -o %FILENAME% %URL%
|
||||
)
|
@@ -1,16 +0,0 @@
|
||||
# Usage: .\download.ps1 https://www.a.url/to/download filename_for_downloaded.file
|
||||
# Usage: .\download.ps1 https://www.a.url/to/download filename_for_downloaded.file a_username a_password
|
||||
$URL=$args[0]
|
||||
$FILENAME=$args[1]
|
||||
|
||||
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
||||
if ($args.count -gt 2) {
|
||||
$USERNAME=$args[2]
|
||||
$PASSWORD=$args[3]
|
||||
|
||||
$AUTH_PAIR=[System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes("$($USERNAME):$($PASSWORD)"))
|
||||
$AUTH_HEADERS=@{Authorization="Basic $AUTH_PAIR"}
|
||||
Invoke-WebRequest -Uri "${URL}" -OutFile "${FILENAME}" -Headers ${AUTH_HEADERS}
|
||||
} else {
|
||||
Invoke-WebRequest -Uri "${URL}" -OutFile "${FILENAME}"
|
||||
}
|
@@ -1,13 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./download.sh https://www.a.url/to/download filename_for_downloaded.file
|
||||
# Usage: ./download.sh https://www.a.url/to/download filename_for_downloaded.file a_username a_password
|
||||
URL=$1
|
||||
FILENAME=$2
|
||||
|
||||
if [ "$#" -gt 2 ]; then
|
||||
USERNAME=$3
|
||||
PASSWORD=$4
|
||||
curl -L -o "${FILENAME}" -u "${USERNAME}:${PASSWORD}" ${URL}
|
||||
else
|
||||
curl -L -o "${FILENAME}" ${URL}
|
||||
fi
|
@@ -1,11 +0,0 @@
|
||||
REM Usage: .\unpack.bat filename.zip
|
||||
REM Usage: .\unpack.bat filename.zip c:\
|
||||
@echo off
|
||||
set FILENAME=%1
|
||||
|
||||
if NOT "%~2" == "" (
|
||||
set DESTPATH=%2
|
||||
powershell -command "Expand-Archive -Force -Path '%FILENAME%' -DestinationPath '%DESTPATH%'"
|
||||
) else (
|
||||
powershell -command "Expand-Archive -Force -Path '%FILENAME%' -DestinationPath '%~dp0'"
|
||||
)
|
@@ -1,10 +0,0 @@
|
||||
# Usage: .\unpack.ps1 filename.zip
|
||||
# Usage: .\unpack.ps1 filename.zip c:\
|
||||
$FILENAME=$args[0]
|
||||
|
||||
if ($args.count -gt 1) {
|
||||
$DESTPATH=$args[1]
|
||||
Expand-Archive -Force -Path "${FILENAME}" -DestinationPath "${DESTPATH}"
|
||||
} else {
|
||||
Expand-Archive -Force -Path "${FILENAME}"
|
||||
}
|
@@ -1,11 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Usage: ./unpack.sh filename.zip
|
||||
# Usage: ./unpack.sh filename.zip /home/user
|
||||
FILENAME=$1
|
||||
|
||||
if [ "$#" -gt 1 ]; then
|
||||
DESTPATH=$2
|
||||
unzip -d ${DESTPATH} ${FILENAME}
|
||||
else
|
||||
unzip ${FILENAME}
|
||||
fi
|
Reference in New Issue
Block a user