Mirror of github.com/gomods/athens, for those times when the internet at large dies
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Aaron Schlesinger a8467661c2
Adding build arg for the alpine version the docker image is based on (#1585)
2 days ago
.circleci run chart install test only if it is needed (#1229) 10 months ago
.github Sample pr template change (#1577) 2 weeks ago
.sail Add support for Sail development environments (#1248) 8 months ago
charts/athens-proxy charts: allow to set deployment update strategy (#1597) 1 week ago
cmd/proxy Adding build arg for the alpine version the docker image is based on (#1585) 2 days ago
docs pkg/storage: add External implementation (#1587) 1 week ago
e2etests Replace the current e2e script with a test suite running e2e tests. (#1514) 1 month ago
pkg pkg/storage: add External implementation (#1587) 1 week ago
scripts Update builds for Go 1.14 (#1558) 1 month ago
test add config options for redis password (#1545) 1 month ago
.dockerignore Add .git to .dockerignore (#1429) 5 months ago
.drone.yml Adds redis sentinel support (#1554) 3 weeks ago
.gitattributes normalize all line endings for the repo (#269) 1 year ago
.gitignore SystemD installation (#1445) 4 months ago
CODE_OF_CONDUCT.md Add Code of Conduct (#707) 1 year ago
CONTRIBUTING.md Adding a header to the contributing doc (#1483) 4 months ago
DEVELOPMENT.md Adding notes for how to do a release (#1576) 2 weeks ago
Dockerfile.test Update builds for Go 1.14 (#1558) 1 month ago
LICENSE Updating the license author (#387) 1 year ago
Makefile update go version in configs (#1594) 1 week ago
PHILOSOPHY.md Move PHILOSOPHY.md to our docs site (#877) 1 year ago
README.md Improving the project status section of our README (#1555) 3 weeks ago
REVIEWS.md Adding comments on when to use each review type (#661) 1 year ago
SHOULDERS.md Update SHOULDERS.md (#1061) 1 year ago
appveyor.yml Update builds for Go 1.14 (#1558) 1 month ago
azure-pipelines.yml Remove dummy mod dir (#1121) 11 months ago
config.dev.toml pkg/storage: add External implementation (#1587) 1 week ago
docker-compose.yml update go version in configs (#1594) 1 week ago
download.example.hcl downloadProtocol: support multi-proxy environments with DownloadFile (#1230) 10 months ago
go.mod update go version in configs (#1594) 1 week ago
go.sum go mod tidy (#1590) 2 weeks ago
init.ps1 #1149 Remove references to Buffalo (#1203) 11 months ago
netlify.toml redirect other domain requests to docs.gomods.io (#663) 1 year ago
robots.txt feat: add /robots.txt (#1355) 6 months ago


Welcome To Athens, Gophers!

Athens Banner

Build Status GoDoc Go Report Card codecov Docker Pulls PRs Welcome Open Source Helpers

Welcome to the Athens project! We are a proxy server for the Go Modules download API.

Office HoursOffice Hours
We hold office hours approximately weekly. To find out what they’re all about, join them, watch previous meetings, or just find out more, see the docs. Absolutely everyone is invited to attend these, suggest topics, and participate!

See our documentation site https://docs.gomods.io for more details on the project.

Project Status

Development teams at several companies are using Athens in their everyday development workflows.

This means that they are running their own Athens servers, hooking them up to their own storage backends (see here for the list of storage backends that Athens supports), and configuring their local Go development environments to use that Athens server.

We encourage you to try it out, consider using it in your development workflow, and letting us know if you are using it by adding a comment to this GitHub issue.

More Details Please!

The proxy implements the Go modules download protocol.

There is currently an experimental public proxy (at https://athens.azurefd.net) that you can use to try out Athens, without installing anything locally. We also have a community of folks using Athens in production inside their organizations as an internal proxy. In either deployment, developers set their GOPROXY environment variable to point to the Athens proxy of their choice. At that point, go get, go build, and more commands will use the proxy to download dependencies as necessary.

Athens proxies are highly configurable, so they can work for lots of different deployments. For example, proxies support a wide variety of storage drivers including:

  • Cloud blob storage services
  • MongoDB
  • Content distribution networks (CDNs)
  • Shared disk
  • In-memory


See DEVELOPMENT.md for details on how to set up your development environment and start contributing code.

Speaking of contributing, read on!


If you use Athens for your development workflow, we hope that you’ll consider contributing back to the project. Athens is widely used and has plenty of interesting work to do, from technical challenges to technical documentation to release management. We have a wonderful community that we would love you to be a part of. Absolutely everyone is welcome.

The quickest way to get involved is by filing issues if you find bugs or find that you need Athens to do something it doesn’t.

If you’d like to help us tackle some of the technical / code challenges and you’re familiar with the GitHub contribution process, you’ll probably be familiar with our process for contributions. You can optionally find or submit an issue, and then submit a pull request (PR) to fix that issue. See here for more of the project-specific details.

If you’re not familiar with the standard GitHub contribution process, which Athens mostly follows, please see this section of our documentation to learn how to contribute. You can also take advantage of @bketelsen’s great video on how to contribute code. The information in these documents and videos will help you not only with this project, but can also help you contribute to many other projects on GitHub.

If you decide to to contribute but aren’t sure what to work on, we have a well maintained list of good first issues that you should look at. If you find one that you would like to work on, please post a comment saying “I want to work on this”, and then it’s all yours to begin working on.

We do recommend that you choose one of the issues on the above list, but you may also consider a different one from our entire list. Many of the issues on that list are more complex and challenging.

Before you do start getting involved or contributing, we want to let you know that we follow a general philosophy in how we work together, and we’d really appreciate you getting familiar with it before you start.

It’s not too long and it’s ok for you to “skim” it (or even just read the first two sections :smile:), just as long as you understand the spirit of who we are and how we work.

Getting Involved Without Contributing Pull Requests or Issues

If you’re not ready to contribute code yet, there are plenty of other great ways to get involved:

  • Come talk to us in the #athens channel in the Gophers slack. We’re a really friendly group, so come say hi and join us! Ping me (@arschles on slack) in the channel and I’ll give you the lowdown
  • Get familiar with the technology. There’s lots to read about. Here are some places to start:

Built on the Shoulders of Giants

The Athens project would not be possible without the amazing projects it builds on. Please see SHOULDERS.md to see a list of them.

Coding Guidelines

We all strive to write nice and readable code which can be understood by every person of the team. To achieve that we follow principles described in Brian’s talk Code like the Go team.

Code of Conduct

This project follows the Contributor Covenant (English version here) code of conduct.

If you have concerns, notice a code of conduct violation, or otherwise would like to talk about something related to this code of conduct, please reach out @arschles on the Gophers Slack.

Athens banner attributed to Golda Manuel