Fast and extensible multi-platform HTTP/1-2-3 web server with automatic HTTPS
Find a file
2015-04-08 23:24:59 -06:00
config Renamed extensionless to extension, Extensionless to Ext 2015-04-02 21:59:45 -06:00
middleware Bug fix for default error handling with gzip 2015-04-08 23:24:59 -06:00
server Refactor: Middleware chain uses Handler instead of HandlerFunc 2015-04-02 23:30:54 -06:00
.gitignore Created basic fastcgi middleware layer 2015-01-21 17:51:47 -07:00
main.go Tweak to parser and main's error handling 2015-03-28 16:24:00 -06:00
README.md Updated README 2015-03-25 22:48:28 -06:00

Meet caddy

Caddy is a web server for your files like Apache, nginx, or lighttpd, but with different goals, features, and advantages.

Note: This software is pre-1.0 and under rapid development. Don't use it in production (yet).

Features

  • HTTP/1.1 and HTTP/2
  • TLS
  • FastCGI
  • WebSockets
  • Markdown
  • IPv4 and IPv6 support
  • Gzip
  • Custom headers
  • Logging
  • Rewrites
  • Redirects
  • Multi-core
    • more

Caddy is designed to be super-easy to use and configure. Full documentation coming soon.

Run Caddy in 10 Seconds

  1. Run go get github.com/mholt/caddy
  2. cd into your website's directory
  3. Run caddy (assumes $GOPATH/bin is in your $PATH)

Caddy will, by default, serve the current working directory on http://localhost:8080 (the default port will change before version 1.0).

When announced, there will be builds of Caddy available for all platforms.

Configuring Caddy

Use a Caddyfile to configure Caddy. If the current directory has a file called Caddyfile, it will be loaded and parsed and used as configuration. Or you can specify the location of the file using the -conf flag.

A Caddyfile always starts with an address to bind to. The rest of the lines are configuration directives. Here's an example:

mydomain.com:80
gzip
ext .html
header /api Access-Control-Allow-Origin *
browse /files /home/myuser/template.tpl

This simple file enables compression, serves clean URLs, adds the coveted Access-Control-Allow-Origin: * header to all requests starting with /api, and enables file browsing in /files using a custom HTML template. Wow! Caddy can do a lot with just a few lines.

Maybe you want to serve both HTTP and HTTPS. You can define multiple (virtual) hosts using curly braces:

mydomain.com:80 {
	gzip
	ext .html
}

mydomain.com:443 {
	tls cert.pem key.pem
}

More documentation and rigorous tests are on their way as this program matures and leaves the experimental phase. Lots of refinements are planned and well on their way to becoming a reality.

Contributing

Please get involved! Before adding a new feature or changing existing behavior, open an issue to discuss it. For non-breaking changes and bug fixes, pull requests are accepted. You can also drop a quick tweet to @mholt6 for quick feedback or comments.

About the project

Caddy was born out of the need for a "batteries-included" web server that runs anywhere and doesn't have to take its configuration with it. Caddy took some inspiration from nginx, lighttpd, Websocketd, and Vagrant, and provides a pleasant mixture of features from each of them. Once announced, Caddy will be suitable for use in both dev and production environments.