File size: 1,383 Bytes
42be730
 
3658992
42be730
 
c0e77ac
42be730
 
c0e77ac
0a404a4
 
42be730
934aa4a
42be730
0a404a4
 
 
 
 
42be730
 
 
 
1130934
42be730
 
8d7f247
42be730
 
8d7f247
42be730
 
 
649c393
42be730
ef8f6a5
23aa172
42be730
 
0c91ad6
42be730
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# Use a suitable base Docker image with necessary dependencies
FROM circulartextapp/spaceread

# Set the working directory to /app
WORKDIR /app

# Copy the current directory contents into the container at /app
COPY . /app

# Define the user ID in the environment variable USER_ID with a default value
ARG USER_ID=1000
ENV USER_ID=$USER_ID

# Check if the user already exists
RUN if [ -z "$USER_ID" ]; then \
      echo "User ID not provided. Using the default user ID 1000."; \
      USER_ID=1000; \
    fi && \
    if id "$USER_ID" >/dev/null 2>&1; then \
      echo "User with ID $USER_ID already exists."; \
    else \
      useradd -m -u "$USER_ID" user; \
    fi

# Set appropriate permissions for the application directory
RUN chown -R user:user /app && chmod -R 755 /app

# Install gosu (adjust the package manager based on your base image)
RUN apt-get update && apt-get install -y gosu && rm -rf /var/lib/apt/lists/*

# Set the entrypoint script as executable
COPY entrypoint.sh /usr/local/bin/entrypoint.sh
RUN chmod +x /usr/local/bin/entrypoint.sh

# Switch to the user for improved security
USER user

# Define the entrypoint script to handle user creation and application startup
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]

# Default command to run if the user doesn't provide a command
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "7860", "--reload"]