A modern Umbraco CMS application with Docker Compose, SQL Server, and devcontainer support for consistent development environments.
- Docker and Docker Compose
- VS Code with Dev Containers extension (recommended)
- .NET 9 SDK (if running locally)
-
Clone the repository:
git clone https://github.com/markcoleman/web.git cd web
-
Copy environment variables:
cp .env.example .env
-
Open in VS Code and reopen in container:
code .
Then press
Ctrl+Shift+P
, select "Dev Containers: Reopen in Container" -
The application will be available at:
- HTTP: http://localhost:5000
- HTTPS: https://localhost:5001
- Umbraco BackOffice: http://localhost:5000/umbraco
-
Clone and setup:
git clone https://github.com/markcoleman/web.git cd web cp .env.example .env
-
Start services:
docker compose up -d
-
View logs:
docker compose logs -f web
-
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
-
Run the application:
cd src/UmbracoWeb/UmbracoWeb dotnet run
- 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
βββ .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
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.
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 |
appsettings.json
- Production configuration with placeholdersappsettings.Development.json
- Development-specific settingsdocker-compose.yml
- Development services orchestration.devcontainer/devcontainer.json
- VS Code dev container settings
# 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
# 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
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
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
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"
# 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
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
- β 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
- Change default SQL Server password in production
- Use proper SSL certificates for HTTPS
- Configure Umbraco security settings for production
- Regularly update dependencies via Dependabot
- Fork the repository
- Create a feature branch:
git checkout -b feature/amazing-feature
- Make changes and test locally
- Commit changes:
git commit -m 'Add amazing feature'
- Push to branch:
git push origin feature/amazing-feature
- Open a Pull Request
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
This project is licensed under the MIT License - see the LICENSE file for details.