Downloads:
19,711
Downloads of v 0.9.5:
3,380
Last Update:
02 Mar 2017
Package Maintainer(s):
Software Author(s):
- Matt Holt
Tags:
caddy web server- Software Specific:
- Software Site
- Software Source
- Software License
- Software Docs
- Software Issues
- Package Specific:
- Package Source
- Package outdated?
- Package broken?
- Contact Maintainers
- Contact Site Admins
- Software Vendor?
- Report Abuse
- Download
Caddy
This is not the latest version of Caddy available.
- 1
- 2
- 3
0.9.5 | Updated: 02 Mar 2017
- Software Specific:
- Software Site
- Software Source
- Software License
- Software Docs
- Software Issues
- Package Specific:
- Package Source
- Package outdated?
- Package broken?
- Contact Maintainers
- Contact Site Admins
- Software Vendor?
- Report Abuse
- Download
Downloads:
19,711
Downloads of v 0.9.5:
3,380
Maintainer(s):
Software Author(s):
- Matt Holt
Caddy 0.9.5
This is not the latest version of Caddy available.
Legal Disclaimer: Neither this package nor Chocolatey Software, Inc. are affiliated with or endorsed by Matt Holt. The inclusion of Matt Holt trademark(s), if any, upon this webpage is solely to identify Matt Holt goods or services and not for commercial purposes.
- 1
- 2
- 3
All Checks are Passing
3 Passing Tests
Deployment Method: Individual Install, Upgrade, & Uninstall
To install Caddy, run the following command from the command line or from PowerShell:
To upgrade Caddy, run the following command from the command line or from PowerShell:
To uninstall Caddy, run the following command from the command line or from PowerShell:
Deployment Method:
This applies to both open source and commercial editions of Chocolatey.
1. Enter Your Internal Repository Url
(this should look similar to https://community.chocolatey.org/api/v2/)
2. Setup Your Environment
1. Ensure you are set for organizational deployment
Please see the organizational deployment guide
2. Get the package into your environment
Option 1: Cached Package (Unreliable, Requires Internet - Same As Community)-
Open Source or Commercial:
- Proxy Repository - Create a proxy nuget repository on Nexus, Artifactory Pro, or a proxy Chocolatey repository on ProGet. Point your upstream to https://community.chocolatey.org/api/v2/. Packages cache on first access automatically. Make sure your choco clients are using your proxy repository as a source and NOT the default community repository. See source command for more information.
- You can also just download the package and push it to a repository Download
-
Open Source
-
Download the package:
Download - Follow manual internalization instructions
-
-
Package Internalizer (C4B)
-
Run: (additional options)
choco download caddy --internalize --version=0.9.5 --source=https://community.chocolatey.org/api/v2/
-
For package and dependencies run:
choco push --source="'INTERNAL REPO URL'"
- Automate package internalization
-
Run: (additional options)
3. Copy Your Script
choco upgrade caddy -y --source="'INTERNAL REPO URL'" --version="'0.9.5'" [other options]
See options you can pass to upgrade.
See best practices for scripting.
Add this to a PowerShell script or use a Batch script with tools and in places where you are calling directly to Chocolatey. If you are integrating, keep in mind enhanced exit codes.
If you do use a PowerShell script, use the following to ensure bad exit codes are shown as failures:
choco upgrade caddy -y --source="'INTERNAL REPO URL'" --version="'0.9.5'"
$exitCode = $LASTEXITCODE
Write-Verbose "Exit code was $exitCode"
$validExitCodes = @(0, 1605, 1614, 1641, 3010)
if ($validExitCodes -contains $exitCode) {
Exit 0
}
Exit $exitCode
- name: Install caddy
win_chocolatey:
name: caddy
version: '0.9.5'
source: INTERNAL REPO URL
state: present
See docs at https://docs.ansible.com/ansible/latest/modules/win_chocolatey_module.html.
chocolatey_package 'caddy' do
action :install
source 'INTERNAL REPO URL'
version '0.9.5'
end
See docs at https://docs.chef.io/resource_chocolatey_package.html.
cChocoPackageInstaller caddy
{
Name = "caddy"
Version = "0.9.5"
Source = "INTERNAL REPO URL"
}
Requires cChoco DSC Resource. See docs at https://github.com/chocolatey/cChoco.
package { 'caddy':
ensure => '0.9.5',
provider => 'chocolatey',
source => 'INTERNAL REPO URL',
}
Requires Puppet Chocolatey Provider module. See docs at https://forge.puppet.com/puppetlabs/chocolatey.
4. If applicable - Chocolatey configuration/installation
See infrastructure management matrix for Chocolatey configuration elements and examples.
This package was approved by moderator AdmiringWorm on 09 Mar 2017.
Caddy is a lightweight, general-purpose web server for Windows, Mac, Linux, BSD and Android. It is a capable alternative to other popular and easy to use web servers. (@caddyserver on Twitter)
The most notable features are HTTP/2, Let's Encrypt support, Virtual Hosts, TLS + SNI, and easy configuration with a Caddyfile. In development, you usually put one Caddyfile with each site. In production, Caddy serves HTTPS by default and manages all cryptographic assets for you.
Server Types
- DNS - DNS server core (see https://coredns.io)
- HTTP - HTTP server core; everything most sites need
Directives/Middleware
- awslambda - Gateways requests to AWS Lambda functions
- cors - Easily configure Cross-Origin Resource Sharing
- expires - Add expiration headers to assets
- filemanager - Manage files on your server with a GUI
- filter - Filter response body contents
- git - Deploy your site with git push
- hugo - Static site generator with admin interface
- ipfilter - Block or allow clients based on IP origin
- jsonp - Wrap JSON responses as JSONP
- jwt - Authorization with JSON Web Tokens
- locale - Detect locale of client
- mailout - SMTP client with REST API and PGP encryption
- minify - Minify static assets on-the-fly
- multipass - Authorization by email
- prometheus - Prometheus metrics integration
- ratelimit - Limit rate of requests
- realip - Restore original IP when behind a proxy
- search - Site search engine
- upload - Upload files
DNS Providers
- cloudflare
- digitalocean
- dnsimple
- dyn
- gandi
- googlecloud
- linode
- namecheap
- ovh
- rfc2136
- route53
- vultr
md5: 68BDE4D1B4258D308A9B416A0A7E10E4 | sha1: C5759CA58FFA818555F65D062DB0E2277012808A | sha256: EF25C5095BDE4AF7B033465098BD9FB72FA095D8AA04EB51FCE016A9FB6CF51A | sha512: 7033FB3A5EC97EB680129F744240D63A15A463F47E752079935A0F6A08592B8D27940C7716B9794ECA6AFE4324C81056B64AF531437E28276F14020B878D23A5
md5: AFD3FEC180E7C383E1D2156F15513CBA | sha1: 768E84090CA0551CB74D074C75337FC42BEFA4FD | sha256: 9A0EA98E3BFC266561AA521C4AD2DE7A08A780B5DBC2E27DB61DB9E85F792EFF | sha512: B946D105FAD539DCE738F247B5F3835388764C768E97AFF5C0B4B33460B0A2EB7FE69ED33C9D8DB81001AD859514F6E8AED9D882020437A4A4402DB24DBA2043
VERIFICATION.TXT is intended to assist the Chocolatey moderators and community
in verifying that this package's contents are trustworthy.
The following package files can be verified by comparing a hash of their content
to hash of the file available at the corresponding download URL.
These download URLs are what we assert to be the trusted source for those files.
tools/caddy-amd64.zip: https://caddyserver.com/download/build?os=windows&arch=amd64&features=awslambda,cloudflare,cors,digitalocean,DNS,dnsimple,dyn,expires,filemanager,filter,gandi,git,googlecloud,hugo,ipfilter,jsonp,jwt,linode,locale,mailout,minify,multipass,namecheap,ovh,prometheus,ratelimit,realip,rfc2136,route53,search,upload,vultr
tools/caddy-386.zip: https://caddyserver.com/download/build?os=windows&arch=386&features=awslambda,cloudflare,cors,digitalocean,DNS,dnsimple,dyn,expires,filemanager,filter,gandi,git,googlecloud,hugo,ipfilter,jsonp,jwt,linode,locale,mailout,minify,multipass,namecheap,ovh,prometheus,ratelimit,realip,rfc2136,route53,search,upload,vultr
CAVEAT!
Caddy's download server only serves the most recent release. As such, the URLs
above always point to the most recent Caddy release which may not match this
package version.
This package is built for Caddy version: 0.9.5.
Log in or click on link to see number of positives.
- caddy.0.9.5.nupkg (049c71cd62d0) - ## / 57
- caddy-386.zip (ef25c5095bde) - ## / 58
- caddy-amd64.zip (9a0ea98e3bfc) - ## / 58
- caddy.exe (bfcb3f3a15e6) - ## / 59
- caddy.exe (01a640cee58a) - ## / 59
In cases where actual malware is found, the packages are subject to removal. Software sometimes has false positives. Moderators do not necessarily validate the safety of the underlying software, only that a package retrieves software from the official distribution point and/or validate embedded software against official distribution point (where distribution rights allow redistribution).
Chocolatey Pro provides runtime protection from possible malware.
Add to Builder | Version | Downloads | Last Updated | Status |
---|---|---|---|---|
Caddy 2.8.4 | 2226 | Monday, June 3, 2024 | Approved | |
Caddy 2.8.1 | 22 | Friday, May 31, 2024 | Approved | |
Caddy 2.8.0 | 149 | Thursday, May 30, 2024 | Approved | |
Caddy 2.7.6 | 2290 | Saturday, December 9, 2023 | Approved | |
Caddy 2.7.5 | 702 | Saturday, October 14, 2023 | Approved | |
Caddy 2.7.3 | 1021 | Sunday, August 6, 2023 | Approved | |
Caddy 2.7.2 | 69 | Friday, August 4, 2023 | Approved | |
Caddy 2.7.0 | 50 | Thursday, August 3, 2023 | Approved | |
Caddy 2.6.4 | 1857 | Thursday, February 16, 2023 | Approved | |
Caddy 2.6.3 | 191 | Thursday, February 9, 2023 | Approved | |
Caddy 2.6.2 | 1068 | Thursday, October 13, 2022 | Approved | |
Caddy 2.5.2 | 768 | Wednesday, July 13, 2022 | Approved | |
Caddy 2.5.1 | 558 | Saturday, May 7, 2022 | Approved | |
Caddy 2.5.0 | 237 | Tuesday, April 26, 2022 | Approved | |
Caddy 2.4.6 | 931 | Tuesday, November 9, 2021 | Approved | |
Caddy 2.4.5 | 405 | Saturday, September 4, 2021 | Approved | |
Caddy 2.4.4 | 218 | Tuesday, August 31, 2021 | Approved | |
Caddy 2.4.3 | 479 | Friday, June 18, 2021 | Approved | |
Caddy 2.4.2 | 229 | Sunday, June 13, 2021 | Approved | |
Caddy 2.4.1 | 267 | Friday, May 21, 2021 | Approved | |
Caddy 2.4.0 | 249 | Tuesday, May 11, 2021 | Approved | |
Caddy 2.3.0 | 730 | Friday, January 1, 2021 | Approved | |
Caddy 2.2.1 | 305 | Wednesday, October 14, 2020 | Approved | |
Caddy 2.2.0 | 192 | Monday, October 12, 2020 | Approved | |
Caddy 0.9.5 | 3380 | Thursday, March 2, 2017 | Approved | |
Caddy 0.8.3 | 538 | Monday, May 16, 2016 | Approved | |
Caddy 0.8.2.20160310 | 468 | Friday, March 11, 2016 | Approved |
Caddy 0.9.5 contains several critical fixes and we recommend applying the update right away. Please read these notes first, though!
Thank you to the collaborators and contributors for all your hard work (especially @tw4452852 and @lhecker - among many others, see the commit history) while I've been busy working on the new website and build infrastructure!
HTTP Timeouts Enabled by Default
Caddy aims to be secure right out of the box. In order to prevent faulty or malicious clients from seeping resources away with slowloris behavior, Caddy now enables timeouts by default. In general, this will not affect most users. However, you may need to raise or disable these timeouts depending on your legitimate visitors' needs and your server's configuration. If your visitors have legitimately slow networks or you need to hold requests for a long time (e.g. long polling or proxying long requests to a trusted backend), consider raising these timeouts.
Default timeout values:
- read: 10s (time spent reading request headers and body)
- header: 10s (time spent reading just headers; not used until Go 1.8 is released)
- write: 20s (starts at reading request body, ends when finished writing response body)
- idle: 2m (time to hold connection between requests; not used until Go 1.8 is released)
As you can see, a couple of the timeout values will begin functioning when Caddy is built on Go 1.8, expected within about a month. Go ahead and set them now; they will just start working when supported. See the timeouts pull request and docs.
Critical Uptime/Connectivity Fix
This is a little embarrassing, but if conditions were just right, Caddy would initiate a certificate renewal using the TLS-SNI-01 challenge, which would cause a deadlock. Subsequent TLS handshakes would block forever until the server stopped responding to requests. It took months to find and fix this because it only happened when very specific conditions are met: certificate needs renewal (once every 60 days), TLS-SNI-01 challenge is chosen (by roll of dice), renewal is trigged from background maintenance goroutine (not on-demand or during startup), and Let's Encrypt did not have a cached authz for that domain. Now it's fixed.
A huge thanks to Bradley Falzon (@bradleyfalzon), Miek Gieben (@miekg), and Sebestian Erhart (@xenolf) for spending considerable time to help me debug this. It wasn't possible without their hours of help.
Proxy performance improvements
We continue to iterate on Caddy's proxy
functionality. Caddy was never designed to be a reverse proxy except as a very simple one, just to say that it can do it. But it turns out that proxy
is one of the most popular directives. So with this release, we've improved on a recent regression that buffered request bodies. Proxy configurations with a single upstream or with try_duration unset (0) will be much faster and use less memory. We're still improving upon failure conditions and retry behavior; we had a rich discussion in #1314 about it. You should also see better HTTPS+websockets support.
Also, the deprecated proxy_header
subdirective is no longer accepted; use header_upstream
instead.
Minor security fixes in browse
The browse
middleware was improved a bit. First, a filter textbox was added to instantly filter the listings by file name. We also now sanitize the file names and links in case, for some reason, you are not already doing that with untrusted files. I want to thank Kevin Froman (@beardog108) for the responsible reporting of this as a precaution. I also went ahead and made sure the browse directive will hide the active Caddyfile if it is within your site's root, no matter the current working directory.
Other things
There's a new -validate
flag to load and parse your Caddyfile, then terminate. It will tell you if the Caddyfile is syntactically valid or not. There's also new placeholders: {when_iso}
gives you the UTC timestamp in ISO 8601 format, and {rewrite_path}
gives you the URI path after a rewrite ({path}
gives the path as it originally was on the request before any rewrites).
Full change list:
- New -validate flag to only check a Caddyfile, then exit
- New {when_iso} placeholder for timestamp ISO 8601 in UTC
- New {rewrite_path} and {rewrite_path_escaped} placeholders
- New 'timeouts' directive to configure or disable HTTP timeouts
- HTTP-level timeouts enabled by default
- browse: Added textbox to filter listing in default template
- browse: Sanitize file names and links in default template
- browse: Ensure active Caddyfile is hidden regardless of cwd
- fastcgi: New 'root' property, mainly for use with containers
- markdown: Apply some front matter fields as <meta> tags
- proxy: Fixed HTTP/2 upstream to backend; honors -http CLI flag
- proxy: Fixed websockets over HTTPS
- proxy: Reduced memory usage and improved performance
- proxy: Added support for HTTP trailers
- tls: Fixed deadlock that affected some background renewals
- Several other smaller bugs squashed and improvements made
Thanks for continuing to use Caddy!
This package has no dependencies.
Ground Rules:
- This discussion is only about Caddy and the Caddy package. If you have feedback for Chocolatey, please contact the Google Group.
- This discussion will carry over multiple versions. If you have a comment about a particular version, please note that in your comments.
- The maintainers of this Chocolatey Package will be notified about new comments that are posted to this Disqus thread, however, it is NOT a guarantee that you will get a response. If you do not hear back from the maintainers after posting a message below, please follow up by using the link on the left side of this page or follow this link to contact maintainers. If you still hear nothing back, please follow the package triage process.
- Tell us what you love about the package or Caddy, or tell us what needs improvement.
- Share your experiences with the package, or extra configuration or gotchas that you've found.
- If you use a url, the comment will be flagged for moderation until you've been whitelisted. Disqus moderated comments are approved on a weekly schedule if not sooner. It could take between 1-5 days for your comment to show up.