| 
									
										
										
										
											2025-09-25 02:02:48 +00:00
										 |  |  | FROM node:22.20.0-alpine AS builder
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  | RUN corepack enable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Install native dependencies since we might be building cross-platform.
 | 
					
						
							|  |  |  | WORKDIR /usr/src/app
 | 
					
						
							| 
									
										
										
										
											2025-05-25 21:47:35 +03:00
										 |  |  | COPY ./docker/package.json ./docker/pnpm-workspace.yaml /usr/src/app/
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  | # We have to use --no-frozen-lockfile due to CKEditor patches
 | 
					
						
							|  |  |  | RUN pnpm install --no-frozen-lockfile --prod && pnpm rebuild
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-09-25 02:02:48 +00:00
										 |  |  | FROM node:22.20.0-alpine
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  | # Create a non-root user with configurable UID/GID
 | 
					
						
							|  |  |  | ARG USER=trilium | 
					
						
							|  |  |  | ARG UID=1001 | 
					
						
							|  |  |  | ARG GID=1001 | 
					
						
							|  |  |  | ENV USER=${USER}
 | 
					
						
							|  |  |  | ENV UID=${UID}
 | 
					
						
							|  |  |  | ENV GID=${GID}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Install runtime dependencies and create user with specific UID/GID
 | 
					
						
							|  |  |  | RUN apk add --no-cache dumb-init && \
 | 
					
						
							| 
									
										
										
										
											2025-05-27 20:05:08 +03:00
										 |  |  |     apk add --no-cache bash && \
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  |     # Alpine uses addgroup/adduser (from busybox) instead of groupadd/useradd
 | 
					
						
							|  |  |  |     addgroup -g ${GID} ${USER} && \
 | 
					
						
							|  |  |  |     adduser -u ${UID} -G ${USER} -s /bin/sh -D -h /home/${USER} ${USER}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | WORKDIR /home/${USER}/app
 | 
					
						
							|  |  |  | COPY ./dist /home/${USER}/app
 | 
					
						
							| 
									
										
										
										
											2025-05-22 12:49:38 -07:00
										 |  |  | # Also copy the rootless entrypoint script
 | 
					
						
							|  |  |  | COPY rootless-entrypoint.sh /home/${USER}/app/
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  | RUN rm -rf /home/${USER}/app/node_modules/better-sqlite3
 | 
					
						
							|  |  |  | COPY --from=builder /usr/src/app/node_modules/better-sqlite3 /home/${USER}/app/node_modules/better-sqlite3
 | 
					
						
							|  |  |  | RUN chown -R ${USER}:${USER} /home/${USER}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Configure container
 | 
					
						
							|  |  |  | USER ${USER}
 | 
					
						
							|  |  |  | EXPOSE 8080
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # By default, use UID/GID that was set during build
 | 
					
						
							|  |  |  | # These can be overridden at runtime
 | 
					
						
							|  |  |  | ENV TRILIUM_UID=${UID}
 | 
					
						
							|  |  |  | ENV TRILIUM_GID=${GID}
 | 
					
						
							|  |  |  | ENV TRILIUM_DATA_DIR=/home/${USER}/trilium-data
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Use dumb-init as entrypoint to handle signals properly
 | 
					
						
							|  |  |  | ENTRYPOINT ["/usr/bin/dumb-init", "--"]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-21 15:40:21 -07:00
										 |  |  | # Use the entrypoint script
 | 
					
						
							| 
									
										
										
										
											2025-05-27 19:52:30 +03:00
										 |  |  | CMD [ "bash", "./rootless-entrypoint.sh" ]
 | 
					
						
							| 
									
										
										
										
											2025-05-13 18:51:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | HEALTHCHECK --start-period=10s CMD node /home/${USER}/app/docker_healthcheck.js
 |