Skip to content

markcoleman/web

Repository files navigation

Umbraco CMS Web Application

A modern Umbraco CMS application with Docker Compose, SQL Server, and devcontainer support for consistent development environments.

πŸš€ Quick Start

Prerequisites

Development with Dev Container (Recommended)

  1. Clone the repository:

    git clone https://github.com/markcoleman/web.git
    cd web
  2. Copy environment variables:

    cp .env.example .env
  3. Open in VS Code and reopen in container:

    code .

    Then press Ctrl+Shift+P, select "Dev Containers: Reopen in Container"

  4. The application will be available at:

Local Development with Docker Compose

  1. Clone and setup:

    git clone https://github.com/markcoleman/web.git
    cd web
    cp .env.example .env
  2. Start services:

    docker compose up -d
  3. View logs:

    docker compose logs -f web

Local Development without Docker

  1. Setup SQL Server (Docker):

    docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=MyStrongPassword123!" \
      -p 1433:1433 --name sql-server \
      -d mcr.microsoft.com/mssql/server:2022-latest
  2. Run the application:

    cd src/UmbracoWeb/UmbracoWeb
    dotnet run

πŸ—οΈ Architecture

Stack

  • CMS: Umbraco 16.2
  • Runtime: .NET 9.0
  • Database: Microsoft SQL Server 2022
  • Logging: Serilog (Console + File)
  • Container: Docker with multi-stage build
  • Development: VS Code Dev Containers

Project Structure

β”œβ”€β”€ .devcontainer/              # VS Code dev container configuration
β”œβ”€β”€ .github/                    # GitHub Actions workflows & Dependabot
β”œβ”€β”€ docs/                       # Documentation
β”œβ”€β”€ src/UmbracoWeb/            # Main application source
β”‚   β”œβ”€β”€ UmbracoWeb/            # Umbraco CMS project
β”‚   β”‚   β”œβ”€β”€ Controllers/       # API controllers
β”‚   β”‚   β”œβ”€β”€ Services/          # Business logic services
β”‚   β”‚   β”œβ”€β”€ Models/           # Data models and DTOs
β”‚   β”‚   └── Views/Partials/   # Umbraco partial views
β”‚   β”œβ”€β”€ UmbracoWeb.Tests/     # Unit and integration tests
β”‚   └── Dockerfile            # Production container image
β”œβ”€β”€ logs/                      # Application logs (gitignored)
β”œβ”€β”€ docker-compose.yml         # Multi-service development stack
β”œβ”€β”€ .env.example              # Environment variables template
└── README.md                 # This file

πŸ›‘οΈ Security Components

PhishLabs Incident Reporter

The application includes a PhishLabs integration for reporting suspicious URLs:

  • Member-friendly UI: Simple form for reporting phishing links
  • Server-side proxy: Secure API integration with PhishLabs
  • Real-time validation: Client and server-side input validation
  • Accessibility: Full ARIA support and keyboard navigation
  • Security: CSRF protection, rate limiting, input sanitization

Usage in templates:

@Html.Partial("PhishLabsIncidentReporter")

Configuration required:

{
  "PhishLabs": {
    "ApiBaseUrl": "https://api.phishlabs.com",
    "ApiKey": "your-api-key",
    "ServicePath": "/incidents/your-service"
  }
}

See PhishLabs Documentation for complete setup and usage details.

βš™οΈ Configuration

Environment Variables

Copy .env.example to .env and configure:

Variable Description Default
SA_PASSWORD SQL Server SA password MyStrongPassword123!
UMBRACO_GLOBAL_ID Unique site identifier local-dev-site
UMBRACO_BACKOFFICE_HOST BackOffice host URL localhost:5000
CONNECTION_STRING Database connection Auto-configured
ASPNETCORE_ENVIRONMENT Application environment Development

