Skip to main content
Glama

Copilot Studio Agent Direct Line MCP Server

by bradcstevens
Dockerfile3.8 kB
# ============================================================================= # Multi-stage Dockerfile for Copilot Studio Agent Direct Line MCP Server # Optimized for production with security best practices # ============================================================================= # ----------------------------------------------------------------------------- # Stage 1: Dependencies # Install production dependencies only # ----------------------------------------------------------------------------- FROM node:18-alpine AS deps # Install security updates RUN apk update && apk upgrade # Set working directory WORKDIR /app # Copy package files COPY package*.json ./ # Install production dependencies only RUN npm ci --only=production && \ npm cache clean --force # ----------------------------------------------------------------------------- # Stage 2: Builder # Build TypeScript application # ----------------------------------------------------------------------------- FROM node:18-alpine AS builder # Install security updates RUN apk update && apk upgrade # Set working directory WORKDIR /app # Copy package files COPY package*.json ./ # Install all dependencies (including dev dependencies for build) RUN npm ci && \ npm cache clean --force # Copy source code COPY tsconfig.json ./ COPY src ./src # Build TypeScript RUN npm run build # Remove dev dependencies after build RUN npm prune --production # ----------------------------------------------------------------------------- # Stage 3: Runtime # Minimal runtime image with only necessary files # ----------------------------------------------------------------------------- FROM node:18-alpine AS runtime # Install security updates and dumb-init for proper signal handling RUN apk update && apk upgrade && \ apk add --no-cache dumb-init && \ rm -rf /var/cache/apk/* # Create non-root user for security RUN addgroup -g 1001 -S nodejs && \ adduser -S nodejs -u 1001 # Set working directory WORKDIR /app # Copy package files and dependencies from deps stage COPY --from=deps --chown=nodejs:nodejs /app/node_modules ./node_modules COPY --from=deps --chown=nodejs:nodejs /app/package*.json ./ # Copy built application from builder stage COPY --from=builder --chown=nodejs:nodejs /app/dist ./dist # Copy environment example (for reference) COPY --chown=nodejs:nodejs .env.example ./.env.example # Create directory for session storage (if using file storage) RUN mkdir -p /app/.sessions && \ chown -R nodejs:nodejs /app/.sessions # Switch to non-root user USER nodejs # Expose port (will be set via environment variable) EXPOSE 3000 # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=40s --retries=3 \ CMD node -e "require('http').get('http://localhost:${MCP_SERVER_PORT:-3000}/health', (r) => { process.exit(r.statusCode === 200 ? 0 : 1); });" # Use dumb-init to handle signals properly ENTRYPOINT ["dumb-init", "--"] # Start the application CMD ["node", "dist/index.js"] # Metadata labels LABEL maintainer="Copilot Studio MCP Team" LABEL description="MCP server for Microsoft Copilot Studio Agent integration via Direct Line 3.0" LABEL version="1.0.5" # ----------------------------------------------------------------------------- # Stage 4: Development # Development image with dev dependencies and hot reload # ----------------------------------------------------------------------------- FROM node:18-alpine AS development # Install security updates RUN apk update && apk upgrade # Set working directory WORKDIR /app # Copy package files COPY package*.json ./ # Install all dependencies (including dev dependencies) RUN npm ci # Copy source code COPY . . # Expose port EXPOSE 3000 # Start in development mode with hot reload CMD ["npm", "run", "dev"]

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/bradcstevens/copilot-studio-agent-direct-line-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server