Configuration Files

  • appsettings.json - Production configuration with placeholders
  • appsettings.Development.json - Development-specific settings
  • docker-compose.yml - Development services orchestration
  • .devcontainer/devcontainer.json - VS Code dev container settings

πŸ”§ Development

Building

# Restore packages
dotnet restore src/UmbracoWeb/UmbracoWeb/UmbracoWeb.csproj

# Build application
dotnet build src/UmbracoWeb/UmbracoWeb/UmbracoWeb.csproj --configuration Release

# Run locally
dotnet run --project src/UmbracoWeb/UmbracoWeb/UmbracoWeb.csproj

Docker Commands

# Build and start all services
docker compose up -d

# View application logs
docker compose logs -f web

# View database logs
docker compose logs -f mssql

# Stop all services
docker compose down

# Rebuild services
docker compose up -d --build

# Clean up volumes (⚠️ deletes database data)
docker compose down -v

Database Management

The SQL Server database persists data in a Docker volume. To reset:

# Stop services and remove volumes
docker compose down -v

# Start fresh
docker compose up -d

πŸš€ Deployment

GitHub Actions CI/CD

The repository includes automated workflows:

  • CI: Build, test, and security scanning on every push/PR
  • CD: Docker image build and push to GitHub Container Registry
  • Dependabot: Automated dependency updates

Production Environment Variables

For production deployment, configure these environment variables:

# Database
CONNECTION_STRING="Server=your-sql-server;Database=UmbracoWeb;User Id=user;Password=password;TrustServerCertificate=true"

# Umbraco
UMBRACO_GLOBAL_ID="your-production-site-id"
UMBRACO_BACKOFFICE_HOST="your-domain.com"

# Environment
ASPNETCORE_ENVIRONMENT="Production"

Docker Production Image

# Build production image
docker build -f src/UmbracoWeb/Dockerfile -t umbraco-web .

# Run production container
docker run -d \
  -p 80:8080 \
  -e CONNECTION_STRING="your-connection-string" \
  -e UMBRACO_GLOBAL_ID="your-site-id" \
  -e UMBRACO_BACKOFFICE_HOST="your-domain.com" \
  --name umbraco-web \
  umbraco-web

πŸ“ Logging

Logs are configured with Serilog and output to:

  • Console: Structured JSON for container logs
  • Files: logs/log-YYYY-MM-DD.txt (daily rolling)

Log levels:

  • Development: Debug level
  • Production: Information level

πŸ”’ Security

Best Practices Implemented

  • βœ… Non-root container user
  • βœ… Environment variable externalization
  • βœ… Secrets excluded from source control
  • βœ… SQL Server with strong passwords
  • βœ… HTTPS support configured
  • βœ… Security scanning in CI/CD
  • βœ… Dependabot for vulnerability management

Security Considerations

  • Change default SQL Server password in production
  • Use proper SSL certificates for HTTPS
  • Configure Umbraco security settings for production
  • Regularly update dependencies via Dependabot

🀝 Contributing

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make changes and test locally
  4. Commit changes: git commit -m 'Add amazing feature'
  5. Push to branch: git push origin feature/amazing-feature
  6. Open a Pull Request

πŸ“‹ Troubleshooting

Common Issues

Database Connection Failed

# Check SQL Server container
docker compose logs mssql

# Verify connection string in logs
docker compose logs web | grep "Connection"

Umbraco Installation Issues

  • Navigate to /umbraco to access the installation wizard
  • Use the connection string from appsettings.Development.json
  • Default admin credentials will be set during installation

Port Conflicts

# Check if ports are in use
netstat -tulpn | grep :5000
netstat -tulpn | grep :1433

# Modify ports in docker-compose.yml if needed

Dev Container Issues

  • Ensure Docker is running
  • Rebuild container: Ctrl+Shift+P β†’ "Dev Containers: Rebuild Container"
  • Check .devcontainer/devcontainer.json configuration

πŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ”— Links

About

No description, website, or topics provided.

Resources

License

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors 3

  •  
  •  
  •