diff --git a/.codeclimate.yml b/.codeclimate.yml new file mode 100644 index 00000000000..0b6935d2979 --- /dev/null +++ b/.codeclimate.yml @@ -0,0 +1,20 @@ +--- +engines: + rubocop: + enabled: true + golint: + enabled: true + gofmt: + enabled: true + govet: + enabled: true + fixme: + enabled: true + duplication: + enabled: true + config: + languages: + - go +ratings: + paths: + - "**.go" diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000000..6b8710a711f --- /dev/null +++ b/.dockerignore @@ -0,0 +1 @@ +.git diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 00000000000..b9b66bb9af7 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,4 @@ +tmpl/assets/* linguist-vendored +*.js linguist-vendored +*.css linguist-vendored +*.html linguist-vendored diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml new file mode 100644 index 00000000000..534a9a101e6 --- /dev/null +++ b/.github/FUNDING.yml @@ -0,0 +1 @@ +github: avelino diff --git a/.github/ISSUE_TEMPLATE/bug.yml b/.github/ISSUE_TEMPLATE/bug.yml new file mode 100644 index 00000000000..69c606f17f5 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/bug.yml @@ -0,0 +1,27 @@ +name: Bug Report +description: Report a bug encountered +labels: ["bug", "pending-review"] +body: + - type: markdown + attributes: + value: | + Thank you very much for opening a bug report at awesome-go. + + If you have a feature idea or need help, please go to [our Forum](https://github.com/avelino/awesome-go/discussions). + before opening the issue we recommend that you read our [contribution guide](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md), there we talk about how you can contribute to awesome-go. + - type: checkboxes + id: confirm-search + attributes: + label: Search first + description: Please search [existing issues](https://github.com/avelino/awesome-go/issues) and the [awesome-go forum](https://github.com/avelino/awesome-go/discussions) before reporting. + options: + - label: I searched and no similar issues were found + required: true + - type: textarea + id: problem + attributes: + label: What Happened? + description: | + Please provide as much info as possible. Not doing so may result in your bug not being addressed in a timely manner. + validations: + required: true diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 00000000000..1e6d5851df5 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1,7 @@ +contact_links: + - name: Feature request + url: https://github.com/avelino/awesome-go/discussions/new?category=ideas + about: Suggest an idea for awesome-go + - name: Questions & Help + url: https://github.com/avelino/awesome-go/discussions/new?category=q-a + about: Ask a question about awesome-go diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 00000000000..860db5d261c --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,40 @@ +## We want to ensure high quality of the packages. Make sure that you've checked the boxes below before sending a pull request. + +- [ ] I have read the [Contribution Guidelines](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md#contribution-guidelines) +- [ ] I have read the [Maintainers Note](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md#maintainers) +- [ ] I have read the [Quality Standards](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md#quality-standards) + +_Not every repository (project) will require every option, but most projects should. Check the Contribution Guidelines for details._ + +- [ ] The repo documentation has a pkg.go.dev link. +- [ ] The repo documentation has a coverage service link. +- [ ] The repo documentation has a goreportcard link. +- [ ] The repo has a version-numbered release and a go.mod file. +- [ ] The repo has a continuous integration process that automatically runs tests that must pass before new pull requests are merged. +- [ ] Continuous integration is used to attempt to catch issues prior to releasing this package to end-users. + +## Please provide some links to your package to ease the review + +- [ ] forge link (github.com, gitlab.com, etc): +- [ ] pkg.go.dev: +- [ ] goreportcard.com: +- [ ] coverage service link ([codecov](https://codecov.io/), [coveralls](https://coveralls.io/), etc.): + +## Pull Request content + +- [ ] The package has been added to the list in alphabetical order. +- [ ] The package has an appropriate description with correct grammar. +- [ ] As far as I know, the package has not been listed here before. + +## Category quality + +_Note that new categories can be added only when there are 3 packages or more._ + +Packages added a long time ago might not meet the current guidelines anymore. It would be very helpful if you could check 3-5 packages above and below your submission to ensure that they also still meet the Quality Standards. + +Please delete one of the following lines: + +- [ ] The packages around my addition still meet the Quality Standards. +- [ ] I removed the following packages around my addition: (please give a short reason for each removal) + +Thanks for your PR, you're awesome! :sunglasses: diff --git a/.github/workflows/check-for-spammy-issues.yml b/.github/workflows/check-for-spammy-issues.yml new file mode 100644 index 00000000000..871ecc39bb7 --- /dev/null +++ b/.github/workflows/check-for-spammy-issues.yml @@ -0,0 +1,14 @@ +name: Issues spammy check +on: + issues: + types: [opened] + +jobs: + mark-as-spam: + name: Remove issues with spammy + runs-on: ubuntu-latest + steps: + - name: close issue + uses: balevine/mark-as-spam@v1.0 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/pull-request-first-comment.yaml b/.github/workflows/pull-request-first-comment.yaml new file mode 100644 index 00000000000..e5f3ac03474 --- /dev/null +++ b/.github/workflows/pull-request-first-comment.yaml @@ -0,0 +1,31 @@ +name: First comment in new pull request + +on: + pull_request_target: + types: [opened] + +jobs: + commentCreated: + runs-on: ubuntu-latest + permissions: + pull-requests: write + issues: write + environment: action + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + steps: + - name: first comment + uses: peter-evans/create-or-update-comment@v3 + with: + token: ${{ secrets.GITHUB_TOKEN }} + issue-number: ${{ github.event.pull_request.number }} + body: | + Thank you for contributing to [awesome-go](https://awesome-go.com/). We will review your contribution as soon as possible. + + Make sure you add the links in the body of the pull request that are requested in the [contribution guide](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md): + - repo link + - pkg.go.dev + - goreportcard.com + - coverage + + > Your project is under review. It may take a few days to be approved. diff --git a/.github/workflows/run-check.yaml b/.github/workflows/run-check.yaml new file mode 100644 index 00000000000..97258613c92 --- /dev/null +++ b/.github/workflows/run-check.yaml @@ -0,0 +1,22 @@ +name: Check For Stale Repositories +on: + workflow_dispatch: + schedule: + - cron: '0 0 * * 0' + +permissions: + contents: read # to fetch code (actions/checkout) + +jobs: + build: + name: Running test + runs-on: ubuntu-latest + container: golang:latest + steps: + - uses: actions/checkout@v4 + - name: Get dependencies + run: go get -v -t -d ./... + - name: run script + run: go test -v -run ^TestStaleRepository$ + env: + OAUTH_TOKEN: ${{secrets.OAUTH_TOKEN}} diff --git a/.github/workflows/site-deploy.yaml b/.github/workflows/site-deploy.yaml new file mode 100644 index 00000000000..e69802c6be7 --- /dev/null +++ b/.github/workflows/site-deploy.yaml @@ -0,0 +1,29 @@ +name: site-deploy + +on: + push: + branches: + - 'main' + +permissions: + contents: read # to fetch code (actions/checkout) + +jobs: + build: + name: Make and Deploy site + runs-on: ubuntu-latest + environment: netlify + container: golang:latest + steps: + - uses: actions/checkout@v4 + - name: Get dependencies + run: go get -v -t -d ./... + - name: Make awesome-go.com + run: go run . + - name: deploy awesome-go.com + uses: jsmrcaga/action-netlify-deploy@v1.1.0 + with: + NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }} + NETLIFY_SITE_ID: ${{ secrets.NETLIFY_SITE_ID }} + NETLIFY_DEPLOY_TO_PROD: true + build_directory: out diff --git a/.github/workflows/tests.yaml b/.github/workflows/tests.yaml new file mode 100644 index 00000000000..0ac9bd45fb3 --- /dev/null +++ b/.github/workflows/tests.yaml @@ -0,0 +1,22 @@ +name: tests + +on: + push: + branches: + - 'main' + pull_request: + +permissions: + contents: read # to fetch code (actions/checkout) + +jobs: + build: + name: Running test + runs-on: ubuntu-latest + container: golang:latest + steps: + - uses: actions/checkout@v4 + - name: Get dependencies + run: go get -v -t -d ./... + - name: Run tests + run: go test main_test.go main.go diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000000..c43b1528b46 --- /dev/null +++ b/.gitignore @@ -0,0 +1,10 @@ +out/ +awesome-go + +# Folders +.idea +.vscode +test_stale_repositories_log +*.exe +# Local Netlify folder +.netlify diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index f248457fd79..00000000000 --- a/.travis.yml +++ /dev/null @@ -1,9 +0,0 @@ -language: go - -go: - - 1.4 - -install: - - go get github.com/russross/blackfriday - - go get github.com/PuerkitoBio/goquery - diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 00000000000..5b85b915e72 --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,84 @@ +# Code of Conduct + +## 1. Purpose + +A primary goal of Awesome Go is to be inclusive to the largest number of contributors, with the most varied and diverse backgrounds possible. As such, we are committed to providing a friendly, safe and welcoming environment for all, regardless of gender, sexual orientation, ability, ethnicity, socioeconomic status, and religion (or lack thereof). + +This code of conduct outlines our expectations for all those who participate in our community, as well as the consequences for unacceptable behavior. + +We invite all those who participate in Awesome Go to help us create safe and positive experiences for everyone. + +## 2. Open Source Citizenship + +A supplemental goal of this Code of Conduct is to increase open source citizenship by encouraging participants to recognize and strengthen the relationships between our actions and their effects on our community. + +Communities mirror the societies in which they exist, and positive action is essential to counteract the many forms of inequality and abuses of power that exist in society. + +If you see someone who is making an extra effort to ensure our community is welcoming, friendly, and encourages all participants to contribute to the fullest extent, we want to know. + +## 3. Expected Behavior + +The following behaviors are expected and requested of all community members: + +* Participate in an authentic and active way. In doing so, you contribute to the health and longevity of this community. +* Exercise consideration and respect in your speech and actions. +* Attempt collaboration before conflict. +* Refrain from demeaning, discriminatory, or harassing behavior and speech. +* Be mindful of your surroundings and of your fellow participants. Alert community leaders if you notice a dangerous situation, someone distressed, or violations of this Code of Conduct, even if they seem inconsequential. +* Remember that community event venues may be shared with members of the public; please be respectful to all patrons of these locations. + +## 4. Unacceptable Behavior + +The following behaviors are considered harassment and are unacceptable within our community: + +* Violence, threats of violence or violent language directed against another person. +* Sexist, racist, homophobic, transphobic, ableist or otherwise discriminatory jokes and language. +* Posting or displaying sexually explicit or violent material. +* Posting or threatening to post other people’s personally identifying information ("doxing"). +* Personal insults, particularly those related to gender, sexual orientation, race, religion, or disability. +* Inappropriate photography or recording. +* Inappropriate physical contact. You should have someone’s consent before touching them. +* Unwelcome sexual attention. This includes, sexualized comments or jokes; inappropriate touching, groping, and unwelcomed sexual advances. +* Deliberate intimidation, stalking or following (online or in person). +* Advocating for, or encouraging, any of the above behavior. +* Sustained disruption of community events, including talks and presentations. + +## 5. Consequences of Unacceptable Behavior + +Unacceptable behavior from any community member, including sponsors and those with decision-making authority, will not be tolerated. + +Anyone asked to stop unacceptable behavior is expected to comply immediately. + +If a community member engages in unacceptable behavior, the community organizers may take any action they deem appropriate, up to and including a temporary ban or permanent expulsion from the community unexpected (and without refund in the case of a paid event). + +## 6. Reporting Guidelines + +If you are subject to or witness unacceptable behavior, or have any other concerns, please notify a community organizer as soon as possible. + +[Reporting Guidelines](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md#contribution-guidelines) + +Additionally, community organizers are available to help community members engage with local law enforcement or to otherwise help those experiencing unacceptable behavior feel safe. In the context of in-person events, organizers will also provide escorts as desired by the person experiencing distress. + +## 7. Addressing Grievances + +If you feel you have been falsely or unfairly accused of violating this Code of Conduct, you should notify Avelino with a concise description of your grievance. Your grievance will be handled in accordance with our existing governing policies. + +[Policy](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md) + +## 8. Scope + +We expect all community participants (contributors, paid or otherwise; sponsors; and other guests) to abide by this Code of Conduct in all community venues–online and in-person–as well as in all one-on-one communications pertaining to community business. + +This code of conduct and its related procedures also applies to unacceptable behavior occurring outside the scope of community activities when such behavior has the potential to adversely affect the safety and well-being of community members. + +## 9. Contact info + +avelinorun AT gmail DOT com + +## 10. License and attribution + +This Code of Conduct is distributed under a [Creative Commons Attribution-ShareAlike license](http://creativecommons.org/licenses/by-sa/3.0/). + +Portions of text derived from the [Django Code of Conduct](https://www.djangoproject.com/conduct/) and the [Geek Feminism Anti-Harassment Policy](http://geekfeminism.wikia.com/wiki/Conference_anti-harassment/Policy). + +Retrieved on November 22, 2016 diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 3cd700b9898..2234cfe4ebc 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,36 +1,168 @@ -This resource was made by the Go community and wouldn't be possible without you! We appreciate and recognize [all contributors](https://github.com/avelino/awesome-go/graphs/contributors). - -Join us on IRC at **#awesome-go** on freenode [web access](http://webchat.freenode.net/?channels=awesome-go) +This resource was made by the Go community and wouldn't be possible without you! +We appreciate and recognize [all contributors](https://github.com/avelino/awesome-go/graphs/contributors). # Contribution Guidelines -- **To add to the list:** Submit a pull request -- **To remove from the list:** Open an issue +> Please be aware that we want to accept your contribution, but we have **some rules to keep the minimum quality** of the packages listed here. All reviews are **not personal feedback**, even if you are a _developer reviewing your contribution_. **Sorry, if we can't meet your expectations; we do our best**. -To set this list apart from and compliment the excellent [Go wiki Projects page](https://golang.org/wiki/Projects), awesome-go is a specially curated list for high-quality, actively maintained Go packages and resources. +- **To add, remove, or change things on the list:** Submit a pull request -- List items should be sorted *alphabetically*. -- Each item should be limited to one link -- The link should be the name of the package or project -- Descriptions should be clear, concise, and non-promotional -- Descriptions should follow the link, on the same line +To set this list apart from and complement the excellent [Go wiki Projects page](https://golang.org/wiki/Projects), +and other lists, awesome-go is a specially curated list of high-quality, actively maintained Go packages and resources. Please contribute links to packages/projects you have used or are familiar with. This will help ensure high-quality entries. +> the maintainers do not work full-time on the project, meaning that we do not have a set periodicity for reviewing contributions - rest assured that we will do our best to review and eventually accept contributions + + +## Quality standards + +To be on the list, project repositories should adhere to the following quality standards. +(https://goreportcard.com/report/github.com/ **github_user** / **github_repo**): + +- have an **open source license**, [see list of allowed licenses](https://opensource.org/licenses/alphabetical); +- function as documented and expected; +- be generally useful to the wider community of Go programmers; +- be actively maintained with: + - regular, recent commits; + - or, for finished projects, issues and pull requests are responded to generally within 2 weeks; +- be stable or progressing toward stable; +- be thoroughly documented (README, pkg.go.dev doc comments, etc.) in the English language, so everyone is able to understand the project's intention and how it works. All public functions and types should have a Go-style documentation header; +- if the library/program is testable, then coverage should be >= 80% for non-data-related packages and >=90% for data-related packages. (**Note**: the tests will be reviewed too. We will check your coverage manually if your package's coverage is just a benchmark result); +- have at least one official version-numbered release that allows go.mod files to list the file by version number of the form vX.X.X. + +Categories must have at least 3 items. + + +## Preparing for review + +Projects listed must have the following in their documentation. When submitting, you will be asked +to provide them. + +- A link to the project's pkg.go.dev page +- A link to the project's Go Report Card report +- A link to a code coverage report + +One way to accomplish the above is to add badges to your project's README file. +- Use https://pkg.go.dev/badge/ to create the pkg.go.dev link. +- Go to https://goreportcard.com/ to generate a Go Report Card report, then click on the report badge in the upper-right corner to see details on how to add the badge to your README. +- Codecov, coveralls, and gocover all offer ways to create badges for code coverage reports. Another option is to generate a badge as part of a continuous integration process. See [Code Coverage](COVERAGE.md) for an example. + + +## How to add an item to the list + +Open a pull request against the README.md document that adds the repository to the list. + +- The pull request should add one and only one item to the list. +- The added item should be in alphabetical order within its category. +- The link should be the name of the package or project. +- Descriptions should be clear, concise, and non-promotional. +- Descriptions should follow the link on the same line and end with a punctuation mark. +- Remember to put a period `.` at the end of the project description. + +If you are creating a new category, move the projects that apply to the new category, ensuring +that the resulting list has at least 3 projects in every category, and that the categories are alphabetized. + +Fill out the template in your PR with the links asked for. If you accidentally remove the PR template from the submission, you can find it [here](https://github.com/avelino/awesome-go/blob/main/.github/PULL_REQUEST_TEMPLATE.md). + + +## Congrats, your project got accepted - what now? +You are an outstanding project now! Feel encouraged to tell others about it by adding one of these badges: +[![Mentioned in Awesome Go](https://awesome.re/mentioned-badge.svg)](https://github.com/avelino/awesome-go) +[![Mentioned in Awesome Go](https://awesome.re/mentioned-badge-flat.svg)](https://github.com/avelino/awesome-go) + +```md +[![Mentioned in Awesome Go](https://awesome.re/mentioned-badge.svg)](https://github.com/avelino/awesome-go) +[![Mentioned in Awesome Go](https://awesome.re/mentioned-badge-flat.svg)](https://github.com/avelino/awesome-go) +``` + + +## Maintenance expectations for projects listed here + +To prevent removal from awesome-go, your project must maintain the following quality standards. +- Development should be ongoing and maintain code quality. Official releases should be at least once a year if the project is ongoing. +- Or, if development has halted because the project is mature and stable, that can be demonstrated by having no bug reports in the Issues list that are older than 6 months. +- All links to quality reports should be to the most recent official release or current ongoing development. + +Highly recommended but not required: +- A continuous integration process to be part of the ongoing development process +- That the project uses a pull-request process, and the owners do not commit directly to the repository +- That the pull-request process requires the continuous-integration tests to pass before a pull request can be merged + -## Quality standard +## How to remove an item from the list -To stay on the list, package repositories should adhere to these quality standards: +- Open a pull request that deletes the line of the project in question. +- Delete the submission template and substitute a description of which criteria the project is not meeting. It should be a combination of the following. + - The project has not made an official release within the last year and has open issues. + - The project is not responding to bug reports issued within 6 months of submission. + - The project is not meeting quality standards as indicated by the Go Report Card or Code Coverage tests. + - The quality standard links have been removed from the documentation. + - The project is no longer open-sourced. + - The project is incompatible with any Go version issued within the last year (there is hopefully an open PR about this at the project). -- Generally useful to the community -- Functional -- Actively maintained (even if that just means acknowledging open issues when they arise) -- Stable, or progressing toward stable -- Documented (preferably godoc.org) -- Tests are preferred (when possible) +If the project is hosted on GitHub, include a link to the project's submitter and/or author so +that they will be notified of the desire to remove the project and have an opportunity to respond. +The link should be of the form @githubID. + +If the project is not hosted on GitHub, open an issue at the project in question's repository linking to the PR +and stating the following: + +>This project is currently listed at awesome-go at https://github.com/avelino/awesome-go. +However, it appears that the project is not maintaining the quality standards required to continue to be listed at the awesome-go project. +This project is scheduled to be removed within 2 weeks of this posting. To continue to be listed at awesome-go, please respond at: + -- link to above PR -- + +Then, comment on your PR at awesome-go with a link to the removal issue at the project. + + +## Maintainers + +To make sure every PR is checked, we have [team maintainers](MAINTAINERS). Every PR MUST be reviewed by at least one maintainer before it can get merged. + +The maintainers will review your PR and notify you and tag it in case any +information is still missing. They will wait 15 days for your interaction, after +that the PR will be closed. ## Reporting issues -Please open an issue if you find anything that could be improved or have suggestions for making the list a more valuable resource. We realize sometimes packages fall into abandonment or have breaking builds for extended periods of time, so if you see that, please let us know. We also realize that sometimes projects are just going through transitions or are more experimental in nature. These can still be cool, but we can indicate them as transitory or experimental -- again, just open an issue. Thanks everyone! +Please open an issue if you would like to discuss anything that could be improved or have suggestions for making the list a more valuable resource. We realize sometimes packages fall into abandonment or have breaking builds for extended periods of time, so if you see that, feel free to change its listing, or please let us know. We also realize that sometimes projects are just going through transitions or are more experimental in nature. These can still be cool, but we can indicate them as transitory or experimental. + +Removal changes will not be applied until they have been pending for a minimum of 1 week (7 days). This grace window benefits projects that may be going through a temporary transition, but are otherwise worthy of being on the list. + +Thanks, everyone! + + +## How decisions are made + +The official group of maintainers has the final decision on what PRs are accepted. Discussions are made openly in issues. Decisions are made by consensus. + + +## How to become a contributor? + +awesome-go is an open source project (created and maintained by the community), we are always open to new people to help us review the contributions (pull requests), **you don't need permission** or _name on the maintainers list_ to review a contribution and mark it as **LGTM**. + +> Before you do anything, please read [this topic](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md#quality-standards) very carefully. + +Now that you've read it, let's go! + +Go into the pull requests (PR) and look at the following aspects: + +* **shared links in the body of the PR:** they need to be valid and follow the quality specified above +* **check that the link added to `README.md`** is the same as the link to the repository mentioned in the body of the PR. +* **is it in the correct category?** + +If everything is OK, mark the PR as approved, [read this documentation](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/reviewing-proposed-changes-in-a-pull-request#starting-a-review) on how to do it. + +**Welcome to awesome-go!** + + +## How to become an ~~"official maintainer"~~? + +We don't give this name to people who are allowed to accept the PR. + +If you are a person who is constantly active in reviewing PR and contributing to the project, you will be invited by a maintainer. + +> **remember:** if you stop contributing with awesome-go for a long time, you will automatically be removed from the list of maintainers. diff --git a/COVERAGE.md b/COVERAGE.md new file mode 100644 index 00000000000..dfba16a3d5b --- /dev/null +++ b/COVERAGE.md @@ -0,0 +1,66 @@ +# Code Coverage + +While we recommend using one of the free websites available for monitoring code coverage during your continuous integration process, below is an example of how you can incorporate code coverage during the continuous integration process provided by GitHub actions and generate a code coverage report without one of those services. + +This `yaml` file will run tests on multiple system configurations, but will produce a code coverage report on only one of those. It will then create a code coverage badge and add it to the README file. + +This file should be put in the `.github/workflows` directory of your repo: + +```yaml +name: Go # The name of the workflow that will appear on Github + +on: + push: + branches: [ main ] + pull_request: + branches: [ main ] + # Allows you to run this workflow manually from the Actions tab + workflow_dispatch: + +jobs: + + build: + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-latest, windows-latest] + go: [1.16, 1.17] + steps: + - uses: actions/checkout@v2 + + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: ${{ matrix.go }} + + - name: Build + run: go install + + - name: Test + run: | + go test -v -cover ./... -coverprofile coverage.out -coverpkg ./... + go tool cover -func coverage.out -o coverage.out # Replaces coverage.out with the analysis of coverage.out + + - name: Go Coverage Badge + uses: tj-actions/coverage-badge-go@v1 + if: ${{ runner.os == 'Linux' && matrix.go == '1.17' }} # Runs this on only one of the ci builds. + with: + green: 80 + filename: coverage.out + + - uses: stefanzweifel/git-auto-commit-action@v4 + id: auto-commit-action + with: + commit_message: Apply Code Coverage Badge + skip_fetch: true + skip_checkout: true + file_pattern: ./README.md + + - name: Push Changes + if: steps.auto-commit-action.outputs.changes_detected == 'true' + uses: ad-m/github-push-action@master + with: + github_token: ${{ github.token }} + branch: ${{ github.ref }} + +``` diff --git a/MAINTAINERS b/MAINTAINERS new file mode 100644 index 00000000000..da378bdaf3d --- /dev/null +++ b/MAINTAINERS @@ -0,0 +1,13 @@ +Avelino (@avelino) +Duke (@dukex) +Dmitri Shuralyov (@dmitshur) +Dobrosław Żybort (@matrixik) +Dean Karn (@joeybloggs) +Kirill Danshin (@kirillDanshin) +Felipe Oliveira (@felipeweb) +Bo-Yi Wu (@appleboy) +Cássio Botaro (@cassiobotaro) +Jessica Temporal (@jtemporal) +Ceriath (@ceriath) +Andy Pan (@panjf2000) +Phani Rithvij (@phanirithvij) diff --git a/README.md b/README.md index e3545f241e9..ba40551be46 100644 --- a/README.md +++ b/README.md @@ -1,889 +1,3778 @@ -# Awesome Go [![Build Status](https://travis-ci.org/avelino/awesome-go.svg?branch=master)](https://travis-ci.org/avelino/awesome-go) - - -A curated list of awesome Go frameworks, libraries and software. Inspired by [awesome-python](https://github.com/vinta/awesome-python). - - -### Contributing - -Please take a quick gander at the [contribution guidelines](https://github.com/avelino/awesome-go/blob/master/CONTRIBUTING.md) first. Thanks to all [contributors](https://github.com/avelino/awesome-go/graphs/contributors); you rock! - -Join us on IRC at **#awesome-go** on freenode [web access](http://webchat.freenode.net/?channels=awesome-go). - -#### *If you see a package or project here that is no longer maintained or is not a good fit, please submit a pull request to improve this file. Thank you!* - - -### Contents +# Awesome Go + +awesome-go + +[![Build Status](https://github.com/avelino/awesome-go/actions/workflows/tests.yaml/badge.svg?branch=main)](https://github.com/avelino/awesome-go/actions/workflows/tests.yaml?query=branch%3Amain) +[![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome) +[![Slack Widget](https://img.shields.io/badge/join-us%20on%20slack-gray.svg?longCache=true&logo=slack&colorB=red)](https://gophers.slack.com/messages/awesome) +[![Netlify Status](https://api.netlify.com/api/v1/badges/83a6dcbe-0da6-433e-b586-f68109286bd5/deploy-status)](https://app.netlify.com/sites/awesome-go/deploys) +[![Track Awesome List](https://www.trackawesomelist.com/badge.svg)](https://www.trackawesomelist.com/avelino/awesome-go/) +[![Last Commit](https://img.shields.io/github/last-commit/avelino/awesome-go)](https://img.shields.io/github/last-commit/avelino/awesome-go) + +We use the _[Golang Bridge](https://github.com/gobridge/about-us/blob/master/README.md)_ community Slack for instant communication, follow the [form here to join](https://invite.slack.golangbridge.org/). + +awesome-go - Curated list awesome Go frameworks, libraries and software | Product Hunt + +**Sponsorships:** + +_Special thanks to_ + + + +**Awesome Go has no monthly fee**_, but we have employees who **work hard** to keep it running. With money raised, we can repay the effort of each person involved! You can see how we calculate our billing and distribution as it is open to the entire community. Want to be a supporter of the project click [here](mailto:avelinorun+oss@gmail.com?subject=awesome-go%3A%20project%20support)._ + +> A curated list of awesome Go frameworks, libraries, and software. Inspired by [awesome-python](https://github.com/vinta/awesome-python). + +**Contributing:** + +Please take a quick gander at the [contribution guidelines](https://github.com/avelino/awesome-go/blob/main/CONTRIBUTING.md) first. Thanks to all [contributors](https://github.com/avelino/awesome-go/graphs/contributors); you rock! + +> _If you see a package or project here that is no longer maintained or is not a good fit, please submit a pull request to improve this file. Thank you!_ + +## Contents - [Awesome Go](#awesome-go) - - [Audio & Music](#audiomusic) - - [Authentication & OAuth](#authentication--oauth) - - [Command Line](#command-line) - - [Configuration](#configuration) - - [CSS Preprocessors](#css-preprocessors) - - [Database](#database) - - [Database Drivers](#database-drivers) - - [Date & Time](#date--time) - - [Distributed Systems](#distributed-systems) - - [Email](#email) - - [Embeddable Scripting Languages](#embeddable-scripting-languages) - - [Financial](#financial) - - [Forms](#forms) - - [Game Development](#game-development) - - [Generation & Generics](#generation--generics) - - [GUI](#gui) - - [Hardware](#hardware) - - [Images](#images) - - [Logging](#logging) - - [Machine Learning](#machine-learning) - - [Messaging](#messaging) - - [Miscellaneous](#miscellaneous) - - [Natural Language Processing](#natural-language-processing) - - [Networking](#networking) - - [OpenGL](#opengl) - - [ORM](#orm) - - [Package Management](#package-management) - - [Resource Embedding](#resource-embedding) - - [Science and Data Analysis](#science-and-data-analysis) - - [Serialization](#serialization) - - [Template Engines](#template-engines) - - [Testing](#testing) - - [Text Processing](#text-processing) - - [Third-party APIs](#third-party-apis) - - [Utilities](#utilities) - - [Validation](#validation) - - [Version Control](#version-control) - - [Video](#video) - - [Web Frameworks](#web-frameworks) - - [Middlewares](#middlewares) - - [Windows](#windows) - -- [Tools](#tools) - - [Code Analysis](#code-analysis) - - [Editor Plugins](#editor-plugins) - - [Software Packages](#software-packages) - - [DevOps Tools](#devops-tools) - - [Other Software](#other-software) - -- [Server Applications](#server-applications) - + - [Contents](#contents) + - [Actor Model](#actor-model) + - [Artificial Intelligence](#artificial-intelligence) + - [Audio and Music](#audio-and-music) + - [Authentication and OAuth](#authentication-and-oauth) + - [Blockchain](#blockchain) + - [Bot Building](#bot-building) + - [Build Automation](#build-automation) + - [Command Line](#command-line) + - [Advanced Console UIs](#advanced-console-uis) + - [Standard CLI](#standard-cli) + - [Configuration](#configuration) + - [Continuous Integration](#continuous-integration) + - [CSS Preprocessors](#css-preprocessors) + - [Data Integration Frameworks](#data-integration-frameworks) + - [Data Structures and Algorithms](#data-structures-and-algorithms) + - [Bit-packing and Compression](#bit-packing-and-compression) + - [Bit Sets](#bit-sets) + - [Bloom and Cuckoo Filters](#bloom-and-cuckoo-filters) + - [Data Structure and Algorithm Collections](#data-structure-and-algorithm-collections) + - [Iterators](#iterators) + - [Maps](#maps) + - [Miscellaneous Data Structures and Algorithms](#miscellaneous-data-structures-and-algorithms) + - [Nullable Types](#nullable-types) + - [Queues](#queues) + - [Sets](#sets) + - [Text Analysis](#text-analysis) + - [Trees](#trees) + - [Pipes](#pipes) + - [Database](#database) + - [Caches](#caches) + - [Databases Implemented in Go](#databases-implemented-in-go) + - [Database Schema Migration](#database-schema-migration) + - [Database Tools](#database-tools) + - [SQL Query Builders](#sql-query-builders) + - [Database Drivers](#database-drivers) + - [Interfaces to Multiple Backends](#interfaces-to-multiple-backends) + - [Relational Database Drivers](#relational-database-drivers) + - [NoSQL Database Drivers](#nosql-database-drivers) + - [Search and Analytic Databases](#search-and-analytic-databases) + - [Date and Time](#date-and-time) + - [Distributed Systems](#distributed-systems) + - [Dynamic DNS](#dynamic-dns) + - [Email](#email) + - [Embeddable Scripting Languages](#embeddable-scripting-languages) + - [Error Handling](#error-handling) + - [File Handling](#file-handling) + - [Financial](#financial) + - [Forms](#forms) + - [Functional](#functional) + - [Game Development](#game-development) + - [Generators](#generators) + - [Geographic](#geographic) + - [Go Compilers](#go-compilers) + - [Goroutines](#goroutines) + - [GUI](#gui) + - [Hardware](#hardware) + - [Images](#images) + - [IoT (Internet of Things)](#iot-internet-of-things) + - [Job Scheduler](#job-scheduler) + - [JSON](#json) + - [Logging](#logging) + - [Machine Learning](#machine-learning) + - [Messaging](#messaging) + - [Microsoft Office](#microsoft-office) + - [Microsoft Excel](#microsoft-excel) + - [Microsoft Word](#microsoft-word) + - [Miscellaneous](#miscellaneous) + - [Dependency Injection](#dependency-injection) + - [Project Layout](#project-layout) + - [Strings](#strings) + - [Uncategorized](#uncategorized) + - [Natural Language Processing](#natural-language-processing) + - [Language Detection](#language-detection) + - [Morphological Analyzers](#morphological-analyzers) + - [Slugifiers](#slugifiers) + - [Tokenizers](#tokenizers) + - [Translation](#translation) + - [Transliteration](#transliteration) + - [Networking](#networking) + - [HTTP Clients](#http-clients) + - [OpenGL](#opengl) + - [ORM](#orm) + - [Package Management](#package-management) + - [Performance](#performance) + - [Query Language](#query-language) + - [Reflection](#reflection) + - [Resource Embedding](#resource-embedding) + - [Science and Data Analysis](#science-and-data-analysis) + - [Security](#security) + - [Serialization](#serialization) + - [Server Applications](#server-applications) + - [Stream Processing](#stream-processing) + - [Template Engines](#template-engines) + - [Testing](#testing) + - [Testing Frameworks](#testing-frameworks) + - [Mock](#mock) + - [Fuzzing and delta-debugging/reducing/shrinking](#fuzzing-and-delta-debuggingreducingshrinking) + - [Selenium and browser control tools](#selenium-and-browser-control-tools) + - [Fail injection](#fail-injection) + - [Text Processing](#text-processing) + - [Formatters](#formatters) + - [Markup Languages](#markup-languages) + - [Parsers/Encoders/Decoders](#parsersencodersdecoders) + - [Regular Expressions](#regular-expressions) + - [Sanitation](#sanitation) + - [Scrapers](#scrapers) + - [RSS](#rss) + - [Utility/Miscellaneous](#utilitymiscellaneous) + - [Third-party APIs](#third-party-apis) + - [Utilities](#utilities) + - [UUID](#uuid) + - [Validation](#validation) + - [Version Control](#version-control) + - [Video](#video) + - [Web Frameworks](#web-frameworks) + - [Middlewares](#middlewares) + - [Actual middlewares](#actual-middlewares) + - [Libraries for creating HTTP middlewares](#libraries-for-creating-http-middlewares) + - [Routers](#routers) + - [WebAssembly](#webassembly) + - [Windows](#windows) + - [XML](#xml) + - [Zero Trust](#zero-trust) + - [Code Analysis](#code-analysis) + - [Editor Plugins](#editor-plugins) + - [Go Generate Tools](#go-generate-tools) + - [Go Tools](#go-tools) + - [Software Packages](#software-packages) + - [DevOps Tools](#devops-tools) + - [Other Software](#other-software) - [Resources](#resources) - - [Benchmarks](#benchmarks) - - [Conferences](#conferences) - - [E-Books](#e-books) + - [Benchmarks](#benchmarks) + - [Conferences](#conferences) + - [E-Books](#e-books) + - [E-books for purchase](#e-books-for-purchase) + - [Free e-books](#free-e-books) + - [Gophers](#gophers) + - [Meetups](#meetups) + - [Style Guides](#style-guides) + - [Social Media](#social-media) - [Twitter](#twitter) - - [Websites](#websites) - - [Tutorials](#tutorials) - - [Windows](#windows) - + - [Reddit](#reddit) + - [Websites](#websites) + - [Tutorials](#tutorials) + - [Guided Learning](#guided-learning) + +**[⬆ back to top](#contents)** + +## Actor Model + +_Libraries for building actor-based programs._ + +- [Ergo](https://github.com/ergo-services/ergo) - An actor-based Framework with network transparency for creating event-driven architecture in Golang. Inspired by Erlang. +- [Goakt](https://github.com/Tochemey/goakt) - Fast and Distributed Actor framework using protocol buffers as message for Golang. +- [Hollywood](https://github.com/anthdm/hollywood) - Blazingly fast and light-weight Actor engine written in Golang. +- [ProtoActor](https://github.com/asynkron/protoactor-go) - Proto Actor - Ultra fast distributed actors for Go, C# and Java/Kotlin. + +## Artificial Intelligence + +_Libraries for building programs that leverage AI._ + +- [chromem-go](https://github.com/philippgille/chromem-go) - Embeddable vector database for Go with Chroma-like interface and zero third-party dependencies. In-memory with optional persistence. +- [fun](https://gitlab.com/tozd/go/fun) - The simplest but powerful way to use large language models (LLMs) in Go. +- [langchaingo](https://github.com/tmc/langchaingo) - LangChainGo is a framework for developing applications powered by language models. +- [LocalAI](https://github.com/mudler/LocalAI) - Open Source OpenAI alternative, self-host AI models. +- [Ollama](https://github.com/jmorganca/ollama) - Run large language models locally. +- [OllamaFarm](https://github.com/presbrey/ollamafarm) - Manage, load-balance, and failover packs of Ollamas + +**[⬆ back to top](#contents)** + +## Audio and Music + +_Libraries for manipulating audio._ + +- [flac](https://github.com/mewkiz/flac) - Native Go FLAC encoder/decoder with support for FLAC streams. +- [gaad](https://github.com/Comcast/gaad) - Native Go AAC bitstream parser. +- [GoAudio](https://github.com/DylanMeeus/GoAudio) - Native Go Audio Processing Library. +- [gosamplerate](https://github.com/dh1tw/gosamplerate) - libsamplerate bindings for go. +- [id3v2](https://github.com/bogem/id3v2) - ID3 decoding and encoding library for Go. +- [malgo](https://github.com/gen2brain/malgo) - Mini audio library. +- [minimp3](https://github.com/tosone/minimp3) - Lightweight MP3 decoder library. +- [Oto](https://github.com/hajimehoshi/oto) - A low-level library to play sound on multiple platforms. +- [PortAudio](https://github.com/gordonklaus/portaudio) - Go bindings for the PortAudio audio I/O library. + +**[⬆ back to top](#contents)** + +## Authentication and OAuth + +_Libraries for implementing authentication schemes._ + +- [authboss](https://github.com/volatiletech/authboss) - Modular authentication system for the web. It tries to remove as much boilerplate and "hard things" as possible so that each time you start a new web project in Go, you can plug it in, configure it, and start building your app without having to build an authentication system each time. +- [branca](https://github.com/essentialkaos/branca) - branca token [specification implementation](https://github.com/tuupola/branca-spec) for Golang 1.15+. +- [casbin](https://github.com/hsluoyz/casbin) - Authorization library that supports access control models like ACL, RBAC, and ABAC. +- [cookiestxt](https://github.com/mengzhuo/cookiestxt) - provides a parser of cookies.txt file format. +- [go-guardian](https://github.com/shaj13/go-guardian) - Go-Guardian is a golang library that provides a simple, clean, and idiomatic way to create powerful modern API and web authentication that supports LDAP, Basic, Bearer token, and Certificate based authentication. +- [go-jose](https://github.com/go-jose/go-jose) - Fairly complete implementation of the JOSE working group's JSON Web Token, JSON Web Signatures, and JSON Web Encryption specs. +- [gologin](https://github.com/dghubble/gologin) - chainable handlers for login with OAuth1 and OAuth2 authentication providers. +- [gorbac](https://github.com/mikespook/gorbac) - provides a lightweight role-based access control (RBAC) implementation in Golang. +- [gosession](http://github.com/Kwynto/gosession) - This is quick session for net/http in GoLang. This package is perhaps the best implementation of the session mechanism, or at least it tries to become one. +- [goth](https://github.com/markbates/goth) - provides a simple, clean, and idiomatic way to use OAuth and OAuth2. Handles multiple providers out of the box. +- [jeff](https://github.com/abraithwaite/jeff) - Simple, flexible, secure, and idiomatic web session management with pluggable backends. +- [jwt](https://github.com/pascaldekloe/jwt) - Lightweight JSON Web Token (JWT) library. +- [jwt](https://github.com/cristalhq/jwt) - Safe, simple, and fast JSON Web Tokens for Go. +- [jwt-auth](https://github.com/adam-hanna/jwt-auth) - JWT middleware for Golang http servers with many configuration options. +- [jwt-go](https://github.com/golang-jwt/jwt) - A full featured implementation of JSON Web Tokens (JWT). This library supports the parsing and verification as well as the generation and signing of JWTs. +- [jwx](https://github.com/lestrrat-go/jwx) - Go module implementing various JWx (JWA/JWE/JWK/JWS/JWT, otherwise known as JOSE) technologies +- [keto](https://github.com/ory/keto) - Open Source (Go) implementation of "Zanzibar: Google's Consistent, Global Authorization System". Ships gRPC, REST APIs, newSQL, and an easy and granular permission language. Supports ACL, RBAC, and other access models. +- [loginsrv](https://github.com/tarent/loginsrv) - JWT login microservice with pluggable backends such as OAuth2 (Github), htpasswd, osiam. +- [oauth2](https://github.com/golang/oauth2) - Successor of goauth2. Generic OAuth 2.0 package that comes with JWT, Google APIs, Compute Engine, and App Engine support. +- [oidc](https://github.com/zitadel/oidc) - Easy to use OpenID Connect client and server library written for Go and certified by the OpenID Foundation +- [openfga](https://github.com/openfga/openfga) - Implementation of fine-grained authorization based on the "Zanzibar: Google's Consistent, Global Authorization System" paper. Backed by [CNCF](https://www.cncf.io/). +- [osin](https://github.com/openshift/osin) - Golang OAuth2 server library. +- [otpgen](https://github.com/grijul/otpgen) - Library to generate TOTP/HOTP codes. +- [otpgo](https://github.com/jltorresm/otpgo) - Time-Based One-Time Password (TOTP) and HMAC-Based One-Time Password (HOTP) library for Go. +- [paseto](https://github.com/o1egl/paseto) - Golang implementation of Platform-Agnostic Security Tokens (PASETO). +- [permissions2](https://github.com/xyproto/permissions2) - Library for keeping track of users, login states, and permissions. Uses secure cookies and bcrypt. +- [scope](https://github.com/SonicRoshan/scope) - Easily Manage OAuth2 Scopes In Go. +- [scs](https://github.com/alexedwards/scs) - Session Manager for HTTP servers. +- [securecookie](https://github.com/chmike/securecookie) - Efficient secure cookie encoding/decoding. +- [session](https://github.com/icza/session) - Go session management for web servers (including support for Google App Engine - GAE). +- [sessions](https://github.com/adam-hanna/sessions) - Dead simple, highly performant, highly customizable sessions service for go http servers. +- [sessionup](https://github.com/swithek/sessionup) - Simple, yet effective HTTP session management and identification package. +- [sjwt](https://github.com/brianvoe/sjwt) - Simple jwt generator and parser. + +**[⬆ back to top](#contents)** + +## Blockchain + +_Tools for building blockchains._ + +- [cometbft](https://github.com/cometbft/cometbft) - A distributed, Byzantine fault-tolerant, deterministic state machine replication engine. It is a fork of Tendermint Core and implements the Tendermint consensus algorithm. +- [cosmos-sdk](https://github.com/cosmos/cosmos-sdk) - A Framework for Building Public Blockchains in the Cosmos Ecosystem. +- [gno](https://github.com/gnolang/gno) - A comprehensive smart contract suite built with Golang and Gnolang, a deterministic, purpose-built Go variant for blockchains. +- [go-ethereum](https://github.com/ethereum/go-ethereum) - Official Go implementation of the Ethereum protocol. +- [gosemble](https://github.com/LimeChain/gosemble) - A Go-based framework for building Polkadot/Substrate-compatible runtimes. +- [gossamer](https://github.com/ChainSafe/gossamer) - A Go implementation of the Polkadot Host. +- [kubo](https://github.com/ipfs/kubo) - A blockchain framework implemented in Go. It provides content-addressable storage which can be used for decentralized storage in DApps. It is based on the IPFS protocol. +- [lnd](https://github.com/lightningnetwork/lnd) - A complete implementation of a Lighting Network node. +- [solana-go](https://github.com/gagliardetto/solana-go) - Go library to interface with Solana JSON RPC and WebSocket interfaces. +- [tendermint](https://github.com/tendermint/tendermint) - High-performance middleware for transforming a state machine written in any programming language into a Byzantine Fault Tolerant replicated state machine using the Tendermint consensus and blockchain protocols. + +**[⬆ back to top](#contents)** + +## Bot Building + +_Libraries for building and working with bots._ + +- [bot](https://github.com/go-telegram/bot) - Zero-dependencies Telegram Bot library with additional UI components +- [echotron](https://github.com/NicoNex/echotron) - An elegant and concurrent library for Telegram Bots in Go. +- [ephemeral-roles](https://github.com/ewohltman/ephemeral-roles) - A Discord bot for managing ephemeral roles based upon voice channel member presence. +- [go-chat-bot](https://github.com/go-chat-bot/bot) - IRC, Slack & Telegram bot written in Go. +- [go-joe](https://joe-bot.net) - A general-purpose bot library inspired by Hubot but written in Go. +- [go-sarah](https://github.com/oklahomer/go-sarah) - Framework to build a bot for desired chat services including LINE, Slack, Gitter, and more. +- [go-tg](https://github.com/mr-linch/go-tg) - Generated from official docs Go client library for accessing Telegram Bot API, with batteries for building complex bots included. +- [go-tgbot](https://github.com/olebedev/go-tgbot) - Pure Golang Telegram Bot API wrapper, generated from swagger file, session-based router, and middleware. +- [go-twitch-irc](https://github.com/gempir/go-twitch-irc) - Library to write bots for twitch.tv chat +- [Golang CryptoTrading Bot](https://github.com/saniales/golang-crypto-trading-bot) - A golang implementation of a console-based trading bot for cryptocurrency exchanges. +- [govkbot](https://github.com/nikepan/govkbot) - Simple Go [VK](https://vk.com) bot library. +- [hanu](https://github.com/sbstjn/hanu) - Framework for writing Slack bots. +- [Kelp](https://github.com/stellar/kelp) - official trading and market-making bot for the [Stellar](https://www.stellar.org/) DEX. Works out-of-the-box, written in Golang, compatible with centralized exchanges and custom trading strategies. +- [larry](https://github.com/ezeoleaf/larry) - Larry 🐦 is a really simple Twitter bot generator that tweets random repositories from Github built in Go. +- [margelet](https://github.com/zhulik/margelet) - Framework for building Telegram bots. +- [micha](https://github.com/onrik/micha) - Go Library for Telegram bot api. +- [olivia](https://github.com/olivia-ai/olivia) - A chatbot built with an artificial neural network. +- [slack-bot](https://github.com/innogames/slack-bot) - Ready to use Slack Bot for lazy developers: Custom commands, Jenkins, Jira, Bitbucket, Github... +- [slacker](https://github.com/slack-io/slacker) - Easy to use framework to create Slack bots. +- [slackscot](https://github.com/alexandre-normand/slackscot) - Another framework for building Slack bots. +- [tbot](https://github.com/yanzay/tbot) - Telegram bot server with API similar to net/http. +- [telebot](https://github.com/tucnak/telebot) - Telegram bot framework is written in Go. +- [telego](https://github.com/mymmrac/telego) - Telegram Bot API library for Golang with full one-to-one API implementation. +- [telegram-bot-api](https://github.com/Syfaro/telegram-bot-api) - Simple and clean Telegram bot client. +- [teleterm](https://github.com/alfiankan/teleterm) - Telegram Bot Exec Terminal Command. +- [Tenyks](https://github.com/kyleterry/tenyks) - Service oriented IRC bot using Redis and JSON for messaging. +- [wayback](https://github.com/wabarc/wayback) - A bot for Telegram, Mastodon, Slack, and other messaging platforms archives webpages. + +**[⬆ back to top](#contents)** + +## Build Automation + +_Libraries and tools help with build automation._ + +- [1build](https://github.com/gopinath-langote/1build) - Command line tool to frictionlessly manage project-specific commands. +- [air](https://github.com/cosmtrek/air) - Air - Live reload for Go apps. +- [anko](https://github.com/GuilhermeCaruso/anko) - Simple application watcher for multiple programming languages. +- [gaper](https://github.com/maxcnunes/gaper) - Builds and restarts a Go project when it crashes or some watched file changes. +- [gilbert](https://go-gilbert.github.io) - Build system and task runner for Go projects. +- [gob](https://github.com/kcmvp/gob) - [Gradle](https://docs.gradle.org/)/[Maven](https://maven.apache.org/) like build tool for Go projects. +- [goyek](https://github.com/goyek/goyek) - Create build pipelines in Go. +- [mage](https://github.com/magefile/mage) - Mage is a make/rake-like build tool using Go. +- [mmake](https://github.com/tj/mmake) - Modern Make. +- [realize](https://github.com/tockins/realize) - Go build a system with file watchers and live to reload. Run, build and watch file changes with custom paths. +- [Task](https://github.com/go-task/task) - simple "Make" alternative. +- [taskctl](https://github.com/taskctl/taskctl) - Concurrent task runner. +- [xc](https://github.com/joerdav/xc) - Task runner with README.md defined tasks, executable markdown. + +**[⬆ back to top](#contents)** -## Audio/Music +## Command Line -*Libraries for manipulating audio.* +### Advanced Console UIs -* [flac](https://github.com/eaburns/flac) - A native Go FLAC decoder. -* [go-sox](https://github.com/krig/go-sox) - libsox bindings for go. -* [PortAudio](https://code.google.com/p/portaudio-go/) - Go bindings for the PortAudio audio I/O library. -* [portmidi](https://github.com/rakyll/portmidi) - Go bindings for PortMidi. -* [taglib](https://github.com/wtolson/go-taglib) - Go bindings for taglib. -* [vorbis](https://github.com/mccoyst/vorbis) - A "native" Go Vorbis decoder (uses CGO, but has no dependencies). -* [waveform](https://github.com/mdlayher/waveform) - Go package capable of generating waveform images from audio streams. +_Libraries for building Console Applications and Console User Interfaces._ + +- [asciigraph](https://github.com/guptarohit/asciigraph) - Go package to make lightweight ASCII line graph ╭┈╯ in command line apps with no other dependencies. +- [aurora](https://github.com/logrusorgru/aurora) - ANSI terminal colors that support fmt.Printf/Sprintf. +- [box-cli-maker](https://github.com/Delta456/box-cli-maker) - Make Highly Customized Boxes for your CLI. +- [bubble-table](https://github.com/Evertras/bubble-table) - An interactive table component for bubbletea. +- [bubbles](https://github.com/charmbracelet/bubbles) - TUI components for bubbletea. +- [bubbletea](https://github.com/charmbracelet/bubbletea) - Go framework to build terminal apps, based on The Elm Architecture. +- [cfmt](https://github.com/mingrammer/cfmt) - Contextual fmt inspired by bootstrap color classes. +- [cfmt](https://github.com/i582/cfmt) - Simple and convenient formatted stylized output fully compatible with fmt library. +- [chalk](https://github.com/ttacon/chalk) - Intuitive package for prettifying terminal/console output. +- [colourize](https://github.com/TreyBastian/colourize) - Go library for ANSI colour text in terminals. +- [crab-config-files-templating](https://github.com/alfiankan/crab-config-files-templating) - Dynamic configuration file templating tool for kubernetes manifest or general configuration files. +- [ctc](https://github.com/wzshiming/ctc) - The non-invasive cross-platform terminal color library does not need to modify the Print method. +- [go-ataman](https://github.com/workanator/go-ataman) - Go library for rendering ANSI colored text templates in terminals. +- [go-colorable](https://github.com/mattn/go-colorable) - Colorable writer for windows. +- [go-colortext](https://github.com/daviddengcn/go-colortext) - Go library for color output in terminals. +- [go-isatty](https://github.com/mattn/go-isatty) - isatty for golang. +- [go-palette](https://github.com/abusomani/go-palette) - Go library that provides elegant and convenient style definitions using ANSI colors. Fully compatible & wraps the [fmt library](https://pkg.go.dev/fmt) for nice terminal layouts. +- [go-prompt](https://github.com/c-bata/go-prompt) - Library for building a powerful interactive prompt, inspired by [python-prompt-toolkit](https://github.com/jonathanslenders/python-prompt-toolkit). +- [gocui](https://github.com/jroimartin/gocui) - Minimalist Go library aimed at creating Console User Interfaces. +- [gommon/color](https://github.com/labstack/gommon/tree/master/color) - Style terminal text. +- [gookit/color](https://github.com/gookit/color) - Terminal color rendering tool library, support 16 colors, 256 colors, RGB color rendering output, compatible with Windows. +- [lipgloss](https://github.com/charmbracelet/lipgloss) - Declaratively define styles for color, format and layout in the terminal. +- [marker](https://github.com/cyucelen/marker) - Easiest way to match and mark strings for colorful terminal outputs. +- [mpb](https://github.com/vbauerster/mpb) - Multi progress bar for terminal applications. +- [progressbar](https://github.com/schollz/progressbar) - Basic thread-safe progress bar that works in every OS. +- [pterm](https://github.com/pterm/pterm) - A library to beautify console output on every platform with many combinable components. +- [simpletable](https://github.com/alexeyco/simpletable) - Simple tables in a terminal with Go. +- [spinner](https://github.com/briandowns/spinner) - Go package to easily provide a terminal spinner with options. +- [tabby](https://github.com/cheynewallace/tabby) - A tiny library for super simple Golang tables. +- [table](https://github.com/tomlazar/table) - Small library for terminal color based tables. +- [tabular](https://github.com/InVisionApp/tabular) - Print ASCII tables from command line utilities without the need to pass large sets of data to the API. +- [termbox-go](https://github.com/nsf/termbox-go) - Termbox is a library for creating cross-platform text-based interfaces. +- [termdash](https://github.com/mum4k/termdash) - Go terminal dashboard based on **termbox-go** and inspired by [termui](https://github.com/gizak/termui). +- [termenv](https://github.com/muesli/termenv) - Advanced ANSI style & color support for your terminal applications. +- [termui](https://github.com/gizak/termui) - Go terminal dashboard based on **termbox-go** and inspired by [blessed-contrib](https://github.com/yaronn/blessed-contrib). +- [uilive](https://github.com/gosuri/uilive) - Library for updating terminal output in real time. +- [uiprogress](https://github.com/gosuri/uiprogress) - Flexible library to render progress bars in terminal applications. +- [uitable](https://github.com/gosuri/uitable) - Library to improve readability in terminal apps using tabular data. +- [yacspin](https://github.com/theckman/yacspin) - Yet Another CLi Spinner package, for working with terminal spinners. + +**[⬆ back to top](#contents)** +### Standard CLI -## Authentication & OAuth +_Libraries for building standard or basic Command Line applications._ + +- [acmd](https://github.com/cristalhq/acmd) - Simple, useful, and opinionated CLI package in Go. +- [argparse](https://github.com/akamensky/argparse) - Command line argument parser inspired by Python's argparse module. +- [argv](https://github.com/cosiner/argv) - Go library to split command line string as arguments array using the bash syntax. +- [carapace](https://github.com/rsteube/carapace) - Command argument completion generator for spf13/cobra. +- [carapace-bin](https://github.com/rsteube/carapace-bin) - Multi-shell multi-command argument completer. +- [carapace-spec](https://github.com/rsteube/carapace-spec) - Define simple completions using a spec file. +- [climax](https://github.com/tucnak/climax) - Alternative CLI with "human face", in spirit of Go command. +- [clîr](https://github.com/leaanthony/clir) - A Simple and Clear CLI library. Dependency free. +- [cmd](https://github.com/posener/cmd) - Extends the standard `flag` package to support sub commands and more in idiomatic way. +- [cmdr](https://github.com/hedzr/cmdr) - A POSIX/GNU style, getopt-like command-line UI Go library. +- [cobra](https://github.com/spf13/cobra) - Commander for modern Go CLI interactions. +- [command-chain](https://github.com/rainu/go-command-chain) - A go library for configure and run command chains - such as pipelining in unix shells. +- [commandeer](https://github.com/jaffee/commandeer) - Dev-friendly CLI apps: sets up flags, defaults, and usage based on struct fields and tags. +- [complete](https://github.com/posener/complete) - Write bash completions in Go + Go command bash completion. +- [Dnote](https://github.com/dnote/dnote) - A simple command line notebook with multi-device sync. +- [elvish](https://github.com/elves/elvish) - An expressive programming language and a versatile interactive shell. +- [env](https://github.com/codingconcepts/env) - Tag-based environment configuration for structs. +- [flag](https://github.com/cosiner/flag) - Simple but powerful command line option parsing library for Go supporting subcommand. +- [flaggy](https://github.com/integrii/flaggy) - A robust and idiomatic flags package with excellent subcommand support. +- [flagvar](https://github.com/sgreben/flagvar) - A collection of flag argument types for Go's standard `flag` package. +- [go-andotp](https://github.com/grijul/go-andotp) - A CLI program to encrypt/decrypt [andOTP](https://github.com/andOTP/andOTP) files. Can be used as a library as well. +- [go-arg](https://github.com/alexflint/go-arg) - Struct-based argument parsing in Go. +- [go-commander](https://github.com/yitsushi/go-commander) - Go library to simplify CLI workflow. +- [go-flags](https://github.com/jessevdk/go-flags) - go command line option parser. +- [go-getoptions](https://github.com/DavidGamba/go-getoptions) - Go option parser inspired by the flexibility of Perl’s GetOpt::Long. +- [gocmd](https://github.com/devfacet/gocmd) - Go library for building command line applications. +- [hiboot cli](https://github.com/hidevopsio/hiboot/tree/master/pkg/app/cli) - cli application framework with auto configuration and dependency injection. +- [job](https://github.com/liujianping/job) - JOB, make your short-term command as a long-term job. +- [kingpin](https://github.com/alecthomas/kingpin) - Command line and flag parser supporting sub commands (superseded by `kong`; see below). +- [liner](https://github.com/peterh/liner) - Go readline-like library for command-line interfaces. +- [mcli](https://github.com/jxskiss/mcli) - A minimal but very powerful cli library for Go. +- [mitchellh/cli](https://github.com/mitchellh/cli) - Go library for implementing command-line interfaces. +- [mkideal/cli](https://github.com/mkideal/cli) - Feature-rich and easy to use command-line package based on golang struct tags. +- [mow.cli](https://github.com/jawher/mow.cli) - Go library for building CLI applications with sophisticated flag and argument parsing and validation. +- [ops](https://github.com/nanovms/ops) - Unikernel Builder/Orchestrator. +- [pflag](https://github.com/spf13/pflag) - Drop-in replacement for Go's flag package, implementing POSIX/GNU-style --flags. +- [readline](https://github.com/reeflective/readline) Shell library with modern and easy to use UI features. +- [sand](https://github.com/Zaba505/sand) - Simple API for creating interpreters and so much more. +- [sflags](https://github.com/octago/sflags) - Struct based flags generator for flag, urfave/cli, pflag, cobra, kingpin, and other libraries. +- [strumt](https://github.com/antham/strumt) - Library to create prompt chain. +- [subcmd](https://github.com/bobg/subcmd) - Another approach to parsing and running subcommands. Works alongside the standard `flag` package. +- [survey](https://github.com/go-survey/survey) - Build interactive and accessible prompts with full support for windows and posix terminals. +- [teris-io/cli](https://github.com/teris-io/cli) - Simple and complete API for building command line interfaces in Go. +- [ts](https://github.com/liujianping/ts) - Timestamp convert & compare tool. +- [ukautz/clif](https://github.com/ukautz/clif) - Small command line interface framework. +- [urfave/cli](https://github.com/urfave/cli) - Simple, fast, and fun package for building command line apps in Go (formerly codegangsta/cli). +- [version](https://github.com/mszostok/version) - Collects and displays CLI version information in multiple formats along with upgrade notice. +- [wlog](https://github.com/dixonwille/wlog) - Simple logging interface that supports cross-platform color and concurrency. +- [wmenu](https://github.com/dixonwille/wmenu) - Easy to use menu structure for cli applications that prompt users to make choices. + +**[⬆ back to top](#contents)** -*Libraries for implementing authentications schemes.* +## Configuration -* [Go-AWS-Auth](https://github.com/smartystreets/go-aws-auth) - AWS (Amazon Web Services) request signing library. -* [go-jose](https://github.com/square/go-jose) - A fairly complete implementation of the JOSE working group's JSON Web Token, JSON Web Signatures, and JSON Web Encryption specs. -* [go.auth](https://github.com/bradrydzewski/go.auth) - Authentication API for Go web applications. -* [gorbac](https://github.com/mikespook/gorbac) - provides a lightweight role-based access control (RBAC) implementation in Golang. -* [httpauth](https://github.com/goji/httpauth) - HTTP Authentication middleware. -* [jwt-go](https://github.com/dgrijalva/jwt-go) - Golang implementation of JSON Web Tokens (JWT). -* [oauth2](https://github.com/golang/oauth2) - Successor of goauth2. Generic OAuth 2.0 package that comes with JWT, Google APIs, Compute Engine and App Engine support. -* [osin](https://github.com/RangelReale/osin) - Golang OAuth2 server library. -* [permissions2](https://github.com/xyproto/permissions2) - Library for keeping track of users, login states and permissions. Uses secure cookies and bcrypt. +_Libraries for configuration parsing._ + +- [aconfig](https://github.com/cristalhq/aconfig) - Simple, useful and opinionated config loader. +- [bcl](https://github.com/wkhere/bcl) - BCL is a configuration language similar to HCL. +- [cleanenv](https://github.com/ilyakaznacheev/cleanenv) - Minimalistic configuration reader (from files, ENV, and wherever you want). +- [config](https://github.com/JeremyLoy/config) - Cloud native application configuration. Bind ENV to structs in only two lines. +- [config](https://github.com/num30/config) - configure your app using file, environment variables, or flags in two lines of code +- [configuration](https://github.com/BoRuDar/configuration) - Library for initializing configuration structs from env variables, files, flags and 'default' tag. +- [configure](https://github.com/paked/configure) - Provides configuration through multiple sources, including JSON, flags and environment variables. +- [configuro](https://github.com/sherifabdlnaby/configuro) - opinionated configuration loading & validation framework from ENV and Files focused towards 12-Factor compliant applications. +- [confiq](https://github.com/greencoda/confiq) - Structured data format to config struct decoder library for Go - supporting multiple data formats +- [confita](https://github.com/heetch/confita) - Load configuration in cascade from multiple backends into a struct. +- [conflate](https://github.com/the4thamigo-uk/conflate) - Library/tool to merge multiple JSON/YAML/TOML files from arbitrary URLs, validation against a JSON schema, and application of default values defined in the schema. +- [env](https://github.com/caarlos0/env) - Parse environment variables to Go structs (with defaults). +- [env](https://github.com/junk1tm/env) - A lightweight package for loading environment variables into structs. +- [env](https://github.com/syntaqx/env) - An environment utility package with support for unmarshaling into structs +- [envconfig](https://github.com/vrischmann/envconfig) - Read your configuration from environment variables. +- [envh](https://github.com/antham/envh) - Helpers to manage environment variables. +- [fig](https://github.com/kkyr/fig) - Tiny library for reading configuration from a file and from environment variables (with validation & defaults). +- [genv](https://github.com/sakirsensoy/genv) - Read environment variables easily with dotenv support. +- [go-array](https://github.com/deatil/go-array) - A Go package that read or set data from map, slice or json. +- [go-aws-ssm](https://github.com/PaddleHQ/go-aws-ssm) - Go package that fetches parameters from AWS System Manager - Parameter Store. +- [go-cfg](https://github.com/dsbasko/go-cfg) - The library provides a unified way to read configuration data into a structure from various sources, such as env, flags, and configuration files (.json, .yaml, .toml, .env). +- [go-conf](https://github.com/ThomasObenaus/go-conf) - Simple library for application configuration based on annotated structs. It supports reading the configuration from environment variables, config files and command line parameters. +- [go-ini](https://github.com/subpop/go-ini) - A Go package that marshals and unmarshals INI-files. +- [go-ssm-config](https://github.com/ianlopshire/go-ssm-config) - Go utility for loading configuration parameters from AWS SSM (Parameter Store). +- [go-up](https://github.com/ufoscout/go-up) - A simple configuration library with recursive placeholders resolution and no magic. +- [GoCfg](https://github.com/Jagerente/gocfg) - Config manager with Struct Tags based contracts, custom value providers, parsers, and documentation generation. Customizable yet simple. +- [goConfig](https://github.com/crgimenes/goConfig) - Parses a struct as input and populates the fields of this struct with parameters from command line, environment variables and configuration file. +- [godotenv](https://github.com/joho/godotenv) - Go port of Ruby's dotenv library (Loads environment variables from `.env`). +- [gofigure](https://github.com/ian-kent/gofigure) - Go application configuration made easy. +- [GoLobby/Config](https://github.com/golobby/config) - GoLobby Config is a lightweight yet powerful configuration manager for the Go programming language. +- [gone/jconf](https://github.com/One-com/gone/tree/master/jconf) - Modular JSON configuration. Keep your config structs along with the code they configure and delegate parsing to submodules without sacrificing full config serialization. +- [gonfig](https://github.com/milad-abbasi/gonfig) - Tag-based configuration parser which loads values from different providers into typesafe struct. +- [gookit/config](https://github.com/gookit/config) - application config manage(load,get,set). support JSON, YAML, TOML, INI, HCL. multi file load, data override merge. +- [harvester](https://github.com/beatlabs/harvester) - Harvester, an easy to use static and dynamic configuration package supporting seeding, env vars and Consul integration. +- [hjson](https://github.com/hjson/hjson-go) - Human JSON, a configuration file format for humans. Relaxed syntax, fewer mistakes, more comments. +- [hocon](https://github.com/gurkankaymak/hocon) - Configuration library for working with the HOCON(a human-friendly JSON superset) format, supports features like environment variables, referencing other values, comments and multiple files. +- [ingo](https://github.com/schachmat/ingo) - Flags persisted in an ini-like config file. +- [ini](https://github.com/go-ini/ini) - Go package to read and write INI files. +- [ini](https://github.com/wlevene/ini) - INI Parser & Write Library, Unmarshal to Struct, Marshal to Json, Write File, watch file. +- [joshbetz/config](https://github.com/joshbetz/config) - Small configuration library for Go that parses environment variables, JSON files, and reloads automatically on SIGHUP. +- [kelseyhightower/envconfig](https://github.com/kelseyhightower/envconfig) - Go library for managing configuration data from environment variables. +- [koanf](https://github.com/knadh/koanf) - Light weight, extensible library for reading config in Go applications. Built in support for JSON, TOML, YAML, env, command line. +- [konf](https://github.com/nil-go/konf) - The simplest API for reading/watching config from file, env, flag and clouds (e.g. AWS, Azure, GCP). +- [konfig](https://github.com/lalamove/konfig) - Composable, observable and performant config handling for Go for the distributed processing era. +- [kong](https://github.com/alecthomas/kong) - Command-line parser with support for arbitrarily complex command-line structures and additional sources of configuration such as YAML, JSON, TOML, etc (successor to `kingpin`). +- [mini](https://github.com/sasbury/mini) - Golang package for parsing ini-style configuration files. +- [nasermirzaei89/env](https://github.com/nasermirzaei89/env) - Simple useful package for read environment variables. +- [nfigure](https://github.com/muir/nfigure) - Per-library struct-tag based configuration from command lines (Posix & Go-style); environment, JSON, YAML +- [onion](https://github.com/goraz/onion) - Layer based configuration for Go, Supports JSON, TOML, YAML, properties, etcd, env, and encryption using PGP. +- [piper](https://github.com/Yiling-J/piper) - Viper wrapper with config inheritance and key generation. +- [sonic](https://github.com/bytedance/sonic) - A blazingly fast JSON serializing & deserializing library. +- [store](https://github.com/tucnak/store) - Lightweight configuration manager for Go. +- [swap](https://github.com/oblq/swap) - Instantiate/configure structs recursively, based on build environment. (YAML, TOML, JSON and env). +- [typenv](https://github.com/diegomarangoni/typenv) - Minimalistic, zero dependency, typed environment variables library. +- [uConfig](https://github.com/omeid/uconfig) - Lightweight, zero-dependency, and extendable configuration management. +- [viper](https://github.com/spf13/viper) - Go configuration with fangs. +- [xdg](https://github.com/adrg/xdg) - Go implementation of the [XDG Base Directory Specification](https://specifications.freedesktop.org/basedir-spec/latest/) and [XDG user directories](https://wiki.archlinux.org/index.php/XDG_user_directories). +- [xdg](https://github.com/OpenPeeDeeP/xdg) - Cross platform package that follows the [XDG Standard](https://specifications.freedesktop.org/basedir-spec/latest/). +- [yamagiconf](https://github.com/romshark/yamagiconf) - The "safe subset" of YAML for Go configs. + +**[⬆ back to top](#contents)** + +## Continuous Integration + +_Tools for help with continuous integration._ + +- [abstruse](https://github.com/bleenco/abstruse) - Abstruse is a distributed CI platform. +- [Bencher](https://bencher.dev/) - A suite of continuous benchmarking tools designed to catch performance regressions in CI. +- [CDS](https://github.com/ovh/cds) - Enterprise-Grade CI/CD and DevOps Automation Open Source Platform. +- [dot](https://github.com/opnlabs/dot) - A minimal, local first continuous integration system that uses Docker to run jobs concurrently in stages. +- [drone](https://github.com/drone/drone) - Drone is a Continuous Integration platform built on Docker, written in Go. +- [go-beautiful-html-coverage](https://github.com/gha-common/go-beautiful-html-coverage) - A GitHub Action to track code coverage in your pull requests, with a beautiful HTML preview, for free. +- [go-fuzz-action](https://github.com/jidicula/go-fuzz-action) - Use Go 1.18's built-in fuzz testing in GitHub Actions. +- [go-semver-release](https://github.com/s0ders/go-semver-release) - Automate the semantic versioning of Git repositories. +- [go-test-coverage](https://github.com/vladopajic/go-test-coverage) - Tool and GitHub action which reports issues when test coverage is below set threshold. +- [gomason](https://github.com/nikogura/gomason) - Test, Build, Sign, and Publish your go binaries from a clean workspace. +- [gotestfmt](https://github.com/GoTestTools/gotestfmt) - go test output for humans. +- [goveralls](https://github.com/mattn/goveralls) - Go integration for Coveralls.io continuous code coverage tracking system. +- [muffet](https://github.com/raviqqe/muffet) - Fast website link checker in Go, see [alternatives](https://github.com/lycheeverse/lychee#features). +- [overalls](https://github.com/go-playground/overalls) - Multi-Package go project coverprofile for tools like goveralls. +- [roveralls](https://github.com/LawrenceWoodman/roveralls) - Recursive coverage testing tool. +- [woodpecker](https://github.com/woodpecker-ci/woodpecker) - Woodpecker is a community fork of the Drone CI system. + +**[⬆ back to top](#contents)** +## CSS Preprocessors -## Command Line +_Libraries for preprocessing CSS files._ +- [gcss](https://github.com/yosssi/gcss) - Pure Go CSS Preprocessor. +- [go-libsass](https://github.com/wellington/go-libsass) - Go wrapper to the 100% Sass compatible libsass project. -### Standard CLI +**[⬆ back to top](#contents)** -*Libraries for building standard or basic Command Line applications* +## Data Integration Frameworks -* [cli](https://github.com/codegangsta/cli) - A small package for building command line apps in Go. -* [cli-init](https://github.com/tcnksm/cli-init) - The easy way to start building Golang command line application. +_Frameworks for performing ELT / ETL_ +- [Benthos](https://github.com/benthosdev/benthos) - A message streaming bridge between a range of protocols. +- [CloudQuery](http://github.com/cloudquery/cloudquery) - A high-performance ELT data integration framework with pluggable architecture. +- [omniparser](https://github.com/jf-tech/omniparser) - A versatile ETL library that parses text input (CSV/txt/JSON/XML/EDI/X12/EDIFACT/etc) in streaming fashion and transforms data into JSON output using data-driven schema. -### Advanced Console UIs +**[⬆ back to top](#contents)** -*Libraries for building Console Applications and Console User Interfaces* +## Data Structures and Algorithms -* [chalk](https://github.com/ttacon/chalk) - Intuitive package for prettifying terminal/console output. -* [color](https://github.com/fatih/color) - Versatile package for colored terminal output. -* [go-colortext](https://github.com/daviddengcn/go-colortext) - Go library for color output in terminals. -* [gocui](https://github.com/jroimartin/gocui) - Minimalist Go library aimed at creating Console User Interfaces. -* [gommon/color](https://github.com/labstack/gommon/tree/master/color) - Style terminal text. -* [termbox-go](https://github.com/nsf/termbox-go) - Termbox is a library for creating cross-platform text-based interfaces. -* [termui](https://github.com/gizak/termui) - Go terminal dashboard based on [termbox-go](https://github.com/nsf/termbox-go) and inspired by [blessed-contrib](https://github.com/yaronn/blessed-contrib). +### Bit-packing and Compression +- [bingo](https://github.com/iancmcc/bingo) - Fast, zero-allocation, lexicographical-order-preserving packing of native types to bytes. +- [binpacker](https://github.com/zhuangsirui/binpacker) - Binary packer and unpacker helps user build custom binary stream. +- [bit](https://github.com/yourbasic/bit) - Golang set data structure with bonus bit-twiddling functions. +- [crunch](https://github.com/superwhiskers/crunch) - Go package implementing buffers for handling various datatypes easily. +- [go-ef](https://github.com/amallia/go-ef) - A Go implementation of the Elias-Fano encoding. +- [roaring](https://github.com/RoaringBitmap/roaring) - Go package implementing compressed bitsets. -## Configuration +### Bit Sets -*Libraries for configuration parsing* +- [bitmap](https://github.com/kelindar/bitmap) - Dense, zero-allocation, SIMD-enabled bitmap/bitset in Go. +- [bitset](https://github.com/bits-and-blooms/bitset) - Go package implementing bitsets. -* [config](https://github.com/olebedev/config) - JSON or YAML configuration wrapper with environment variables and flags parsing. -* [envcfg](https://github.com/tomazk/envcfg) - Un-marshaling environment variables to Go structs. -* [envconf](https://github.com/ian-kent/envconf) - Configuration from environment -* [gofigure](https://github.com/ian-kent/gofigure) - Go application configuration made easy -* [mini](https://github.com/FogCreek/mini) - A golang package for parsing ini-style configuration files -* [viper](https://github.com/spf13/viper) - Go configuration with fangs +### Bloom and Cuckoo Filters -## CSS Preprocessors +- [bloom](https://github.com/bits-and-blooms/bloom) - Go package implementing Bloom filters. +- [bloom](https://github.com/zhenjl/bloom) - Bloom filters implemented in Go. +- [bloom](https://github.com/yourbasic/bloom) - Golang Bloom filter implementation. +- [bloomfilter](https://github.com/OldPanda/bloomfilter) - Yet another Bloomfilter implementation in Go, compatible with Java's Guava library. +- [boomfilters](https://github.com/tylertreat/BoomFilters) - Probabilistic data structures for processing continuous, unbounded streams. +- [cuckoo-filter](https://github.com/linvon/cuckoo-filter) - Cuckoo filter: a comprehensive cuckoo filter, which is configurable and space optimized compared with other implements, and all features mentioned in original paper are available. +- [cuckoofilter](https://github.com/seiflotfy/cuckoofilter) - Cuckoo filter: a good alternative to a counting bloom filter implemented in Go. +- [ring](https://github.com/TheTannerRyan/ring) - Go implementation of a high performance, thread safe bloom filter. -*Libraries for preprocessing CSS files* +### Data Structure and Algorithm Collections -* [gcss](https://github.com/yosssi/gcss) - Pure Go CSS Preprocessor. +- [algorithms](https://github.com/shady831213/algorithms) - Algorithms and data structures.CLRS study. +- [go-datastructures](https://github.com/Workiva/go-datastructures) - Collection of useful, performant, and thread-safe data structures. +- [gods](https://github.com/emirpasic/gods) - Go Data Structures. Containers, Sets, Lists, Stacks, Maps, BidiMaps, Trees, HashSet etc. +- [gostl](https://github.com/liyue201/gostl) - Data structure and algorithm library for go, designed to provide functions similar to C++ STL. +### Iterators -## Database +- [goterator](https://github.com/yaa110/goterator) - Iterator implementation to provide map and reduce functionalities. +- [iter](https://github.com/disksing/iter) - Go implementation of C++ STL iterators and algorithms. -*Generic data structures and algorithms for databases in Go.* +### Maps -* [bitset](https://github.com/willf/bitset) - Go package implementing bitsets. -* [bloom](https://github.com/dataence/bloom) - Bloom filters implemented in Go. -* [encoding](https://github.com/dataence/encoding) - Integer Compression Libraries for Go. -* [mafsa](https://github.com/smartystreets/mafsa) - MA-FSA implementation with Minimal Perfect Hashing -* [skiplist](https://github.com/gansidui/skiplist) - Skiplist implementation in Go -* [trie](https://github.com/derekparker/trie) - Trie implementation in Go +See also [Database](#database) for more complex key-value stores, and [Trees](#trees) for +additional ordered map implementations. -*Databases implemented in Go.* +- [cmap](https://github.com/lrita/cmap) - a thread-safe concurrent map for go, support using `interface{}` as key and auto scale up shards. +- [dict](https://github.com/srfrog/dict) - Python-like dictionaries (dict) for Go. +- [go-shelve](https://github.com/lucmq/go-shelve) - A persistent, map-like object for the Go programming language. Supports multiple embedded key-value stores. +- [goradd/maps](https://github.com/goradd/maps) - Go 1.18+ generic map interface for maps; safe maps; ordered maps; ordered, safe maps; etc. -* [bolt](https://github.com/boltdb/bolt) - A low-level key/value database for Go. -* [cache2go](https://github.com/muesli/cache2go) - An in-memory key:value cache which supports automatic invalidation based on timeouts. -* [diskv](https://github.com/peterbourgon/diskv) - A home-grown disk-backed key-value store. -* [forestdb](https://github.com/couchbaselabs/goforestdb) - Go bindings for ForestDB. -* [go-cache](https://github.com/pmylund/go-cache) - An in-memory key:value store/cache (similar to Memcached) library for Go, suitable for single-machine applications. -* [goleveldb](https://github.com/syndtr/goleveldb) - An implementation of the [LevelDB](https://github.com/google/leveldb) key/value database in the Go. -* [groupcache](https://github.com/golang/groupcache) - Groupcache is a caching and cache-filling library, intended as a replacement for memcached in many cases. -* [influxdb](https://github.com/influxdb/influxdb) - Scalable datastore for metrics, events, and real-time analytics -* [ledisdb](https://github.com/siddontang/ledisdb) - Ledisdb is a high performance NoSQL like Redis based on LevelDB. -* [levigo](https://github.com/jmhodges/levigo) - Levigo is a Go wrapper for LevelDB. -* [tiedot](https://github.com/HouzuoGuo/tiedot) - Your NoSQL database powered by Golang. +### Miscellaneous Data Structures and Algorithms -*Database tools.* +- [concurrent-writer](https://github.com/free/concurrent-writer) - Highly concurrent drop-in replacement for `bufio.Writer`. +- [conjungo](https://github.com/InVisionApp/conjungo) - A small, powerful and flexible merge library. +- [count-min-log](https://github.com/seiflotfy/count-min-log) - Go implementation Count-Min-Log sketch: Approximately counting with approximate counters (Like Count-Min sketch but using less memory). +- [fsm](https://github.com/cocoonspace/fsm) - Finite-State Machine package. +- [genfuncs](https://github.com/nwillc/genfuncs) - Go 1.18+ generics package inspired by Kotlin's Sequence and Map. +- [go-generics](https://github.com/bobg/go-generics) - Generic slice, map, set, iterator, and goroutine utilities. +- [go-geoindex](https://github.com/hailocab/go-geoindex) - In-memory geo index. +- [go-rampart](https://github.com/francesconi/go-rampart) - Determine how intervals relate to each other. +- [go-rquad](https://github.com/aurelien-rainone/go-rquad) - Region quadtrees with efficient point location and neighbour finding. +- [go-tuple](https://github.com/barweiss/go-tuple) - Generic tuple implementation for Go 1.18+. +- [go18ds](https://github.com/daichi-m/go18ds) - Go Data Structures using Go 1.18 generics. +- [gofal](https://github.com/xxjwxc/gofal) - fractional api for Go. +- [gogu](https://github.com/esimov/gogu) - A comprehensive, reusable and efficient concurrent-safe generics utility functions and data structures library. +- [gota](https://github.com/kniren/gota) - Implementation of dataframes, series, and data wrangling methods for Go. +- [hide](https://github.com/emvi/hide) - ID type with marshalling to/from hash to prevent sending IDs to clients. +- [hilbert](https://github.com/google/hilbert) - Go package for mapping values to and from space-filling curves, such as Hilbert and Peano curves. +- [hyperloglog](https://github.com/axiomhq/hyperloglog) - HyperLogLog implementation with Sparse, LogLog-Beta bias correction and TailCut space reduction. +- [quadtree](https://github.com/s0rg/quadtree) - Generic, zero-alloc, 100%-test covered quadtree. +- [slices](https://github.com/srfrog/slices) - Functions that operate on slices; like `package strings` but adapted to work with slices. +- [slices](https://github.com/twharmon/slices) - Pure, generic functions for slices. -* [go-mysql](https://github.com/siddontang/go-mysql) - A go toolset to handle MySQL protocol and replication. -* [go-mysql-elasticsearch](https://github.com/siddontang/go-mysql-elasticsearch) - Sync your MySQL data into Elasticsearch automatically. -* [goose](https://bitbucket.org/liamstask/goose) - Database migration tool. You can manage your database's evolution by creating incremental SQL or Go scripts. -* [myreplication](https://github.com/2tvenom/myreplication) - MySql binary log replication listener. Support statement and row based replication. -* [pgweb](https://github.com/sosedoff/pgweb) - A web-based PostgreSQL database browser -* [pravasan](https://github.com/pravasan/pravasan) - Simple Migration tool - currently for MySQL but planning to support soon for Postgres, SQLite, MongoDB, etc., -* [vitess](https://github.com/youtube/vitess) - vitess provides servers and tools which facilitate scaling of MySQL databases for large scale web services. +### Nullable Types -*SQL query builder, libraries for building and using SQL.* +- [nan](https://github.com/kak-tus/nan) - Zero allocation Nullable structures in one library with handy conversion functions, marshallers and unmarshallers. +- [null](https://github.com/emvi/null) - Nullable Go types that can be marshalled/unmarshalled to/from JSON. +- [typ](https://github.com/gurukami/typ) - Null Types, Safe primitive type conversion and fetching value from complex structures. -* [Dotsql](https://github.com/gchaincl/dotsql) - Go library that helps you keep sql files in one place and use it with ease. -* [goqu](https://github.com/doug-martin/goqu) - An idiomatic SQL builder and query library. -* [Squirrel](https://github.com/lann/squirrel) - Go library that helps you build SQL queries. +### Queues +- [deque](https://github.com/edwingeng/deque) - A highly optimized double-ended queue. +- [deque](https://github.com/gammazero/deque) - Fast ring-buffer deque (double-ended queue). +- [goconcurrentqueue](https://github.com/enriquebris/goconcurrentqueue) - Concurrent FIFO queue. +- [hatchet](https://github.com/hatchet-dev/hatchet) - Distributed, Fault-tolerant task queue. +- [memlog](https://github.com/embano1/memlog) - An easy to use, lightweight, thread-safe and append-only in-memory data structure inspired by Apache Kafka. +- [queue](https://github.com/adrianbrad/queue) - Multiple thread-safe, generic queue implementations for Go. -## Database Drivers +### Sets -*Libraries for connecting and operating databases. (see [Testing](#testing) for mock drivers)* +- [dsu](https://github.com/ihebu/dsu) - Disjoint Set data structure implementation in Go. +- [golang-set](https://github.com/deckarep/golang-set) - Thread-Safe and Non-Thread-Safe high-performance sets for Go. +- [goset](https://github.com/zoumo/goset) - A useful Set collection implementation for Go. +- [set](https://github.com/StudioSol/set) - Simple set data structure implementation in Go using LinkedHashMap. -* Relational Databases - * [go-adodb](https://github.com/mattn/go-adodb) - Microsoft ActiveX Object DataBase driver for go that using database/sql. - * [go-bqstreamer](https://github.com/rounds/go-bqstreamer) - BigQuery fast and concurrent stream insert. - * [go-mssqldb](https://github.com/denisenkom/go-mssqldb) - Microsoft MSSQL driver prototype in go language. - * [go-oci8](https://github.com/mattn/go-oci8) - Oracle driver for go that using database/sql. - * [go-pgsql](https://github.com/lxn/go-pgsql) - A PostgreSQL client package for the Go Programming Language. - * [go-sql-driver/mysql](https://github.com/go-sql-driver/mysql) - MySQL driver for Go. - * [go-sqlite3](https://github.com/mattn/go-sqlite3) - SQLite3 driver for go that using database/sql. - * [pq](https://github.com/lib/pq) - Pure Go Postgres driver for database/sql. +### Text Analysis + +- [bleve](https://github.com/blevesearch/bleve) - Modern text indexing library for go. +- [go-adaptive-radix-tree](https://github.com/plar/go-adaptive-radix-tree) - Go implementation of Adaptive Radix Tree. +- [go-edlib](https://github.com/hbollon/go-edlib) - Go string comparison and edit distance algorithms library (Levenshtein, LCS, Hamming, Damerau levenshtein, Jaro-Winkler, etc.) compatible with Unicode. +- [levenshtein](https://github.com/agext/levenshtein) - Levenshtein distance and similarity metrics with customizable edit costs and Winkler-like bonus for common prefix. +- [levenshtein](https://github.com/agnivade/levenshtein) - Implementation to calculate levenshtein distance in Go. +- [mspm](https://github.com/BlackRabbitt/mspm) - Multi-String Pattern Matching Algorithm for information retrieval. +- [parsefields](https://github.com/MonaxGT/parsefields) - Tools for parse JSON-like logs for collecting unique fields and events. +- [ptrie](https://github.com/viant/ptrie) - An implementation of prefix tree. +- [trie](https://github.com/derekparker/trie) - Trie implementation in Go. + +### Trees + +- [hashsplit](http://github.com/bobg/hashsplit) - Split byte streams into chunks, and arrange chunks into trees, with boundaries determined by content, not position. +- [merkle](https://github.com/bobg/merkle) - Space-efficient computation of Merkle root hashes and inclusion proofs. +- [skiplist](https://github.com/MauriceGit/skiplist) - Very fast Go Skiplist implementation. +- [skiplist](https://github.com/gansidui/skiplist) - Skiplist implementation in Go. +- [treap](https://github.com/perdata/treap) - Persistent, fast ordered map using tree heaps. +- [treemap](https://github.com/igrmk/treemap) - Generic key-sorted map using a red-black tree under the hood. + +### Pipes + +- [ordered-concurrently](https://github.com/tejzpr/ordered-concurrently) - Go module that processes work concurrently and returns output in a channel in the order of input. +- [parapipe](https://github.com/nazar256/parapipe) - FIFO Pipeline which parallels execution on each stage while maintaining the order of messages and results. +- [pipeline](https://github.com/hyfather/pipeline) - An implementation of pipelines with fan-in and fan-out. + +**[⬆ back to top](#contents)** -* NoSQL Databases - * [aerospike-client-go](https://github.com/aerospike/aerospike-client-go) - Aerospike client in Go language. - * [cayley](https://github.com/google/cayley) - A graph database with support for multiple backends. - * [go-couchbase](https://github.com/couchbaselabs/go-couchbase) - Couchbase client in Go - * [gocql](http://gocql.github.io) - A Go language driver for Apache Cassandra. - * [gomemcache](https://github.com/bradfitz/gomemcache/) - memcache client library for the Go programming language. - * [gorethink](https://github.com/dancannon/gorethink) - Go language driver for RethinkDB - * [mgo](http://godoc.org/labix.org/v2/mgo) - MongoDB driver for the Go language that implements a rich and well tested selection of features under a very simple API following standard Go idioms. - * [neo4j](https://github.com/cihangir/neo4j) - Neo4j Rest API Bindings for Golang - * [Neo4j-GO](https://github.com/davemeehan/Neo4j-GO) - Neo4j REST Client in golang. - * [neoism](https://github.com/jmcvetta/neoism) - Neo4j client for Golang - * [redigo](https://github.com/garyburd/redigo) - Redigo is a Go client for the Redis database. - * [redis](https://github.com/hoisie/redis) - A simple, powerful Redis client for Go. - -* Search and Analytic Databases - * [bleve](https://github.com/blevesearch/bleve) - A modern text indexing library for go. - * [elastic](https://github.com/olivere/elastic) - Elasticsearch client for Google Go. - * [elastigo](https://github.com/mattbaird/elastigo) - A Elasticsearch client library. - * [goes](https://github.com/belogik/goes) - A library to interact with Elasticsearch. - - -## Date & Time +## Database -*Libraries for working with dates and times.* +### Caches + +_Data stores with expiring records, in-memory distributed data stores, or in-memory subsets of file-based databases._ + +- [2q](https://github.com/floatdrop/2q) - 2Q in-memory cache implementation. +- [bcache](https://github.com/iwanbk/bcache) - Eventually consistent distributed in-memory cache Go library. +- [BigCache](https://github.com/allegro/bigcache) - Efficient key/value cache for gigabytes of data. +- [cache](https://github.com/akyoto/cache) - In-memory key:value store with expiration time, 0 dependencies, <100 LoC, 100% coverage. +- [cache2go](https://github.com/muesli/cache2go) - In-memory key:value cache which supports automatic invalidation based on timeouts. +- [cachego](https://github.com/faabiosr/cachego) - Golang Cache component for multiple drivers. +- [clusteredBigCache](https://github.com/oaStuff/clusteredBigCache) - BigCache with clustering support and individual item expiration. +- [coherence-go-client](https://github.com/oracle/coherence-go-client) - Full implementation of Oracle Coherence cache API for Go applications using gRPC as network transport. +- [couchcache](https://github.com/codingsince1985/couchcache) - RESTful caching micro-service backed by Couchbase server. +- [EchoVault](https://github.com/EchoVault/EchoVault) - Embeddable Distributed in-memory data store compatible with Redis clients. +- [fastcache](https://github.com/VictoriaMetrics/fastcache) - fast thread-safe inmemory cache for big number of entries. Minimizes GC overhead. +- [GCache](https://github.com/bluele/gcache) - Cache library with support for expirable Cache, LFU, LRU and ARC. +- [gdcache](https://github.com/ulovecode/gdcache) - A pure non-intrusive cache library implemented by golang, you can use it to implement your own distributed cache. +- [go-cache](https://github.com/viney-shih/go-cache) - A flexible multi-layer Go caching library to deal with in-memory and shared cache by adopting Cache-Aside pattern. +- [go-freelru](https://github.com/elastic/go-freelru) A GC-less, fast and generic LRU hashmap library with optional locking, sharding, eviction and expiration. +- [go-mcache](https://github.com/OrlovEvgeny/go-mcache) - Fast in-memory key:value store/cache library. Pointer caches. +- [gocache](https://github.com/eko/gocache) - A complete Go cache library with multiple stores (memory, memcache, redis, ...), chainable, loadable, metrics cache and more. +- [gocache](https://github.com/yuseferi/gocache) - A data race free Go ache library with high performance and auto pruge functionality +- [groupcache](https://github.com/golang/groupcache) - Groupcache is a caching and cache-filling library, intended as a replacement for memcached in many cases. +- [icache](https://github.com/mdaliyan/icache) - A High Performance, Generic, thread-safe, zero-dependency cache package. +- [imcache](https://github.com/erni27/imcache) - A generic in-memory cache Go library. It supports expiration, sliding expiration, max entries limit, eviction callbacks and sharding. +- [nscache](https://github.com/no-src/nscache) - A Go caching framework that supports multiple data source drivers. +- [otter](https://github.com/maypok86/otter) - A high performance lockless cache for Go. Many times faster than Ristretto and friends. +- [remember-go](https://github.com/rocketlaunchr/remember-go) - A universal interface for caching slow database queries (backed by redis, memcached, ristretto, or in-memory). +- [sturdyc](https://github.com/creativecreature/sturdyc) - A caching library with advanced concurrency features designed to make I/O heavy applications robust and highly performant. +- [theine](https://github.com/Yiling-J/theine-go) - High performance, near optimal in-memory cache with proactive TTL expiration and generics. +- [timedmap](https://github.com/zekroTJA/timedmap) - Map with expiring key-value pairs. +- [ttlcache](https://github.com/jellydator/ttlcache) - An in-memory cache with item expiration and generics. +- [ttlcache](https://github.com/cheshir/ttlcache) - In-memory key value storage with TTL for each record. + +### Databases Implemented in Go + +- [badger](https://github.com/dgraph-io/badger) - Fast key-value store in Go. +- [bbolt](https://github.com/etcd-io/bbolt) - An embedded key/value database for Go. +- [Bitcask](https://git.mills.io/prologic/bitcask) - Bitcask is an embeddable, persistent and fast key-value (KV) database written in pure Go with predictable read/write performance, low latency and high throughput thanks to the bitcask on-disk layout (LSM+WAL). +- [buntdb](https://github.com/tidwall/buntdb) - Fast, embeddable, in-memory key/value database for Go with custom indexing and spatial support. +- [clover](https://github.com/ostafen/clover) - A lightweight document-oriented NoSQL database written in pure Golang. +- [cockroach](https://github.com/cockroachdb/cockroach) - Scalable, Geo-Replicated, Transactional Datastore. +- [Coffer](https://github.com/claygod/coffer) - Simple ACID key-value database that supports transactions. +- [column](https://github.com/kelindar/column) - High-performance, columnar, embeddable in-memory store with bitmap indexing and transactions. +- [CovenantSQL](https://github.com/CovenantSQL/CovenantSQL) - CovenantSQL is a SQL database on blockchain. +- [Databunker](https://github.com/paranoidguy/databunker) - Personally identifiable information (PII) storage service built to comply with GDPR and CCPA. +- [dgraph](https://github.com/dgraph-io/dgraph) - Scalable, Distributed, Low Latency, High Throughput Graph Database. +- [diskv](https://github.com/peterbourgon/diskv) - Home-grown disk-backed key-value store. +- [dolt](https://github.com/dolthub/dolt) - Dolt – It's Git for Data. +- [dtf](https://github.com/dtm-labs/dtf) - A distributed transaction manager. Support XA, TCC, SAGA, Reliable Messages. +- [eliasdb](https://github.com/krotik/eliasdb) - Dependency-free, transactional graph database with REST API, phrase search and SQL-like query language. +- [godis](https://github.com/hdt3213/godis) - A Golang implemented high-performance Redis server and cluster. +- [goleveldb](https://github.com/syndtr/goleveldb) - Implementation of the [LevelDB](https://github.com/google/leveldb) key/value database in Go. +- [hare](https://github.com/jameycribbs/hare) - A simple database management system that stores each table as a text file of line-delimited JSON. +- [immudb](https://github.com/codenotary/immudb) - immudb is a lightweight, high-speed immutable database for systems and applications written in Go. +- [influxdb](https://github.com/influxdb/influxdb) - Scalable datastore for metrics, events, and real-time analytics. +- [ledisdb](https://github.com/siddontang/ledisdb) - Ledisdb is a high performance NoSQL like Redis based on LevelDB. +- [levigo](https://github.com/jmhodges/levigo) - Levigo is a Go wrapper for LevelDB. +- [libradb](https://github.com/amit-davidson/LibraDB) - LibraDB is a simple database with less than 1000 lines of code for learning. +- [LinDB](https://github.com/lindb/lindb) - LinDB is a scalable, high performance, high availability distributed time series database. +- [lotusdb](https://github.com/flower-corp/lotusdb) - Fast k/v database compatible with lsm and b+tree. +- [Milvus](https://github.com/milvus-io/milvus) - Milvus is a vector database for embedding management, analytics and search. +- [moss](https://github.com/couchbase/moss) - Moss is a simple LSM key-value storage engine written in 100% Go. +- [nutsdb](https://github.com/xujiajun/nutsdb) - Nutsdb is a simple, fast, embeddable, persistent key/value store written in pure Go. It supports fully serializable transactions and many data structures such as list, set, sorted set. +- [objectbox-go](https://github.com/objectbox/objectbox-go) - High-performance embedded Object Database (NoSQL) with Go API. +- [pebble](https://github.com/cockroachdb/pebble) - RocksDB/LevelDB inspired key-value database in Go. +- [piladb](https://github.com/fern4lvarez/piladb) - Lightweight RESTful database engine based on stack data structures. +- [pogreb](https://github.com/akrylysov/pogreb) - Embedded key-value store for read-heavy workloads. +- [prometheus](https://github.com/prometheus/prometheus) - Monitoring system and time series database. +- [pudge](https://github.com/recoilme/pudge) - Fast and simple key/value store written using Go's standard library. +- [rosedb](https://github.com/roseduan/rosedb) - An embedded k-v database based on LSM+WAL, supports string, list, hash, set, zset. +- [rotom](https://github.com/xgzlucario/rotom) - A tiny Redis server built with Golang, compatible with RESP protocols. +- [rqlite](https://github.com/rqlite/rqlite) - The lightweight, distributed, relational database built on SQLite. +- [tempdb](https://github.com/rafaeljesus/tempdb) - Key-value store for temporary items. +- [tidb](https://github.com/pingcap/tidb) - TiDB is a distributed SQL database. Inspired by the design of Google F1. +- [tiedot](https://github.com/HouzuoGuo/tiedot) - Your NoSQL database powered by Golang. +- [unitdb](https://github.com/unit-io/unitdb) - Fast timeseries database for IoT, realtime messaging applications. Access unitdb with pubsub over tcp or websocket using github.com/unit-io/unitd application. +- [Vasto](https://github.com/chrislusf/vasto) - A distributed high-performance key-value store. On Disk. Eventual consistent. HA. Able to grow or shrink without service interruption. +- [VictoriaMetrics](https://github.com/VictoriaMetrics/VictoriaMetrics) - fast, resource-effective and scalable open source time series database. May be used as long-term remote storage for Prometheus. Supports PromQL. + +### Database Schema Migration + +- [atlas](https://github.com/ariga/atlas) - A Database Toolkit. A CLI designed to help companies better work with their data. +- [avro](https://github.com/khezen/avro) - Discover SQL schemas and convert them to AVRO schemas. Query SQL records into AVRO bytes. +- [bytebase](https://github.com/bytebase/bytebase) - Safe database schema change and version control for DevOps teams. +- [darwin](https://github.com/GuiaBolso/darwin) - Database schema evolution library for Go. +- [dbmate](https://github.com/amacneil/dbmate) - A lightweight, framework-agnostic database migration tool. +- [go-fixtures](https://github.com/RichardKnop/go-fixtures) - Django style fixtures for Golang's excellent built-in database/sql library. +- [go-pg-migrate](https://github.com/lawzava/go-pg-migrate) - CLI-friendly package for go-pg migrations management. +- [go-pg-migrations](https://github.com/robinjoseph08/go-pg-migrations) - A Go package to help write migrations with go-pg/pg. +- [goavro](https://github.com/linkedin/goavro) - A Go package that encodes and decodes Avro data. +- [godfish](https://github.com/rafaelespinoza/godfish) - Database migration manager, works with native query language. Support for cassandra, mysql, postgres, sqlite3. +- [goose](https://github.com/pressly/goose) - Database migration tool. You can manage your database's evolution by creating incremental SQL or Go scripts. +- [gorm-seeder](https://github.com/Kachit/gorm-seeder) - Simple database seeder for Gorm ORM. +- [gormigrate](https://github.com/go-gormigrate/gormigrate) - Database schema migration helper for Gorm ORM. +- [libschema](https://github.com/muir/libschema) - Define your migrations separately in each library. Migrations for open source libraries. MySQL & PostgreSQL. +- [migrate](https://github.com/golang-migrate/migrate) - Database migrations. CLI and Golang library. +- [migrator](https://github.com/lopezator/migrator) - Dead simple Go database migration library. +- [migrator](https://github.com/larapulse/migrator) - MySQL database migrator designed to run migrations to your features and manage database schema update with intuitive go code. +- [schema](https://github.com/adlio/schema) - Library to embed schema migrations for database/sql-compatible databases inside your Go binaries. +- [skeema](https://github.com/skeema/skeema) - Pure-SQL schema management system for MySQL, with support for sharding and external online schema change tools. +- [soda](https://github.com/gobuffalo/pop/tree/master/soda) - Database migration, creation, ORM, etc... for MySQL, PostgreSQL, and SQLite. +- [sql-migrate](https://github.com/rubenv/sql-migrate) - Database migration tool. Allows embedding migrations into the application using go-bindata. +- [sqlize](https://github.com/sunary/sqlize) - Database migration generator. Allows generate sql migration from model and existing sql by differ them. + +### Database Tools + +- [chproxy](https://github.com/Vertamedia/chproxy) - HTTP proxy for ClickHouse database. +- [clickhouse-bulk](https://github.com/nikepan/clickhouse-bulk) - Collects small inserts and sends big requests to ClickHouse servers. +- [dbbench](https://github.com/sj14/dbbench) - Database benchmarking tool with support for several databases and scripts. +- [dg](https://github.com/codingconcepts/dg) - A fast data generator that produces CSV files from generated relational data. +- [dynago](https://github.com/twharmon/dynago) - Simplify working with AWS DynamoDB. +- [gatewayd](https://github.com/gatewayd-io/gatewayd) - Cloud-native database gateway and framework for building data-driven applications. Like API gateways, for databases. +- [go-mysql](https://github.com/siddontang/go-mysql) - Go toolset to handle MySQL protocol and replication. +- [gorm-multitenancy](https://github.com/bartventer/gorm-multitenancy) - Multi-tenancy support for GORM managed databases. +- [hasql](https://golang.yandex/hasql) - Library for accessing multi-host SQL database installations. +- [octillery](https://github.com/knocknote/octillery) - Go package for sharding databases ( Supports every ORM or raw SQL ). +- [onedump](https://github.com/liweiyi88/onedump) - Database backup from different drivers to different destinations with one command and configuration. +- [pg_timetable](https://github.com/cybertec-postgresql/pg_timetable) - Advanced scheduling for PostgreSQL. +- [pgweb](https://github.com/sosedoff/pgweb) - Web-based PostgreSQL database browser. +- [prep](https://github.com/hexdigest/prep) - Use prepared SQL statements without changing your code. +- [pREST](https://github.com/prest/prest) - Simplify and accelerate development, ⚡ instant, realtime, high-performance on any Postgres application, existing or new. +- [rdb](https://github.com/HDT3213/rdb) - Redis RDB file parser for secondary development and memory analysis. +- [rwdb](https://github.com/andizzle/rwdb) - rwdb provides read replica capability for multiple database servers setup. +- [vitess](https://github.com/youtube/vitess) - vitess provides servers and tools which facilitate scaling of MySQL databases for large scale web services. +- [wescale](https://github.com/wesql/wescale) - WeScale is a database proxy designed to enhance the scalability, performance, security, and resilience of your applications. + +### SQL Query Builders + +_Libraries for building and using SQL._ + +- [bqb](https://github.com/nullism/bqb) - Lightweight and easy to learn query builder. +- [buildsqlx](https://github.com/arthurkushman/buildsqlx) - Go database query builder library for PostgreSQL. +- [builq](https://github.com/cristalhq/builq) - Easily build SQL queries in Go. +- [dbq](https://github.com/rocketlaunchr/dbq) - Zero boilerplate database operations for Go. +- [Dotsql](https://github.com/gchaincl/dotsql) - Go library that helps you keep sql files in one place and use them with ease. +- [gendry](https://github.com/didi/gendry) - Non-invasive SQL builder and powerful data binder. +- [godbal](https://github.com/xujiajun/godbal) - Database Abstraction Layer (dbal) for go. Support SQL builder and get result easily. +- [goqu](https://github.com/doug-martin/goqu) - Idiomatic SQL builder and query library. +- [gosql](https://github.com/twharmon/gosql) - SQL Query builder with better null values support. +- [Hotcoal](https://github.com/motrboat/hotcoal) - Secure your handcrafted SQL against injection. +- [igor](https://github.com/galeone/igor) - Abstraction layer for PostgreSQL that supports advanced functionality and uses gorm-like syntax. +- [jet](https://github.com/go-jet/jet) - Framework for writing type-safe SQL queries in Go, with ability to easily convert database query result into desired arbitrary object structure. +- [ormlite](https://github.com/pupizoid/ormlite) - Lightweight package containing some ORM-like features and helpers for sqlite databases. +- [ozzo-dbx](https://github.com/go-ozzo/ozzo-dbx) - Powerful data retrieval methods as well as DB-agnostic query building capabilities. +- [qry](https://github.com/HnH/qry) - Tool that generates constants from files with raw SQL queries. +- [sg](https://github.com/go-the-way/sg) - A SQL Gen for generating standard SQLs(supports: CRUD) written in Go. +- [sq](https://github.com/bokwoon95/go-structured-query) - Type-safe SQL builder and struct mapper for Go. +- [sqlc](https://github.com/kyleconroy/sqlc) - Generate type-safe code from SQL. +- [sqlf](https://github.com/leporo/sqlf) - Fast SQL query builder. +- [sqlingo](https://github.com/lqs/sqlingo) - A lightweight DSL to build SQL in Go. +- [sqrl](https://github.com/elgris/sqrl) - SQL query builder, fork of Squirrel with improved performance. +- [Squalus](https://gitlab.com/qosenergy/squalus) - Thin layer over the Go SQL package that makes it easier to perform queries. +- [Squirrel](https://github.com/Masterminds/squirrel) - Go library that helps you build SQL queries. +- [xo](https://github.com/knq/xo) - Generate idiomatic Go code for databases based on existing schema definitions or custom queries supporting PostgreSQL, MySQL, SQLite, Oracle, and Microsoft SQL Server. + +**[⬆ back to top](#contents)** -* [now](https://github.com/jinzhu/now) - Now is a time toolkit for golang. +## Database Drivers +### Interfaces to Multiple Backends + +- [cayley](https://github.com/google/cayley) - Graph database with support for multiple backends. +- [dsc](https://github.com/viant/dsc) - Datastore connectivity for SQL, NoSQL, structured files. +- [dynamo](https://github.com/fogfish/dynamo) - A simple key-value abstraction to store algebraic and linked-data data types at AWS storage services: AWS DynamoDB and AWS S3. +- [go-transaction-manager](https://github.com/avito-tech/go-transaction-manager) - Transaction manager with multiple adapters (sql, sqlx, gorm, mongo, ...) controls transaction boundaries. +- [gokv](https://github.com/philippgille/gokv) - Simple key-value store abstraction and implementations for Go (Redis, Consul, etcd, bbolt, BadgerDB, LevelDB, Memcached, DynamoDB, S3, PostgreSQL, MongoDB, CockroachDB and many more). + +### Relational Database Drivers + +- [avatica](https://github.com/apache/calcite-avatica-go) - Apache Avatica/Phoenix SQL driver for database/sql. +- [bgc](https://github.com/viant/bgc) - Datastore Connectivity for BigQuery for go. +- [firebirdsql](https://github.com/nakagami/firebirdsql) - Firebird RDBMS SQL driver for Go. +- [go-adodb](https://github.com/mattn/go-adodb) - Microsoft ActiveX Object DataBase driver for go that uses database/sql. +- [go-mssqldb](https://github.com/denisenkom/go-mssqldb) - Microsoft MSSQL driver for Go. +- [go-oci8](https://github.com/mattn/go-oci8) - Oracle driver for go that uses database/sql. +- [go-sql-driver/mysql](https://github.com/go-sql-driver/mysql) - MySQL driver for Go. +- [go-sqlite3](https://github.com/mattn/go-sqlite3) - SQLite3 driver for go that uses database/sql. +- [godror](https://github.com/godror/godror) - Oracle driver for Go, using the ODPI-C driver. +- [gofreetds](https://github.com/minus5/gofreetds) - Microsoft MSSQL driver. Go wrapper over [FreeTDS](https://www.freetds.org). +- [KSQL](https://github.com/VinGarcia/ksql) - A Simple and Powerful Golang SQL Library +- [pgx](https://github.com/jackc/pgx) - PostgreSQL driver supporting features beyond those exposed by database/sql. +- [pig](https://github.com/alexeyco/pig) - Simple [pgx](https://github.com/jackc/pgx) wrapper to execute and [scan](https://github.com/georgysavva/scany) query results easily. +- [pq](https://github.com/lib/pq) - Pure Go Postgres driver for database/sql. +- [Sqinn-Go](https://github.com/cvilsmeier/sqinn-go) - SQLite with pure Go. +- [sqlhooks](https://github.com/qustavo/sqlhooks) - Attach hooks to any database/sql driver. +- [surrealdb.go](https://github.com/surrealdb/surrealdb.go) - SurrealDB Driver for Go. +- [ydb-go-sdk](https://github.com/ydb-platform/ydb-go-sdk) - native and database/sql driver YDB (Yandex Database) + +### NoSQL Database Drivers + +- [aerospike-client-go](https://github.com/aerospike/aerospike-client-go) - Aerospike client in Go language. +- [arangolite](https://github.com/solher/arangolite) - Lightweight golang driver for ArangoDB. +- [asc](https://github.com/viant/asc) - Datastore Connectivity for Aerospike for go. +- [forestdb](https://github.com/couchbase/goforestdb) - Go bindings for ForestDB. +- [go-couchbase](https://github.com/couchbase/go-couchbase) - Couchbase client in Go. +- [go-mongox](https://github.com/chenmingyong0423/go-mongox) - A Go Mongo library based on the official driver, featuring streamlined document operations, generic binding of structs to collections, built-in CRUD, aggregation, automated field updates, struct validation, hooks, and plugin-based programming. +- [go-pilosa](https://github.com/pilosa/go-pilosa) - Go client library for Pilosa. +- [go-rejson](https://github.com/nitishm/go-rejson) - Golang client for redislabs' ReJSON module using Redigo golang client. Store and manipulate structs as JSON objects in redis with ease. +- [gocb](https://github.com/couchbase/gocb) - Official Couchbase Go SDK. +- [gocosmos](https://github.com/btnguyen2k/gocosmos) - REST client and standard `database/sql` driver for Azure Cosmos DB. +- [gocql](https://gocql.github.io) - Go language driver for Apache Cassandra. +- [godis](https://github.com/piaohao/godis) - redis client implement by golang, inspired by jedis. +- [godscache](https://github.com/defcronyke/godscache) - A wrapper for the Google Cloud Platform Go Datastore package that adds caching using memcached. +- [gomemcache](https://github.com/bradfitz/gomemcache/) - memcache client library for the Go programming language. +- [gomemcached](https://github.com/aliexpressru/gomemcached) - A binary Memcached client for Go with support for sharding using consistent hashing, along with SASL. +- [gorethink](https://github.com/dancannon/gorethink) - Go language driver for RethinkDB. +- [goriak](https://github.com/zegl/goriak) - Go language driver for Riak KV. +- [Kivik](https://github.com/go-kivik/kivik) - Kivik provides a common Go and GopherJS client library for CouchDB, PouchDB, and similar databases. +- [mgm](https://github.com/kamva/mgm) - MongoDB model-based ODM for Go (based on official MongoDB driver). +- [mgo](https://github.com/globalsign/mgo) - (unmaintained) MongoDB driver for the Go language that implements a rich and well tested selection of features under a very simple API following standard Go idioms. +- [mongo-go-driver](https://github.com/mongodb/mongo-go-driver) - Official MongoDB driver for the Go language. +- [neo4j](https://github.com/cihangir/neo4j) - Neo4j Rest API Bindings for Golang. +- [Neo4j-GO](https://github.com/davemeehan/Neo4j-GO) - Neo4j REST Client in golang. +- [neoism](https://github.com/jmcvetta/neoism) - Neo4j client for Golang. +- [qmgo](https://github.com/qiniu/qmgo) - The MongoDB driver for Go. It‘s based on official MongoDB driver but easier to use like Mgo. +- [redeo](https://github.com/bsm/redeo) - Redis-protocol compatible TCP servers/services. +- [redigo](https://github.com/gomodule/redigo) - Redigo is a Go client for the Redis database. +- [redis](https://github.com/redis/go-redis) - Redis client for Golang. +- [rueidis](http://github.com/rueian/rueidis) - Fast Redis RESP3 client with auto pipelining and server-assisted client side caching. +- [xredis](https://github.com/shomali11/xredis) - Typesafe, customizable, clean & easy to use Redis client. + +### Search and Analytic Databases + +- [clickhouse-go](https://github.com/ClickHouse/clickhouse-go/) - ClickHouse SQL client for Go with a `database/sql` compatibility. +- [effdsl](https://github.com/sdqri/effdsl) - Elasticsearch query builder for Go. +- [elastic](https://github.com/olivere/elastic) - Elasticsearch client for Go. +- [elasticsql](https://github.com/cch123/elasticsql) - Convert sql to elasticsearch dsl in Go. +- [elastigo](https://github.com/mattbaird/elastigo) - Elasticsearch client library. +- [go-elasticsearch](https://github.com/elastic/go-elasticsearch) - Official Elasticsearch client for Go. +- [goes](https://github.com/OwnLocal/goes) - Library to interact with Elasticsearch. +- [skizze](https://github.com/seiflotfy/skizze) - probabilistic data-structures service and storage. + +**[⬆ back to top](#contents)** + +## Date and Time + +_Libraries for working with dates and times._ + +- [approx](https://github.com/goschtalt/approx) - A Duration extension supporting parsing/printing durations in days, weeks and years. +- [carbon](https://github.com/golang-module/carbon) - A simple, semantic and developer-friendly golang package for datetime. +- [carbon](https://github.com/uniplaces/carbon) - Simple Time extension with a lot of util methods, ported from PHP Carbon library. +- [cronrange](https://github.com/1set/cronrange) - Parses Cron-style time range expressions, checks if the given time is within any ranges. +- [date](https://github.com/rickb777/date) - Augments Time for working with dates, date ranges, time spans, periods, and time-of-day. +- [dateparse](https://github.com/araddon/dateparse) - Parse date's without knowing format in advance. +- [durafmt](https://github.com/hako/durafmt) - Time duration formatting library for Go. +- [feiertage](https://github.com/wlbr/feiertage) - Set of functions to calculate public holidays in Germany, incl. specialization on the states of Germany (Bundesländer). Things like Easter, Pentecost, Thanksgiving... +- [go-anytime](https://github.com/ijt/go-anytime) - Parse dates/times like "next dec 22nd at 3pm" and ranges like "from today until next thursday" without knowing the format in advance. +- [go-datebin](https://github.com/deatil/go-datebin) - A simple datetime parse pkg. +- [go-persian-calendar](https://github.com/yaa110/go-persian-calendar) - The implementation of the Persian (Solar Hijri) Calendar in Go (golang). +- [go-str2duration](https://github.com/xhit/go-str2duration) - Convert string to duration. Support time.Duration returned string and more. +- [go-sunrise](https://github.com/nathan-osman/go-sunrise) - Calculate the sunrise and sunset times for a given location. +- [go-week](https://github.com/stoewer/go-week) - An efficient package to work with ISO8601 week dates. +- [gostradamus](https://github.com/bykof/gostradamus) - A Go package for working with dates. +- [iso8601](https://github.com/relvacode/iso8601) - Efficiently parse ISO8601 date-times without regex. +- [kair](https://github.com/GuilhermeCaruso/kair) - Date and Time - Golang Formatting Library. +- [now](https://github.com/jinzhu/now) - Now is a time toolkit for golang. +- [strftime](https://github.com/awoodbeck/strftime) - C99-compatible strftime formatter. +- [timespan](https://github.com/SaidinWoT/timespan) - For interacting with intervals of time, defined as a start time and a duration. +- [timeutil](https://github.com/leekchan/timeutil) - Useful extensions (Timedelta, Strftime, ...) to the golang's time package. +- [tuesday](https://github.com/osteele/tuesday) - Ruby-compatible Strftime function. + +**[⬆ back to top](#contents)** ## Distributed Systems -*Packages that help with building Distributed Systems.* - -* [goraft](https://github.com/goraft/raft) - A Go implementation of the Raft distributed consensus protocol. -* [raft](https://github.com/hashicorp/raft) - Golang implementation of the Raft consensus protocol, by HashiCorp. - +_Packages that help with building Distributed Systems._ + +- [arpc](https://github.com/lesismal/arpc) - More effective network communication, support two-way-calling, notify, broadcast. +- [bedrock](https://github.com/z5labs/bedrock) - Provides a minimal, modular and composable foundation for quickly developing services and more use case specific frameworks in Go. +- [capillaries](https://github.com/capillariesio/capillaries) - distributed batch data processing framework. +- [celeriac](https://github.com/svcavallar/celeriac.v1) - Library for adding support for interacting and monitoring Celery workers, tasks and events in Go. +- [consistent](https://github.com/buraksezer/consistent) - Consistent hashing with bounded loads. +- [consistenthash](https://github.com/mbrostami/consistenthash) - Consistent hashing with configurable replicas. +- [dht](https://github.com/anacrolix/dht) - BitTorrent Kademlia DHT implementation. +- [digota](https://github.com/digota/digota) - grpc ecommerce microservice. +- [dot](https://github.com/dotchain/dot/) - distributed sync using operational transformation/OT. +- [doublejump](https://github.com/edwingeng/doublejump) - A revamped Google's jump consistent hash. +- [dragonboat](https://github.com/lni/dragonboat) - A feature complete and high performance multi-group Raft library in Go. +- [Dragonfly](https://github.com/dragonflyoss/Dragonfly2) - Provide efficient, stable and secure file distribution and image acceleration based on p2p technology to be the best practice and standard solution in cloud native architectures. +- [drmaa](https://github.com/dgruber/drmaa) - Job submission library for cluster schedulers based on the DRMAA standard. +- [dynamolock](https://cirello.io/dynamolock) - DynamoDB-backed distributed locking implementation. +- [dynatomic](https://github.com/tylfin/dynatomic) - A library for using DynamoDB as an atomic counter. +- [emitter-io](https://github.com/emitter-io/emitter) - High performance, distributed, secure and low latency publish-subscribe platform built with MQTT, Websockets and love. +- [evans](https://github.com/ktr0731/evans) - Evans: more expressive universal gRPC client. +- [failured](https://github.com/andy2046/failured) - adaptive accrual failure detector for distributed systems. +- [flowgraph](https://github.com/vectaport/flowgraph) - flow-based programming package. +- [gleam](https://github.com/chrislusf/gleam) - Fast and scalable distributed map/reduce system written in pure Go and Luajit, combining Go's high concurrency with Luajit's high performance, runs standalone or distributed. +- [glow](https://github.com/chrislusf/glow) - Easy-to-Use scalable distributed big data processing, Map-Reduce, DAG execution, all in pure Go. +- [gmsec](https://github.com/gmsec/micro) - A Go distributed systems development framework. +- [go-doudou](https://github.com/unionj-cloud/go-doudou) - A gossip protocol and OpenAPI 3.0 spec based decentralized microservice framework. Built-in go-doudou cli focusing on low-code and rapid dev can power up your productivity. +- [go-health](https://github.com/InVisionApp/go-health) - Library for enabling asynchronous dependency health checks in your service. +- [go-jump](https://github.com/dgryski/go-jump) - Port of Google's "Jump" Consistent Hash function. +- [go-kit](https://github.com/go-kit/kit) - Microservice toolkit with support for service discovery, load balancing, pluggable transports, request tracking, etc. +- [go-micro](https://github.com/micro/go-micro) - A distributed systems development framework. +- [go-mysql-lock](https://github.com/sanketplus/go-mysql-lock) - MySQL based distributed lock. +- [go-pdu](https://github.com/pdupub/go-pdu) - A decentralized identity-based social network. +- [go-sundheit](https://github.com/AppsFlyer/go-sundheit) - A library built to provide support for defining async service health checks for golang services. +- [go-zero](https://github.com/tal-tech/go-zero) - A web and rpc framework. It's born to ensure the stability of the busy sites with resilient design. Builtin goctl greatly improves the development productivity. +- [gorpc](https://github.com/valyala/gorpc) - Simple, fast and scalable RPC library for high load. +- [grpc-go](https://github.com/grpc/grpc-go) - The Go language implementation of gRPC. HTTP/2 based RPC. +- [hprose](https://github.com/hprose/hprose-golang) - Very newbility RPC Library, support 25+ languages now. +- [jsonrpc](https://github.com/osamingo/jsonrpc) - The jsonrpc package helps implement of JSON-RPC 2.0. +- [jsonrpc](https://github.com/ybbus/jsonrpc) - JSON-RPC 2.0 HTTP client implementation. +- [K8gb](https://github.com/k8gb-io/k8gb) - A cloud native Kubernetes Global Balancer. +- [Kitex](https://github.com/cloudwego/kitex) - A high-performance and strong-extensibility Golang RPC framework that helps developers build microservices. If the performance and extensibility are the main concerns when you develop microservices, Kitex can be a good choice. +- [Kratos](https://github.com/go-kratos/kratos) - A modular-designed and easy-to-use microservices framework in Go. +- [liftbridge](https://github.com/liftbridge-io/liftbridge) - Lightweight, fault-tolerant message streams for NATS. +- [lura](https://github.com/luraproject/lura) - Ultra performant API Gateway framework with middlewares. +- [micro](https://github.com/micro/micro) - A distributed systems runtime for the cloud and beyond. +- [mochi mqtt](https://github.com/mochi-co/mqtt) - Fully spec compliant, embeddable high-performance MQTT v5/v3 broker for IoT, smarthome, and pubsub. +- [NATS](https://github.com/nats-io/gnatsd) - Lightweight, high performance messaging system for microservices, IoT, and cloud native systems. +- [outboxer](https://github.com/italolelis/outboxer) - Outboxer is a go library that implements the outbox pattern. +- [pglock](https://cirello.io/pglock) - PostgreSQL-backed distributed locking implementation. +- [pjrpc](https://gitlab.com/pjrpc/pjrpc) - Golang JSON-RPC Server-Client with Protobuf spec. +- [raft](https://github.com/hashicorp/raft) - Golang implementation of the Raft consensus protocol, by HashiCorp. +- [raft](https://github.com/etcd-io/raft) - Go implementation of the Raft consensus protocol, by CoreOS. +- [rain](https://github.com/cenkalti/rain) - BitTorrent client and library. +- [redis-lock](https://github.com/bsm/redislock) - Simplified distributed locking implementation using Redis. +- [resgate](https://resgate.io/) - Realtime API Gateway for building REST, real time, and RPC APIs, where all clients are synchronized seamlessly. +- [ringpop-go](https://github.com/uber/ringpop-go) - Scalable, fault-tolerant application-layer sharding for Go applications. +- [rpcx](https://github.com/smallnest/rpcx) - Distributed pluggable RPC service framework like alibaba Dubbo. +- [Semaphore](https://github.com/jexia/semaphore) - A straightforward (micro) service orchestrator. +- [sleuth](https://github.com/ursiform/sleuth) - Library for master-less p2p auto-discovery and RPC between HTTP services (using [ZeroMQ](https://github.com/zeromq/libzmq)). +- [sponge](https://github.com/zhufuyi/sponge) - A distributed development framework that integrates automatic code generation, gin and grpc frameworks, base development frameworks. +- [Tarmac](https://github.com/tarmac-project/tarmac) - Framework for writing functions, microservices, or monoliths with WebAssembly +- [Temporal](https://github.com/temporalio/sdk-go) - Durable execution system for making code fault-tolerant and simple. +- [torrent](https://github.com/anacrolix/torrent) - BitTorrent client package. +- [trpc-go](https://github.com/trpc-group/trpc-go) - The Go language implementation of tRPC, which is a pluggable, high-performance RPC framework. + +**[⬆ back to top](#contents)** + +## Dynamic DNS + +_Tools for updating dynamic DNS records._ + +- [DDNS](https://github.com/skibish/ddns) - Personal DDNS client with Digital Ocean Networking DNS as backend. +- [dyndns](https://gitlab.com/alcastle/dyndns) - Background Go process to regularly and automatically check your IP Address and make updates to (one or many) Dynamic DNS records for Google domains whenever your address changes. +- [GoDNS](https://github.com/timothyye/godns) - A dynamic DNS client tool, supports DNSPod & HE.net, written in Go. + +**[⬆ back to top](#contents)** ## Email -*Libraries that implement email creation and sending* - -* [email](https://github.com/jordan-wright/email) - A robust and flexible email library for Go. -* [Gomail](https://github.com/go-gomail/gomail/) - Gomail is a very simple and powerful package to send emails. -* [MailHog](https://github.com/mailhog/MailHog) - Email and SMTP testing with web and API interface -* [smtp](https://github.com/mailhog/smtp) - SMTP server protocol state machine - +_Libraries and tools that implement email creation and sending._ + +- [chasquid](https://blitiri.com.ar/p/chasquid) - SMTP server written in Go. +- [douceur](https://github.com/aymerick/douceur) - CSS inliner for your HTML emails. +- [email](https://github.com/jordan-wright/email) - A robust and flexible email library for Go. +- [email-verifier](https://github.com/AfterShip/email-verifier) - A Go library for email verification without sending any emails. +- [go-dkim](https://github.com/toorop/go-dkim) - DKIM library, to sign & verify email. +- [go-email-normalizer](https://github.com/dimuska139/go-email-normalizer) - Golang library for providing a canonical representation of email address. +- [go-email-validator](https://github.com/go-email-validator/go-email-validator) - Modular email validator for syntax, disposable, smtp, etc... checking. +- [go-imap](https://github.com/emersion/go-imap) - IMAP library for clients and servers. +- [go-mail](https://github.com/wneessen/go-mail) - A simple Go library for sending mails in Go. +- [go-message](https://github.com/emersion/go-message) - Streaming library for the Internet Message Format and mail messages. +- [go-premailer](https://github.com/vanng822/go-premailer) - Inline styling for HTML mail in Go. +- [go-simple-mail](https://github.com/xhit/go-simple-mail) - Very simple package to send emails with SMTP Keep Alive and two timeouts: Connect and Send. +- [Hectane](https://github.com/hectane/hectane) - Lightweight SMTP client providing an HTTP API. +- [hermes](https://github.com/matcornic/hermes) - Golang package that generates clean, responsive HTML e-mails. +- [Maddy](https://github.com/foxcpp/maddy) - All-in-one (SMTP, IMAP, DKIM, DMARC, MTA-STS, DANE) email server +- [mailchain](https://github.com/mailchain/mailchain) - Send encrypted emails to blockchain addresses written in Go. +- [mailgun-go](https://github.com/mailgun/mailgun-go) - Go library for sending mail with the Mailgun API. +- [MailHog](https://github.com/mailhog/MailHog) - Email and SMTP testing with web and API interface. +- [Mailpit](https://github.com/axllent/mailpit) - Email and SMTP testing tool for developers. +- [mailx](https://github.com/valord577/mailx) - Mailx is a library that makes it easier to send email via SMTP. It is an enhancement of the golang standard library `net/smtp`. +- [mox](https://github.com/mjl-/mox) - Modern full-featured secure mail server for low-maintenance, self-hosted email. +- [SendGrid](https://github.com/sendgrid/sendgrid-go) - SendGrid's Go library for sending email. +- [smtp](https://github.com/mailhog/smtp) - SMTP server protocol state machine. +- [smtpmock](https://github.com/mocktools/go-smtp-mock) - Lightweight configurable multithreaded fake SMTP server. Mimic any SMTP behaviour for your test environment. +- [truemail-go](https://github.com/truemail-rb/truemail-go) - Configurable Golang email validator/verifier. Verify email via Regex, DNS, SMTP and even more. + +**[⬆ back to top](#contents)** ## Embeddable Scripting Languages -*Embedding other languages inside your go code* - -* [agora](https://github.com/PuerkitoBio/agora) - Dynamically typed, embeddable programming language in Go -* [anko](https://github.com/mattn/anko) - Scriptable interpreter written in Go -* [gisp](https://github.com/jcla1/gisp) - Simple LISP in Go -* [go-duktape](https://github.com/olebedev/go-duktape) - Duktape JavaScript engine bindings for Go -* [go-lua](https://github.com/Shopify/go-lua) - A port of the Lua 5.2 VM to pure Go -* [go-python](https://github.com/sbinet/go-python) - naive go bindings to the CPython C-API -* [golua](https://github.com/aarzilli/golua) - Go bindings for Lua C API -* [otto](https://github.com/robertkrimen/otto) - A JavaScript interpreter written in Go -* [purl](https://github.com/ian-kent/purl) - Perl 5.18.2 embedded in Go - +_Embedding other languages inside your go code._ + +- [anko](https://github.com/mattn/anko) - Scriptable interpreter written in Go. +- [binder](https://github.com/alexeyco/binder) - Go to Lua binding library, based on [gopher-lua](https://github.com/yuin/gopher-lua). +- [cel-go](https://github.com/google/cel-go) - Fast, portable, non-Turing complete expression evaluation with gradual typing. +- [ecal](https://github.com/krotik/ecal) - A simple embeddable scripting language which supports concurrent event processing. +- [expr](https://github.com/antonmedv/expr) - Expression evaluation engine for Go: fast, non-Turing complete, dynamic typing, static typing. +- [gentee](https://github.com/gentee/gentee) - Embeddable scripting programming language. +- [gisp](https://github.com/jcla1/gisp) - Simple LISP in Go. +- [go-duktape](https://github.com/olebedev/go-duktape) - Duktape JavaScript engine bindings for Go. +- [go-lua](https://github.com/Shopify/go-lua) - Port of the Lua 5.2 VM to pure Go. +- [go-php](https://github.com/deuill/go-php) - PHP bindings for Go. +- [go-python](https://github.com/sbinet/go-python) - naive go bindings to the CPython C-API. +- [goal](https://codeberg.org/anaseto/goal) - An embeddable scripting array language. +- [goja](https://github.com/dop251/goja) - ECMAScript 5.1(+) implementation in Go. +- [golua](https://github.com/aarzilli/golua) - Go bindings for Lua C API. +- [gopher-lua](https://github.com/yuin/gopher-lua) - Lua 5.1 VM and compiler written in Go. +- [gval](https://github.com/PaesslerAG/gval) - A highly customizable expression language written in Go. +- [metacall](https://github.com/metacall/core) - Cross-platform Polyglot Runtime which supports NodeJS, JavaScript, TypeScript, Python, Ruby, C#, WebAssembly, Java, Cobol and more. +- [ngaro](https://github.com/db47h/ngaro) - Embeddable Ngaro VM implementation enabling scripting in Retro. +- [prolog](https://github.com/ichiban/prolog) - Embeddable Prolog. +- [purl](https://github.com/ian-kent/purl) - Perl 5.18.2 embedded in Go. +- [starlark-go](https://github.com/google/starlark-go) - Go implementation of Starlark: Python-like language with deterministic evaluation and hermetic execution. +- [starlet](https://github.com/1set/starlet) - Go wrapper for [starlark-go](https://github.com/google/starlark-go) that simplifies script execution, offers data conversion, and useful Starlark libraries and extensions. +- [tengo](https://github.com/d5/tengo) - Bytecode compiled script language for Go. +- [Wa/凹语言](https://github.com/wa-lang/wa) - The Wa Programming Language embedded in Go. + +**[⬆ back to top](#contents)** + +## Error Handling + +_Libraries for handling errors._ + +- [emperror](https://github.com/emperror/emperror) - Error handling tools and best practices for Go libraries and applications. +- [eris](https://github.com/rotisserie/eris) - A better way to handle, trace, and log errors in Go. Compatible with the standard error library and github.com/pkg/errors. +- [errlog](https://github.com/snwfdhmp/errlog) - Hackable package that determines responsible source code for an error (and some other fast-debugging features). Pluggable to any logger in-place. +- [errors](https://github.com/emperror/errors) - Drop-in replacement for the standard library errors package and github.com/pkg/errors. Provides various error handling primitives. +- [errors](https://github.com/neuronlabs/errors) - Simple golang error handling with classification primitives. +- [errors](https://github.com/PumpkinSeed/errors) - The most simple error wrapper with awesome performance and minimal memory overhead. +- [errors](https://gitlab.com/tozd/go/errors) - Providing errors with a stack trace and optional structured details. Compatible with github.com/pkg/errors API but does not use it internally. +- [errors](https://github.com/naughtygopher/errors) - Drop-in replacement for builtin Go errors. This is a minimal error handling package with custom error types, user friendly messages, Unwrap & Is. With very easy to use and straightforward helper functions. +- [errors](https://github.com/cockroachdb/errors) - Go error library with error portability over the network. +- [errorx](https://github.com/joomcode/errorx) - A feature rich error package with stack traces, composition of errors and more. +- [exception](https://github.com/rbrahul/exception) - A simple utility package for exception handling with try-catch in Golang. +- [Falcon](https://github.com/SonicRoshan/falcon) - A Simple Yet Highly Powerful Package For Error Handling. +- [Fault](https://github.com/Southclaws/fault) - An ergonomic mechanism for wrapping errors in order to facilitate structured metadata and context for error values. +- [go-multierror](https://github.com/hashicorp/go-multierror) - Go (golang) package for representing a list of errors as a single error. +- [multierr](https://github.com/uber-go/multierr) - Package for representing a list of errors as a single error. +- [oops](https://github.com/samber/oops) - Error handling with context, stack trace and source fragments. +- [tracerr](https://github.com/ztrue/tracerr) - Golang errors with stack trace and source fragments. + +**[⬆ back to top](#contents)** + +## File Handling + +_Libraries for handling files and file systems._ + +- [afero](https://github.com/spf13/afero) - FileSystem Abstraction System for Go. +- [afs](https://github.com/viant/afs) - Abstract File Storage (mem, scp, zip, tar, cloud: s3, gs) for Go. +- [baraka](https://github.com/xis/baraka) - A library to process http file uploads easily. +- [bigfile](https://github.com/bigfile/bigfile) - A file transfer system, support to manage files with http api, rpc call and ftp client. +- [checksum](https://github.com/codingsince1985/checksum) - Compute message digest, like MD5, SHA256, SHA1, CRC or BLAKE2s, for large files. +- [copy](https://github.com/otiai10/copy) - Copy directory recursively. +- [flop](https://github.com/homedepot/flop) - File operations library which aims to mirror feature parity with [GNU cp](https://www.gnu.org/software/coreutils/manual/html_node/cp-invocation.html). +- [gdu](https://github.com/dundee/gdu) - Disk usage analyzer with console interface. +- [go-csv-tag](https://github.com/artonge/go-csv-tag) - Load csv file using tag. +- [go-decent-copy](https://github.com/hugocarreira/go-decent-copy) - Copy files for humans. +- [go-exiftool](https://github.com/barasher/go-exiftool) - Go bindings for ExifTool, the well-known library used to extract as much metadata as possible (EXIF, IPTC, ...) from files (pictures, PDF, office, ...). +- [go-gtfs](https://github.com/artonge/go-gtfs) - Load gtfs files in go. +- [go-wkhtmltopdf](https://github.com/SebastiaanKlippert/go-wkhtmltopdf) - A package to convert an HTML template to a PDF file. +- [gofs](https://github.com/no-src/gofs) - A cross-platform real-time file synchronization tool out of the box. +- [gut/yos](https://github.com/1set/gut) - Simple and reliable package for file operations like copy/move/diff/list on files, directories and symbolic links. +- [higgs](https://github.com/dastoori/higgs) - A tiny cross-platform Go library to hide/unhide files and directories. +- [iso9660](https://github.com/kdomanski/iso9660) - A package for reading and creating ISO9660 disk images +- [notify](https://github.com/rjeczalik/notify) - File system event notification library with simple API, similar to os/signal. +- [opc](https://github.com/qmuntal/opc) - Load Open Packaging Conventions (OPC) files for Go. +- [parquet](https://github.com/parsyl/parquet) - Read and write [parquet](https://parquet.apache.org) files. +- [pathtype](https://github.com/jonchun/pathtype) - Treat paths as their own type instead of using strings. +- [pdfcpu](https://github.com/pdfcpu/pdfcpu) - PDF processor. +- [skywalker](https://github.com/dixonwille/skywalker) - Package to allow one to concurrently go through a filesystem with ease. +- [todotxt](https://github.com/1set/todotxt) - Go library for Gina Trapani's [_todo.txt_](http://todotxt.org/) files, supports parsing and manipulating of task lists in the [_todo.txt_ format](https://github.com/todotxt/todo.txt). +- [vfs](https://github.com/C2FO/vfs) - A pluggable, extensible, and opinionated set of filesystem functionality for Go across a number of filesystem types such as os, S3, and GCS. + +**[⬆ back to top](#contents)** ## Financial -*Packages for accounting and finance* - -* [decimal](https://github.com/shopspring/decimal) - Arbitrary-precision fixed-point decimal numbers - +_Packages for accounting and finance._ + +- [accounting](https://github.com/leekchan/accounting) - money and currency formatting for golang. +- [ach](https://github.com/moov-io/ach) - A reader, writer, and validator for Automated Clearing House (ACH) files. +- [bbgo](https://github.com/c9s/bbgo) - A crypto trading bot framework written in Go. Including common crypto exchange API, standard indicators, back-testing and many built-in strategies. +- [currency](https://github.com/bojanz/currency) - Handles currency amounts, provides currency information and formatting. +- [currency](https://github.com/naughtygopher/currency) - High performant & accurate currency computation package. +- [decimal](https://github.com/shopspring/decimal) - Arbitrary-precision fixed-point decimal numbers. +- [decimal](https://github.com/govalues/decimal) - Immutable decimal numbers with panic-free arithmetic. +- [fpdecimal](https://github.com/nikolaydubina/fpdecimal) - Fast and precise serialization and arithmetic for small fixed-point decimals +- [fpmoney](https://github.com/nikolaydubina/fpmoney) - Fast and simple ISO4217 fixed-point decimal money. +- [go-finance](https://github.com/alpeb/go-finance) - Library of financial functions for time value of money (annuities), cash flow, interest rate conversions, bonds and depreciation calculations. +- [go-finance](https://github.com/pieterclaerhout/go-finance) - Module to fetch exchange rates, check VAT numbers via VIES and check IBAN bank account numbers. +- [go-finnhub](https://github.com/m1/go-finnhub) - Client for stock market, forex and crypto data from finnhub.io. Access real-time financial market data from 60+ stock exchanges, 10 forex brokers, and 15+ crypto exchanges. +- [go-money](https://github.com/rhymond/go-money) - Implementation of Fowler's Money pattern. +- [go-nowpayments](https://github.com/matm/go-nowpayments) - Library for the crypto NOWPayments API. +- [money](https://github.com/govalues/money) - Immutable monetary amounts and exchange rates with panic-free arithmetic. +- [ofxgo](https://github.com/aclindsa/ofxgo) - Query OFX servers and/or parse the responses (with example command-line client). +- [orderbook](https://github.com/i25959341/orderbook) - Matching Engine for Limit Order Book in Golang. +- [payme](https://github.com/jovandeginste/payme) - QR code generator (ASCII & PNG) for SEPA payments. +- [sleet](https://github.com/BoltApp/sleet) - One unified interface for multiple Payment Service Providers (PsP) to process online payment. +- [swift](https://code.pfad.fr/swift/) - Offline validity check of IBAN (International Bank Account Number) and retrieval of BIC (for some countries). +- [techan](https://github.com/sdcoffey/techan) - Technical analysis library with advanced market analysis and trading strategies. +- [ticker](https://github.com/achannarasappa/ticker) - Terminal stock watcher and stock position tracker. +- [transaction](https://github.com/claygod/transaction) - Embedded transactional database of accounts, running in multithreaded mode. +- [vat](https://github.com/dannyvankooten/vat) - VAT number validation & EU VAT rates. + +**[⬆ back to top](#contents)** ## Forms -*Libraries for working with forms.* - -* [bind](https://github.com/robfig/bind) - Bind form data to any Go values -* [binding](https://github.com/mholt/binding) - Binds form and JSON data from net/http Request to struct. -* [formam](https://github.com/monoculum/formam) - decode form's values into a struct. -* [nosurf](https://github.com/justinas/nosurf) - A CSRF protection middleware for Go. +_Libraries for working with forms._ +- [bind](https://github.com/robfig/bind) - Bind form data to any Go values. +- [binding](https://github.com/mholt/binding) - Binds form and JSON data from net/http Request to struct. +- [checker](https://github.com/cinar/checker) - Checker helps validating user input through rules defined in struct tags or directly through functions. +- [conform](https://github.com/leebenson/conform) - Keeps user input in check. Trims, sanitizes & scrubs data based on struct tags. +- [form](https://github.com/go-playground/form) - Decodes url.Values into Go value(s) and Encodes Go value(s) into url.Values. Dual Array and Full map support. +- [formam](https://github.com/monoculum/formam) - decode form's values into a struct. +- [forms](https://github.com/albrow/forms) - Framework-agnostic library for parsing and validating form/JSON data which supports multipart forms and files. +- [gbind](https://github.com/bdjimmy/gbind) - Bind data to any Go value. Can use built-in and custom expression binding capabilities; supports data validation +- [gorilla/csrf](https://github.com/gorilla/csrf) - CSRF protection for Go web applications & services. +- [httpin](https://github.com/ggicci/httpin) - Decode an HTTP request into a custom struct, including querystring, forms, HTTP headers, etc. +- [nosurf](https://github.com/justinas/nosurf) - CSRF protection middleware for Go. +- [qs](https://github.com/sonh/qs) - Go module for encoding structs into URL query parameters. +- [queryparam](https://github.com/tomwright/queryparam) - Decode `url.Values` into usable struct values of standard or custom types. -## Game Development - -*Awesome game development libraries.* +**[⬆ back to top](#contents)** -* [GarageEngine](https://github.com/vova616/GarageEngine) - 2d game engine written in Go working on OpenGL. -* [glop](https://github.com/runningwild/glop) - Glop (Game Library Of Power) is a fairly simple cross-platform game library. -* [go-astar](https://github.com/beefsack/go-astar) - Go implementation of the A* path finding algorithm -* [go-collada](https://github.com/GlenKelley/go-collada) - Go package for working with the Collada file format. -* [go3d](https://github.com/ungerik/go3d) - A performance oriented 2D/3D math package for Go -* [gonet](https://github.com/xtaci/gonet) - A game server skeleton implemented with golang -* [Leaf](https://github.com/name5566/leaf) - A lightweight game server framework +## Functional +_Packages to support functional programming in Go._ -## Generation & Generics +- [fp-go](https://github.com/repeale/fp-go) - Collection of Functional Programming helpers powered by Golang 1.18+ generics. +- [fpGo](https://github.com/TeaEntityLab/fpGo) - Monad, Functional Programming features for Golang. +- [fuego](https://github.com/seborama/fuego) - Functional Experiment in Go. +- [go-functional](https://github.com/BooleanCat/go-functional) - Functional programming in Go using generics +- [go-underscore](https://github.com/tobyhede/go-underscore) - Useful collection of helpfully functional Go collection utilities. +- [gofp](https://github.com/rbrahul/gofp) - A lodash like powerful utility library for Golang. +- [mo](https://github.com/samber/mo) - Monads and popular FP abstractions, based on Go 1.18+ Generics (Option, Result, Either...). +- [underscore](https://github.com/rjNemo/underscore) - Functional programming helpers for Go 1.18 and beyond. +- [valor](https://github.com/phelmkamp/valor) - Generic option and result types that optionally contain a value. -*Tools to enhance the language with features like generics via code generation* +**[⬆ back to top](#contents)** -* [gen](https://github.com/clipperhouse/gen) - Code generation tool for ‘generics’-like functionality. -* [go-linq](https://github.com/ahmetalpbalkan/go-linq) - .NET LINQ-like query methods for Go. -* [pkgreflect](https://github.com/ungerik/pkgreflect) - A Go preprocessor for package scoped reflection. +## Game Development +_Awesome game development libraries._ + +- [Azul3D](https://github.com/azul3d/engine) - 3D game engine written in Go. +- [Ebitengine](https://github.com/hajimehoshi/ebiten) - dead simple 2D game engine in Go. +- [ecs](https://github.com/andygeiss/ecs) - Build your own Game-Engine based on the Entity Component System concept in Golang. +- [engo](https://github.com/EngoEngine/engo) - Engo is an open-source 2D game engine written in Go. It follows the Entity-Component-System paradigm. +- [fantasyname](https://github.com/s0rg/fantasyname) - Fantasy names generator. +- [g3n](https://github.com/g3n/engine) - Go 3D Game Engine. +- [go-astar](https://github.com/beefsack/go-astar) - Go implementation of the A\* path finding algorithm. +- [go-sdl2](https://github.com/veandco/go-sdl2) - Go bindings for the [Simple DirectMedia Layer](https://www.libsdl.org/). +- [go3d](https://github.com/ungerik/go3d) - Performance oriented 2D/3D math package for Go. +- [gonet](https://github.com/xtaci/gonet) - Game server skeleton implemented with golang. +- [goworld](https://github.com/xiaonanln/goworld) - Scalable game server engine, featuring space-entity framework and hot-swapping. +- [grid](https://github.com/s0rg/grid) - Generic 2D grid with ray-casting, shadow-casting and path finding. +- [Harfang3D](https://github.com/harfang3d/harfang3d) - 3D engine for the Go language, works on Windows and Linux ([Harfang on Go.dev](https://github.com/harfang3d/harfang-go)). +- [Leaf](https://github.com/name5566/leaf) - Lightweight game server framework. +- [nano](https://github.com/lonng/nano) - Lightweight, facility, high performance golang based game server framework. +- [Oak](https://github.com/oakmound/oak) - Pure Go game engine. +- [Pitaya](https://github.com/topfreegames/pitaya) - Scalable game server framework with clustering support and client libraries for iOS, Android, Unity and others through the C SDK. +- [Pixel](https://github.com/faiface/pixel) - Hand-crafted 2D game library in Go. +- [prototype](https://github.com/gonutz/prototype) - Cross-platform (Windows/Linux/Mac) library for creating desktop games using a minimal API. +- [raylib-go](https://github.com/gen2brain/raylib-go) - Go bindings for [raylib](https://www.raylib.com/), a simple and easy-to-use library to learn videogames programming. +- [termloop](https://github.com/JoelOtter/termloop) - Terminal-based game engine for Go, built on top of Termbox. +- [tile](https://github.com/kelindar/tile) - Data-oriented and cache-friendly 2D Grid library (TileMap), includes pathfinding, observers and import/export. + +**[⬆ back to top](#contents)** + +## Generators + +_Tools that generate Go code._ + +- [convergen](https://github.com/reedom/convergen) - Feature rich type-to-type copy code generator. +- [copygen](https://github.com/switchupcb/copygen) - Generate type-to-type and type-based code without reflection. +- [generis](https://github.com/senselogic/GENERIS) - Code generation tool providing generics, free-form macros, conditional compilation and HTML templating. +- [go-enum](https://github.com/abice/go-enum) - Code generation for enums from code comments. +- [go-linq](https://github.com/ahmetalpbalkan/go-linq) - .NET LINQ-like query methods for Go. +- [goderive](https://github.com/awalterschulze/goderive) - Derives functions from input types +- [goverter](https://github.com/jmattheis/goverter) - Generate converters by defining an interface. +- [GoWrap](https://github.com/hexdigest/gowrap) - Generate decorators for Go interfaces using simple templates. +- [interfaces](https://github.com/rjeczalik/interfaces) - Command line tool for generating interface definitions. +- [jennifer](https://github.com/dave/jennifer) - Generate arbitrary Go code without templates. +- [oapi-codegen](https://github.com/deepmap/oapi-codegen) - This package contains a set of utilities for generating Go boilerplate code for services based on OpenAPI 3.0 API definitions. +- [typeregistry](https://github.com/xiaoxin01/typeregistry) - A library to create type dynamically. + +**[⬆ back to top](#contents)** + +## Geographic + +_Geographic tools and servers_ + +- [geoos](https://github.com/spatial-go/geoos) - A library provides spatial data and geometric algorithms. +- [geoserver](https://github.com/hishamkaram/geoserver) - geoserver Is a Go Package For Manipulating a GeoServer Instance via the GeoServer REST API. +- [gismanager](https://github.com/hishamkaram/gismanager) - Publish Your GIS Data(Vector Data) to PostGIS and Geoserver. +- [godal](https://github.com/airbusgeo/godal) - Go wrapper for GDAL. +- [H3](https://github.com/uber/h3-go) - Go bindings for H3, a hierarchical hexagonal geospatial indexing system. +- [H3 GeoJSON](https://github.com/mmadfox/go-geojson2h3) - Conversion utilities between H3 indexes and GeoJSON. +- [H3GeoDist](https://github.com/mmadfox/go-h3geo-dist) - Distribution of Uber H3geo cells by virtual nodes. +- [mbtileserver](https://github.com/consbio/mbtileserver) - A simple Go-based server for map tiles stored in mbtiles format. +- [osm](https://github.com/paulmach/osm) - Library for reading, writing and working with OpenStreetMap data and APIs. +- [pbf](https://github.com/maguro/pbf) - OpenStreetMap PBF golang encoder/decoder. +- [S2 geojson](https://github.com/pantrif/s2-geojson) - Convert geojson to s2 cells & demonstrating some S2 geometry features on map. +- [S2 geometry](https://github.com/golang/geo) - S2 geometry library in Go. +- [simplefeatures](https://github.com/peterstace/simplefeatures) - simplesfeatures is a 2D geometry library that provides Go types that model geometries, as well as algorithms that operate on them. +- [Tile38](https://github.com/tidwall/tile38) - Geolocation DB with spatial index and realtime geofencing. +- [Web-Mercator-Projection](https://github.com/jorelosorio/web-mercator-projection) A project to easily use and convert LonLat, Point and Tile to display info, markers, etc, in a map using the Web Mercator Projection. +- [WGS84](https://github.com/wroge/wgs84) - Library for Coordinate Conversion and Transformation (ETRS89, OSGB36, NAD83, RGF93, Web Mercator, UTM). + +**[⬆ back to top](#contents)** + +## Go Compilers + +_Tools for compiling Go to other languages._ + +- [c2go](https://github.com/goplus/c2go) - Convert C code to Go code. +- [c4go](https://github.com/Konstantin8105/c4go) - Transpile C code to Go code. +- [esp32](https://github.com/andygeiss/esp32-transpiler) - Transpile Go into Arduino code. +- [f4go](https://github.com/Konstantin8105/f4go) - Transpile FORTRAN 77 code to Go code. +- [gopherjs](https://github.com/gopherjs/gopherjs) - Compiler from Go to JavaScript. +- [tardisgo](https://github.com/tardisgo/tardisgo) - Golang to Haxe to CPP/CSharp/Java/JavaScript transpiler. + +**[⬆ back to top](#contents)** + +## Goroutines + +_Tools for managing and working with Goroutines._ + +- [ants](https://github.com/panjf2000/ants) - A high-performance and low-cost goroutine pool in Go. +- [artifex](https://github.com/borderstech/artifex) - Simple in-memory job queue for Golang using worker-based dispatching. +- [async](https://github.com/yaitoo/async) - An asynchronous task package with async/await style for Go. +- [async](https://github.com/reugn/async) - An alternative sync library for Go (Future, Promise, Locks). +- [async](https://github.com/studiosol/async) - A safe way to execute functions asynchronously, recovering them in case of panic. +- [async-job](https://github.com/lab210-dev/async-job) - AsyncJob is an asynchronous queue job manager with light code, clear and speed. +- [breaker](https://github.com/kamilsk/breaker) - Flexible mechanism to make execution flow interruptible. +- [channelify](https://github.com/ddelizia/channelify) - Transform your function to return channels for easy and powerful parallel processing. +- [conc](https://github.com/sourcegraph/conc) - `conc` is your toolbelt for structured concurrency in go, making common tasks easier and safer. +- [concurrency-limiter](https://github.com/vivek-ng/concurrency-limiter) - Concurrency limiter with support for timeouts, dynamic priority and context cancellation of goroutines. +- [conexec](https://github.com/ITcathyh/conexec) - A concurrent toolkit to help execute funcs concurrently in an efficient and safe way. It supports specifying the overall timeout to avoid blocking and uses goroutine pool to improve efficiency. +- [cyclicbarrier](https://github.com/marusama/cyclicbarrier) - CyclicBarrier for golang. +- [execpool](https://github.com/hexdigest/execpool) - A pool built around exec.Cmd that spins up a given number of processes in advance and attaches stdin and stdout to them when needed. Very similar to FastCGI or Apache Prefork MPM but works for any command. +- [flowmatic](https://github.com/carlmjohnson/flowmatic) - Structured concurrency made easy. +- [go-accumulator](https://github.com/nar10z/go-accumulator) - Solution for accumulation of events and their subsequent processing. +- [go-actor](https://github.com/vladopajic/go-actor) - A tiny library for writing concurrent programs using actor model. +- [go-floc](https://github.com/workanator/go-floc) - Orchestrate goroutines with ease. +- [go-flow](https://github.com/kamildrazkiewicz/go-flow) - Control goroutines execution order. +- [go-tools/multithreading](https://github.com/nikhilsaraf/go-tools) - Manage a pool of goroutines using this lightweight library with a simple API. +- [go-trylock](https://github.com/subchen/go-trylock) - TryLock support on read-write lock for Golang. +- [go-waitgroup](https://github.com/pieterclaerhout/go-waitgroup) - Like `sync.WaitGroup` with error handling and concurrency control. +- [go-workerpool](https://github.com/zenthangplus/go-workerpool) - Inspired from Java Thread Pool, Go WorkerPool aims to control heavy Go Routines. +- [go-workers](https://github.com/catmullet/go-workers) - Easily and safely run workers for large data processing pipelines. +- [goccm](https://github.com/zenthangplus/goccm) - Go Concurrency Manager package limits the number of goroutines that allowed to run concurrently. +- [gohive](https://github.com/loveleshsharma/gohive) - A highly performant and easy to use Goroutine pool for Go. +- [gollback](https://github.com/vardius/gollback) - asynchronous simple function utilities, for managing execution of closures and callbacks. +- [gowl](https://github.com/hamed-yousefi/gowl) - Gowl is a process management and process monitoring tool at once. An infinite worker pool gives you the ability to control the pool and processes and monitor their status. +- [goworker](https://github.com/benmanns/goworker) - goworker is a Go-based background worker. +- [gowp](https://github.com/xxjwxc/gowp) - gowp is concurrency limiting goroutine pool. +- [gpool](https://github.com/Sherifabdlnaby/gpool) - manages a resizeable pool of context-aware goroutines to bound concurrency. +- [grpool](https://github.com/ivpusic/grpool) - Lightweight Goroutine pool. +- [hands](https://github.com/duanckham/hands) - A process controller used to control the execution and return strategies of multiple goroutines. +- [Hunch](https://github.com/AaronJan/Hunch) - Hunch provides functions like: `All`, `First`, `Retry`, `Waterfall` etc., that makes asynchronous flow control more intuitive. +- [kyoo](https://github.com/dirkaholic/kyoo) - Provides an unlimited job queue and concurrent worker pools. +- [neilotoole/errgroup](https://github.com/neilotoole/errgroup) - Drop-in alternative to `sync/errgroup`, limited to a pool of N worker goroutines. +- [nursery](https://github.com/arunsworld/nursery) - Structured concurrency in Go. +- [oversight](https://pkg.go.dev/cirello.io/oversight) - Oversight is a complete implementation of the Erlang supervision trees. +- [parallel-fn](https://github.com/rafaeljesus/parallel-fn) - Run functions in parallel. +- [pond](https://github.com/alitto/pond) - Minimalistic and High-performance goroutine worker pool written in Go. +- [pool](https://github.com/go-playground/pool) - Limited consumer goroutine or unlimited goroutine pool for easier goroutine handling and cancellation. +- [rill](https://github.com/destel/rill) - Go concurrency with channel transformations. No boilerplate, type safety, batching and error handling. +- [routine](https://github.com/timandy/routine) - `routine` is a `ThreadLocal` for go library. It encapsulates and provides some easy-to-use, non-competitive, high-performance `goroutine` context access interfaces, which can help you access coroutine context information more gracefully. +- [routine](https://github.com/x-mod/routine) - go routine control with context, support: Main, Go, Pool and some useful Executors. +- [semaphore](https://github.com/kamilsk/semaphore) - Semaphore pattern implementation with timeout of lock/unlock operations based on channel and context. +- [semaphore](https://github.com/marusama/semaphore) - Fast resizable semaphore implementation based on CAS (faster than channel-based semaphore implementations). +- [stl](https://github.com/ssgreg/stl) - Software transactional locks based on Software Transactional Memory (STM) concurrency control mechanism. +- [threadpool](https://github.com/shettyh/threadpool) - Golang threadpool implementation. +- [tunny](https://github.com/Jeffail/tunny) - Goroutine pool for golang. +- [worker-pool](https://github.com/vardius/worker-pool) - goworker is a Go simple async worker pool. +- [workerpool](https://github.com/gammazero/workerpool) - Goroutine pool that limits the concurrency of task execution, not the number of tasks queued. + +**[⬆ back to top](#contents)** ## GUI -*Libraries for building GUI Applications* - -* [go-gtk](http://mattn.github.io/go-gtk/) - Go bindings for GTK -* [go-qml](https://github.com/go-qml/qml) - QML support for the Go language -* [gotk3](https://github.com/conformal/gotk3) - Go bindings for GTK3. -* [gxui](https://github.com/google/gxui) - A Go cross platform UI library. -* [ui](https://github.com/andlabs/ui) - Platform-native GUI library for Go. -* [walk](https://github.com/lxn/walk) - Windows application library kit for Go. +_Libraries for building GUI Applications._ + +_Toolkits_ + +- [app](https://github.com/murlokswarm/app) - Package to create apps with GO, HTML and CSS. Supports: MacOS, Windows in progress. +- [cimgui-go](https://github.com/AllenDang/cimgui-go) - Auto generated Go wrapper for [Dear ImGui](https://github.com/ocornut/imgui) via [cimgui](https://github.com/cimgui/cimgui). +- [Cogent Core](https://github.com/cogentcore/core) - A framework for building 2D and 3D apps that run on macOS, Windows, Linux, iOS, Android, and the web. +- [DarwinKit](https://github.com/progrium/darwinkit) - Build native macOS applications using Go. +- [energy](https://github.com/energye/energy) - Cross-platform based on LCL(Native System UI Control Library) and CEF(Chromium Embedded Framework) (Windows/ macOS / Linux) +- [fyne](https://github.com/fyne-io/fyne) - Cross platform native GUIs designed for Go based on Material Design. Supports: Linux, macOS, Windows, BSD, iOS and Android. +- [gio](https://gioui.org) - Gio is a library for writing cross-platform immediate mode GUI-s in Go. Gio supports all the major platforms: Linux, macOS, Windows, Android, iOS, FreeBSD, OpenBSD and WebAssembly. +- [go-gtk](https://mattn.github.io/go-gtk/) - Go bindings for GTK. +- [go-sciter](https://github.com/sciter-sdk/go-sciter) - Go bindings for Sciter: the Embeddable HTML/CSS/script engine for modern desktop UI development. Cross platform. +- [Goey](https://bitbucket.org/rj/goey/src/master/) - Cross platform UI toolkit aggregator for Windows / Linux / Mac. GTK, Cocoa, Windows API +- [goradd/html5tag](https://github.com/goradd/html5tag) - Library for outputting HTML5 tags. +- [gotk3](https://github.com/gotk3/gotk3) - Go bindings for GTK3. +- [gowd](https://github.com/dtylman/gowd) - Rapid and simple desktop UI development with GO, HTML, CSS and NW.js. Cross platform. +- [qt](https://github.com/therecipe/qt) - Qt binding for Go (support for Windows / macOS / Linux / Android / iOS / Sailfish OS / Raspberry Pi). +- [Spot](https://github.com/roblillack/spot) - Reactive, cross-platform desktop GUI toolkit. +- [ui](https://github.com/andlabs/ui) - Platform-native GUI library for Go. Cross platform. +- [unison](https://github.com/richardwilkes/unison) - A unified graphical user experience toolkit for Go desktop applications. macOS, Windows, and Linux are supported. +- [Wails](https://wails.io) - Mac, Windows, Linux desktop apps with HTML UI using built-in OS HTML renderer. +- [walk](https://github.com/lxn/walk) - Windows application library kit for Go. +- [webview](https://github.com/zserge/webview) - Cross-platform webview window with simple two-way JavaScript bindings (Windows / macOS / Linux). + +_Interaction_ + +- [AppIndicator Go](https://github.com/gopherlibs/appindicator) - Go bindings for libappindicator3 C library. +- [gosx-notifier](https://github.com/deckarep/gosx-notifier) - OSX Desktop Notifications library for Go. +- [mac-activity-tracker](https://github.com/prashantgupta24/activity-tracker) - OSX library to notify about any (pluggable) activity on your machine. +- [mac-sleep-notifier](https://github.com/prashantgupta24/mac-sleep-notifier) - OSX Sleep/Wake notifications in golang. +- [robotgo](https://github.com/go-vgo/robotgo) - Go Native cross-platform GUI system automation. Control the mouse, keyboard and other. +- [systray](https://github.com/getlantern/systray) - Cross platform Go library to place an icon and menu in the notification area. +- [trayhost](https://github.com/shurcooL/trayhost) - Cross-platform Go library to place an icon in the host operating system's taskbar. +- [zenity](https://github.com/ncruces/zenity) - Cross-platform Go library and CLI to create simple dialogs that interact graphically with the user. + +**[⬆ back to top](#contents)** ## Hardware -*Libraries for interacting with hardware.* - -* [embd](https://github.com/kidoman/embd) - Embedded Programming Framework supporting Raspberry Pi, Beaglebone Black, etc. -* [gobot](https://github.com/hybridgroup/gobot) - Framework for robotics, physical computing, and the Internet of Things +_Libraries, tools, and tutorials for interacting with hardware._ -## Images +- [arduino-cli](https://github.com/arduino/arduino-cli) - Official Arduino CLI and library. Can run standalone, or be incorporated into larger Go projects. +- [emgo](https://github.com/ziutek/emgo) - Go-like language for programming embedded systems (e.g. STM32 MCU). +- [ghw](https://github.com/jaypipes/ghw) - Golang hardware discovery/inspection library. +- [go-osc](https://github.com/hypebeast/go-osc) - Open Sound Control (OSC) bindings for Go. +- [go-rpio](https://github.com/stianeikeland/go-rpio) - GPIO for Go, doesn't require cgo. +- [goroslib](https://github.com/aler9/goroslib) - Robot Operating System (ROS) library for Go. +- [joystick](https://github.com/0xcafed00d/joystick) - a polled API to read the state of an attached joystick. +- [sysinfo](https://github.com/zcalusic/sysinfo) - A pure Go library providing Linux OS / kernel / hardware system information. -*Libraries for manipulating images.* +**[⬆ back to top](#contents)** -* [geopattern](https://github.com/pravj/geopattern) - Create beautiful generative image patterns from a string. -* [gift](https://github.com/disintegration/gift) - Package of image processing filters. -* [go-cairo](https://github.com/ungerik/go-cairo) - Go binding for the cairo graphics library. -* [go-gd](https://github.com/bolknote/go-gd) - Go binding for GD library -* [go-nude](https://github.com/koyachi/go-nude) - Nudity detection with Go. -* [go-opencv](https://github.com/lazywei/go-opencv) - Go bindings for OpenCV. -* [go-webcolors](https://github.com/jyotiska/go-webcolors) - Port of webcolors library from Python to Go. -* [imagick](https://github.com/gographics/imagick) - Go binding to ImageMagick's MagickWand C API. -* [imaging](https://github.com/disintegration/imaging) - Simple Go image processing package. -* [img](https://github.com/hawx/img) - A selection of image manipulation tools. -* [resize](https://github.com/nfnt/resize) - Image resizing for the Go with common interpolation methods. -* [rez](https://github.com/bamiaux/rez) - Image resizing in pure Go and SIMD. -* [smartcrop](https://github.com/muesli/smartcrop) - Finds good crops for arbitrary images and crop sizes -* [svgo](https://github.com/ajstarks/svgo) - Go Language Library for SVG generation. +## Images +_Libraries for manipulating images._ + +- [bild](https://github.com/anthonynsimon/bild) - Collection of image processing algorithms in pure Go. +- [bimg](https://github.com/h2non/bimg) - Small package for fast and efficient image processing using libvips. +- [cameron](https://github.com/aofei/cameron) - An avatar generator for Go. +- [canvas](https://github.com/tdewolff/canvas) - Vector graphics to PDF, SVG or rasterized image. +- [color-extractor](https://github.com/marekm4/color-extractor) - Dominant color extractor with no external dependencies. +- [darkroom](https://github.com/gojek/darkroom) - An image proxy with changeable storage backends and image processing engines with focus on speed and resiliency. +- [draft](https://github.com/lucasepe/draft) - Generate High Level Microservice Architecture diagrams for GraphViz using simple YAML syntax. +- [geopattern](https://github.com/pravj/geopattern) - Create beautiful generative image patterns from a string. +- [gg](https://github.com/fogleman/gg) - 2D rendering in pure Go. +- [gift](https://github.com/disintegration/gift) - Package of image processing filters. +- [gltf](https://github.com/qmuntal/gltf) - Efficient and robust glTF 2.0 reader, writer and validator. +- [go-cairo](https://github.com/ungerik/go-cairo) - Go binding for the cairo graphics library. +- [go-gd](https://github.com/bolknote/go-gd) - Go binding for GD library. +- [go-nude](https://github.com/koyachi/go-nude) - Nudity detection with Go. +- [go-webcolors](https://github.com/jyotiska/go-webcolors) - Port of webcolors library from Python to Go. +- [go-webp](https://github.com/kolesa-team/go-webp) - Library for encode and decode webp pictures, using libwebp. +- [gocv](https://github.com/hybridgroup/gocv) - Go package for computer vision using OpenCV 3.3+. +- [goimagehash](https://github.com/corona10/goimagehash) - Go Perceptual image hashing package. +- [goimghdr](https://github.com/corona10/goimghdr) - The imghdr module determines the type of image contained in a file for Go. +- [govatar](https://github.com/o1egl/govatar) - Library and CMD tool for generating funny avatars. +- [govips](https://github.com/davidbyttow/govips) - A lightning fast image processing and resizing library for Go. +- [gowitness](https://github.com/sensepost/gowitness) - Screenshoting webpages using go and headless chrome on command line. +- [gridder](https://github.com/shomali11/gridder) - A Grid based 2D Graphics library. +- [image2ascii](https://github.com/qeesung/image2ascii) - Convert image to ASCII. +- [imagick](https://github.com/gographics/imagick) - Go binding to ImageMagick's MagickWand C API. +- [imaginary](https://github.com/h2non/imaginary) - Fast and simple HTTP microservice for image resizing. +- [imaging](https://github.com/disintegration/imaging) - Simple Go image processing package. +- [imagor](https://github.com/cshum/imagor) - Fast, secure image processing server and Go library, using libvips. +- [img](https://github.com/hawx/img) - Selection of image manipulation tools. +- [ln](https://github.com/fogleman/ln) - 3D line art rendering in Go. +- [mergi](https://github.com/noelyahan/mergi) - Tool & Go library for image manipulation (Merge, Crop, Resize, Watermark, Animate). +- [mort](https://github.com/aldor007/mort) - Storage and image processing server written in Go. +- [mpo](https://github.com/donatj/mpo) - Decoder and conversion tool for MPO 3D Photos. +- [picfit](https://github.com/thoas/picfit) - An image resizing server written in Go. +- [pt](https://github.com/fogleman/pt) - Path tracing engine written in Go. +- [rez](https://github.com/bamiaux/rez) - Image resizing in pure Go and SIMD. +- [scout](https://github.com/jonoton/scout) - Scout is a standalone open source software solution for DIY video security. +- [smartcrop](https://github.com/muesli/smartcrop) - Finds good crops for arbitrary images and crop sizes. +- [steganography](https://github.com/auyer/steganography) - Pure Go Library for LSB steganography. +- [stegify](https://github.com/DimitarPetrov/stegify) - Go tool for LSB steganography, capable of hiding any file within an image. +- [svgo](https://github.com/ajstarks/svgo) - Go Language Library for SVG generation. +- [tga](https://github.com/ftrvxmtrx/tga) - Package tga is a TARGA image format decoder/encoder. +- [transformimgs](https://github.com/Pixboost/transformimgs) - Transformimgs resizes and optimises images for Web using next-generation formats. +- [webp-server](https://github.com/mehdipourfar/webp-server) - Simple and minimal image server capable of storing, resizing, converting and caching images. + +**[⬆ back to top](#contents)** + +## IoT (Internet of Things) + +_Libraries for programming devices of the IoT._ + +- [connectordb](https://github.com/connectordb/connectordb) - Open-Source Platform for Quantified Self & IoT. +- [devices](https://github.com/goiot/devices) - Suite of libraries for IoT devices, experimental for x/exp/io. +- [ekuiper](https://github.com/lf-edge/ekuiper) - Lightweight data stream processing engine for IoT edge. +- [eywa](https://github.com/xcodersun/eywa) - Project Eywa is essentially a connection manager that keeps track of connected devices. +- [flogo](https://github.com/tibcosoftware/flogo) - Project Flogo is an Open Source Framework for IoT Edge Apps & Integration. +- [gatt](https://github.com/paypal/gatt) - Gatt is a Go package for building Bluetooth Low Energy peripherals. +- [gobot](https://github.com/hybridgroup/gobot/) - Gobot is a framework for robotics, physical computing, and the Internet of Things. +- [huego](https://github.com/amimof/huego) - An extensive Philips Hue client library for Go. +- [iot](https://github.com/vaelen/iot/) - IoT is a simple framework for implementing a Google IoT Core device. +- [mainflux](https://github.com/Mainflux/mainflux) - Industrial IoT Messaging and Device Management Server. +- [periph](https://periph.io/) - Peripherals I/O to interface with low-level board facilities. +- [rulego](https://github.com/rulego/rulego) - RuleGo is a lightweight, high-performance, embedded, orchestrable component-based rule engine for IoT edge. +- [sensorbee](https://github.com/sensorbee/sensorbee) - Lightweight stream processing engine for IoT. +- [shifu](https://github.com/Edgenesis/shifu) - Kubernetes native IoT development framework. +- [smart-home](https://github.com/e154/smart-home) - Software package for IoT automation. + +**[⬆ back to top](#contents)** + +## Job Scheduler + +_Libraries for scheduling jobs._ + +- [Cadence-client](https://github.com/uber-go/cadence-client) - A framework for authoring workflows and activities running on top of the Cadence orchestration engine made by Uber. +- [cdule](https://github.com/deepaksinghvi/cdule) - Job scheduler library with database support +- [cheek](https://github.com/datarootsio/cheek) - A simple crontab like scheduler that aims to offer a KISS approach to job scheduling. +- [clockwerk](https://github.com/onatm/clockwerk) - Go package to schedule periodic jobs using a simple, fluent syntax. +- [cronticker](https://github.com/krayzpipes/cronticker) - A ticker implementation to support cron schedules. +- [Dagu](https://github.com/dagu-go/dagu) - No-code workflow executor. it executes DAGs defined in a simple YAML format. +- [go-cron](https://github.com/rk/go-cron) - Simple Cron library for go that can execute closures or functions at varying intervals, from once a second to once a year on a specific date and time. Primarily for web applications and long running daemons. +- [go-dag](https://github.com/rhosocial/go-dag) - A framework developed in Go that manages the execution of workflows described by directed acyclic graphs. +- [go-quartz](https://github.com/reugn/go-quartz) - Simple, zero-dependency scheduling library for Go. +- [gocron](https://github.com/go-co-op/gocron) - Easy and fluent Go job scheduling. This is an actively maintained fork of [jasonlvhit/gocron](https://github.com/jasonlvhit/gocron). +- [goflow](https://github.com/fieldryand/goflow) - A simple but powerful DAG scheduler and dashboard. +- [gron](https://github.com/roylee0704/gron) - Define time-based tasks using a simple Go API and Gron’s scheduler will run them accordingly. +- [gronx](https://github.com/adhocore/gronx) - Cron expression parser, task runner and daemon consuming crontab like task list. +- [JobRunner](https://github.com/bamzi/jobrunner) - Smart and featureful cron job scheduler with job queuing and live monitoring built in. +- [jobs](https://github.com/albrow/jobs) - Persistent and flexible background jobs library. +- [leprechaun](https://github.com/kilgaloon/leprechaun) - Job scheduler that supports webhooks, crons and classic scheduling. +- [sched](https://github.com/romshark/sched) - A job scheduler with the ability to fast-forward time. +- [scheduler](https://github.com/carlescere/scheduler) - Cronjobs scheduling made easy. +- [tasks](https://github.com/madflojo/tasks) - An easy to use in-process scheduler for recurring tasks in Go. + +**[⬆ back to top](#contents)** + +## JSON + +_Libraries for working with JSON._ + +- [ajson](https://github.com/spyzhov/ajson) - Abstract JSON for golang with JSONPath support. +- [ask](https://github.com/simonnilsson/ask) - Easy access to nested values in maps and slices. Works in combination with encoding/json and other packages that "Unmarshal" arbitrary data into Go data-types. +- [dynjson](https://github.com/cocoonspace/dynjson) - Client-customizable JSON formats for dynamic APIs. +- [ej](https://github.com/lucassscaravelli/ej) - Write and read JSON from different sources succinctly. +- [epoch](https://github.com/vtopc/epoch) - Contains primitives for marshaling/unmarshalling Unix timestamp/epoch to/from build-in time.Time type in JSON. +- [fastjson](https://github.com/valyala/fastjson) - Fast JSON parser and validator for Go. No custom structs, no code generation, no reflection. +- [gabs](https://github.com/Jeffail/gabs) - For parsing, creating and editing unknown or dynamic JSON in Go. +- [gjo](https://github.com/skanehira/gjo) - Small utility to create JSON objects. +- [GJSON](https://github.com/tidwall/gjson) - Get a JSON value with one line of code. +- [go-jsonerror](https://github.com/ddymko/go-jsonerror) - Go-JsonError is meant to allow us to easily create json response errors that follow the JsonApi spec. +- [go-respond](https://github.com/nicklaw5/go-respond) - Go package for handling common HTTP JSON responses. +- [gojmapr](https://github.com/limiu82214/gojmapr) - Get simple struct from complex json by json path. +- [gojq](https://github.com/elgs/gojq) - JSON query in Golang. +- [gojson](https://github.com/ChimeraCoder/gojson) - Automatically generate Go (golang) struct definitions from example JSON. +- [htmljson](https://github.com/nikolaydubina/htmljson) - Rich rendering of JSON as HTML in Go. +- [JayDiff](https://github.com/yazgazan/jaydiff) - JSON diff utility written in Go. +- [jettison](https://github.com/wI2L/jettison) - Fast and flexible JSON encoder for Go. +- [jscan](https://github.com/romshark/jscan) - High performance zero-allocation JSON iterator. +- [JSON-to-Go](https://mholt.github.io/json-to-go/) - Convert JSON to Go struct. +- [JSON-to-Proto](https://json-to-proto.github.io/) - Convert JSON to Protobuf online. +- [json2go](https://github.com/m-zajac/json2go) - Advanced JSON to Go struct conversion. Provides package that can parse multiple JSON documents and create struct to fit them all. +- [jsonapi-errors](https://github.com/AmuzaTkts/jsonapi-errors) - Go bindings based on the JSON API errors reference. +- [jsoncolor](https://github.com/neilotoole/jsoncolor) - Drop-in replacement for `encoding/json` that outputs colorized JSON. +- [jsondiff](https://github.com/wI2L/jsondiff) - JSON diff library for Go based on RFC6902 (JSON Patch). +- [jsonf](https://github.com/miolini/jsonf) - Console tool for highlighted formatting and struct query fetching JSON. +- [jsongo](https://github.com/ricardolonga/jsongo) - Fluent API to make it easier to create Json objects. +- [jsonhal](https://github.com/RichardKnop/jsonhal) - Simple Go package to make custom structs marshal into HAL compatible JSON responses. +- [jsonhandlers](https://github.com/abusomani/jsonhandlers) - JSON library to expose simple handlers that lets you easily read and write json from various sources. +- [jsonic](https://github.com/sinhashubham95/jsonic) - Utilities to handle and query JSON without defining structs in a type safe manner. +- [jsonvalue](https://github.com/Andrew-M-C/go.jsonvalue) - A fast and convenient library for unstructured JSON data, replacing `encoding/json`. +- [jzon](https://github.com/zerosnake0/jzon) - JSON library with standard compatible API/behavior. +- [kazaam](https://github.com/Qntfy/kazaam) - API for arbitrary transformation of JSON documents. +- [mapslice-json](https://github.com/mickep76/mapslice-json) - Go MapSlice for ordered marshal/ unmarshal of maps in JSON. +- [marshmallow](https://github.com/PerimeterX/marshmallow) - Performant JSON unmarshalling for flexible use cases. +- [mp](https://github.com/sanbornm/mp) - Simple cli email parser. It currently takes stdin and outputs JSON. +- [OjG](https://github.com/ohler55/ojg) - Optimized JSON for Go is a high performance parser with a variety of additional JSON tools including JSONPath. +- [omg.jsonparser](https://github.com/dedalqq/omg.jsonparser) - Simple JSON parser with validation by condition via golang struct fields tags. +- [ujson](https://github.com/olvrng/ujson) - Fast and minimal JSON parser and transformer that works on unstructured JSON. +- [vjson](https://github.com/miladibra10/vjson) - Go package for validating JSON objects with declaring a JSON schema with fluent API. + +**[⬆ back to top](#contents)** ## Logging -*Libraries for generating and working with log files.* - -* [glog](https://github.com/golang/glog) - Leveled execution logs for Go. -* [go-log](https://github.com/siddontang/go-log) - Log lib supports level and multi handlers. -* [go-log](https://github.com/ian-kent/go-log) - A log4j implementation in Go. -* [go-logger](https://github.com/apsdehal/go-logger) - Simple logger of Go Programs, with level handlers. -* [gologex](https://github.com/chzyer/gologex) - An golang log lib, supports tracking and level, wrap by standard log lib -* [hiprus](https://github.com/nubo/hiprus) - [logrus](https://github.com/sirupsen/logrus) plug-in to send errors to a channel in [Hipchat](https://hipchat.com). -* [log-voyage](https://github.com/firstrow/logvoyage) - Full-featured logging saas writen in golang. -* [logrus](https://github.com/sirupsen/logrus) - Structured, pluggable logging for Go. -* [logrusly](https://github.com/sebest/logrusly) - [logrus](https://github.com/sirupsen/logrus) plug-in to send errors to a [Loggly](https://www.loggly.com/). -* [logxi](https://github.com/mgutz/logxi) - A 12-factor app logger that is fast and makes you happy. -* [lumberjack](https://github.com/natefinch/lumberjack) - Simple rolling logger, implements io.WriteCloser. -* [seelog](https://github.com/cihub/seelog) - logging functionality with flexible dispatching, filtering, and formatting. -* [slackrus](https://github.com/johntdyer/slackrus) - [logrus](https://github.com/sirupsen/logrus) plug-in to send errors to a channel in [Slack](https://slack.com). -* [stdlog](https://github.com/alexcesaro/log) - Stdlog is an object-oriented library providing leveled logging. It is very useful for cron jobs. -* [tail](https://github.com/ActiveState/tail) - A Go package striving to emulate the features of the BSD tail program. +_Libraries for generating and working with log files._ + +- [distillog](https://github.com/amoghe/distillog) - distilled levelled logging (think of it as stdlib + log levels). +- [glg](https://github.com/kpango/glg) - glg is simple and fast leveled logging library for Go. +- [glo](https://github.com/lajosbencz/glo) - PHP Monolog inspired logging facility with identical severity levels. +- [glog](https://github.com/golang/glog) - Leveled execution logs for Go. +- [go-cronowriter](https://github.com/utahta/go-cronowriter) - Simple writer that rotate log files automatically based on current date and time, like cronolog. +- [go-log](https://github.com/pieterclaerhout/go-log) - A logging library with stack traces, object dumping and optional timestamps. +- [go-log](https://github.com/subchen/go-log) - Simple and configurable Logging in Go, with level, formatters and writers. +- [go-log](https://github.com/siddontang/go-log) - Log lib supports level and multi handlers. +- [go-log](https://github.com/ian-kent/go-log) - Log4j implementation in Go. +- [go-logger](https://github.com/apsdehal/go-logger) - Simple logger of Go Programs, with level handlers. +- [gomol](https://github.com/aphistic/gomol) - Multiple-output, structured logging for Go with extensible logging outputs. +- [gone/log](https://github.com/One-com/gone/tree/master/log) - Fast, extendable, full-featured, std-lib source compatible log library. +- [httpretty](https://github.com/henvic/httpretty) - Pretty-prints your regular HTTP requests on your terminal for debugging (similar to http.DumpRequest). +- [journald](https://github.com/ssgreg/journald) - Go implementation of systemd Journal's native API for logging. +- [kemba](https://github.com/clok/kemba) - A tiny debug logging tool inspired by [debug](https://github.com/visionmedia/debug), great for CLI tools and applications. +- [log](https://github.com/aerogo/log) - An O(1) logging system that allows you to connect one log to multiple writers (e.g. stdout, a file and a TCP connection). +- [log](https://github.com/apex/log) - Structured logging package for Go. +- [log](https://github.com/go-playground/log) - Simple, configurable and scalable Structured Logging for Go. +- [log](https://github.com/teris-io/log) - Structured log interface for Go cleanly separates logging facade from its implementation. +- [log](https://github.com/heartwilltell/log) - Simple leveled logging wrapper around standard log package. +- [log](https://github.com/no-src/log) - A simple logging framework out of the box. +- [log-voyage](https://github.com/firstrow/logvoyage) - Full-featured logging saas written in golang. +- [log15](https://github.com/inconshreveable/log15) - Simple, powerful logging for Go. +- [logdump](https://github.com/ewwwwwqm/logdump) - Package for multi-level logging. +- [logex](https://github.com/chzyer/logex) - Golang log lib, supports tracking and level, wrap by standard log lib. +- [logger](https://github.com/azer/logger) - Minimalistic logging library for Go. +- [logo](https://github.com/mbndr/logo) - Golang logger to different configurable writers. +- [logrus](https://github.com/Sirupsen/logrus) - Structured logger for Go. +- [logrusiowriter](https://github.com/cabify/logrusiowriter) - `io.Writer` implementation using [logrus](https://github.com/sirupsen/logrus) logger. +- [logrusly](https://github.com/sebest/logrusly) - [logrus](https://github.com/sirupsen/logrus) plug-in to send errors to a [Loggly](https://www.loggly.com/). +- [logur](https://github.com/logur/logur) - An opinionated logger interface and collection of logging best practices with adapters and integrations for well-known libraries ([logrus](https://github.com/sirupsen/logrus), [go-kit log](https://github.com/go-kit/kit/tree/master/log), [zap](https://github.com/uber-go/zap), [zerolog](https://github.com/rs/zerolog), etc). +- [logutils](https://github.com/hashicorp/logutils) - Utilities for slightly better logging in Go (Golang) extending the standard logger. +- [logxi](https://github.com/mgutz/logxi) - 12-factor app logger that is fast and makes you happy. +- [lumberjack](https://github.com/natefinch/lumberjack) - Simple rolling logger, implements io.WriteCloser. +- [mlog](https://github.com/jbrodriguez/mlog) - Simple logging module for go, with 5 levels, an optional rotating logfile feature and stdout/stderr output. +- [noodlog](https://github.com/gyozatech/noodlog) - Parametrized JSON logging library which lets you obfuscate sensitive data and marshal any kind of content. No more printed pointers instead of values, nor escape chars for the JSON strings. +- [onelog](https://github.com/francoispqt/onelog) - Onelog is a dead simple but very efficient JSON logger. It is the fastest JSON logger out there in all scenarios. Also, it is one of the logger with the lowest allocation. +- [ozzo-log](https://github.com/go-ozzo/ozzo-log) - High performance logging supporting log severity, categorization, and filtering. Can send filtered log messages to various targets (e.g. console, network, mail). +- [phuslu/log](https://github.com/phuslu/log) - High performance structured logging. +- [pp](https://github.com/k0kubun/pp) - Colored pretty printer for Go language. +- [rollingwriter](https://github.com/arthurkiller/rollingWriter) - RollingWriter is an auto-rotate `io.Writer` implementation with multi policies to provide log file rotation. +- [seelog](https://github.com/cihub/seelog) - Logging functionality with flexible dispatching, filtering, and formatting. +- [slf4g](https://github.com/echocat/slf4g) - Simple Logging Facade for Golang: Simple structured logging; but powerful, extendable and customizable, with huge amount of learnings from decades of past logging frameworks. +- [slog](https://github.com/gookit/slog) - Lightweight, configurable, extensible logger for Go. +- [slog-formatter](https://github.com/samber/slog-formatter) - Common formatters for slog and helpers to build your own. +- [slog-multi](https://github.com/samber/slog-multi) - Chain of slog.Handler (pipeline, fanout...). +- [slogor](https://gitlab.com/greyxor/slogor) - A colorful slog handler. +- [spew](https://github.com/davecgh/go-spew) - Implements a deep pretty printer for Go data structures to aid in debugging. +- [sqldb-logger](https://github.com/simukti/sqldb-logger) - A logger for Go SQL database driver without modify existing \*sql.DB stdlib usage. +- [stdlog](https://github.com/alexcesaro/log) - Stdlog is an object-oriented library providing leveled logging. It is very useful for cron jobs. +- [structy/log](https://github.com/structy/log) - A simple to use log system, minimalist but with features for debugging and differentiation of messages. +- [tail](https://github.com/hpcloud/tail) - Go package striving to emulate the features of the BSD tail program. +- [tint](https://github.com/lmittmann/tint) - A slog.Handler that writes tinted logs. +- [xlog](https://github.com/xfxdev/xlog) - Plugin architecture and flexible log system for Go, with level ctrl, multiple log target and custom log format. +- [xlog](https://github.com/rs/xlog) - Structured logger for `net/context` aware HTTP handlers with flexible dispatching. +- [xylog](https://github.com/xybor-x/xylog) - Leveled and structured logging, dynamic fields, high performance, zone management, simple configuration, and readable syntax. +- [yell](https://github.com/jfcg/yell) - Yet another minimalistic logging library. +- [zap](https://github.com/uber-go/zap) - Fast, structured, leveled logging in Go. +- [zax](https://github.com/yuseferi/zax) - Integrate Context with Zap logger, which leads to more flexibility in Go logging. +- [zerolog](https://github.com/rs/zerolog) - Zero-allocation JSON logger. +- [zkits-logger](https://github.com/edoger/zkits-logger) - A powerful zero-dependency JSON logger. +- [zl](https://github.com/nkmr-jp/zl) - High Developer Experience, zap based logger. It offers rich functionality but is easy to configure. + +**[⬆ back to top](#contents)** ## Machine Learning -*Libraries for Machine Learning.* - -* [bayesian](https://github.com/jbrukh/bayesian) - Naive Bayesian Classification for Golang. -* [CloudForest](https://github.com/ryanbressler/CloudForest) - Fast, flexible, multi-threaded ensembles of decision trees for machine learning in pure Go. -* [go-fann](https://github.com/white-pony/go-fann) - Go bindings for Fast Artificial Neural Networks(FANN) library. -* [go-galib](https://github.com/thoj/go-galib) - Genetic Algorithms library written in Go / golang -* [go-pr](https://github.com/daviddengcn/go-pr) - Pattern recognition package in Go lang. -* [gobrain](https://github.com/goml/gobrain) - Neural Networks written in go -* [godist](https://github.com/e-dard/godist) - Various probability distributions, and associated methods. -* [GoLearn](https://github.com/sjwhitworth/golearn) - General Machine Learning library for Go. -* [golinear](https://github.com/danieldk/golinear) - liblinear bindings for Go -* [goRecommend](https://github.com/timkaye11/goRecommend) - Recommendation Algorithms library written in Go. -* [libsvm](https://github.com/datastream/libsvm) - libsvm golang version derived work based on LIBSVM 3.14. -* [mlgo](https://code.google.com/p/mlgo/) - This project aims to provide minimalistic machine learning algorithms in Go. -* [neural-go](https://github.com/schuyler/neural-go) - A multilayer perceptron network implemented in Go, with training via backpropagation. -* [probab](https://code.google.com/p/probab/) - Probability distribution functions. Bayesian inference. Written in pure Go. -* [regommend](https://github.com/muesli/regommend) - Recommendation & collaborative filtering engine -* [shield](https://github.com/eaigner/shield) - Bayesian text classifier with flexible tokenizers and storage backends for Go - +_Libraries for Machine Learning._ + +- [bayesian](https://github.com/jbrukh/bayesian) - Naive Bayesian Classification for Golang. +- [CloudForest](https://github.com/ryanbressler/CloudForest) - Fast, flexible, multi-threaded ensembles of decision trees for machine learning in pure Go. +- [ddt](https://github.com/sgrodriguez/ddt) - Dynamic decision tree, create trees defining customizable rules. +- [eaopt](https://github.com/MaxHalford/eaopt) - An evolutionary optimization library. +- [evoli](https://github.com/khezen/evoli) - Genetic Algorithm and Particle Swarm Optimization library. +- [fonet](https://github.com/Fontinalis/fonet) - A Deep Neural Network library written in Go. +- [go-cluster](https://github.com/e-XpertSolutions/go-cluster) - Go implementation of the k-modes and k-prototypes clustering algorithms. +- [go-deep](https://github.com/patrikeh/go-deep) - A feature-rich neural network library in Go. +- [go-fann](https://github.com/white-pony/go-fann) - Go bindings for Fast Artificial Neural Networks(FANN) library. +- [go-featureprocessing](https://github.com/nikolaydubina/go-featureprocessing) - Fast and convenient feature processing for low latency machine learning in Go. +- [go-galib](https://github.com/thoj/go-galib) - Genetic Algorithms library written in Go / golang. +- [go-pr](https://github.com/daviddengcn/go-pr) - Pattern recognition package in Go lang. +- [gobrain](https://github.com/goml/gobrain) - Neural Networks written in go. +- [godist](https://github.com/e-dard/godist) - Various probability distributions, and associated methods. +- [goga](https://github.com/tomcraven/goga) - Genetic algorithm library for Go. +- [GoLearn](https://github.com/sjwhitworth/golearn) - General Machine Learning library for Go. +- [golinear](https://github.com/danieldk/golinear) - liblinear bindings for Go. +- [GoMind](https://github.com/surenderthakran/gomind) - A simplistic Neural Network Library in Go. +- [goml](https://github.com/cdipaolo/goml) - On-line Machine Learning in Go. +- [GoMLX](https://github.com/gomlx/gomlx) - An accelerated Machine Learning framework for Go. +- [gonet](https://github.com/dathoangnd/gonet) - Neural Network for Go. +- [Goptuna](https://github.com/c-bata/goptuna) - Bayesian optimization framework for black-box functions written in Go. Everything will be optimized. +- [goRecommend](https://github.com/timkaye11/goRecommend) - Recommendation Algorithms library written in Go. +- [gorgonia](https://github.com/gorgonia/gorgonia) - graph-based computational library like Theano for Go that provides primitives for building various machine learning and neural network algorithms. +- [gorse](https://github.com/zhenghaoz/gorse) - An offline recommender system backend based on collaborative filtering written in Go. +- [goscore](https://github.com/asafschers/goscore) - Go Scoring API for PMML. +- [gosseract](https://github.com/otiai10/gosseract) - Go package for OCR (Optical Character Recognition), by using Tesseract C++ library. +- [hugot](https://github.com/knights-analytics/hugot) - Huggingface transformer pipelines for golang with onnxruntime. +- [libsvm](https://github.com/datastream/libsvm) - libsvm golang version derived work based on LIBSVM 3.14. +- [m2cgen](https://github.com/BayesWitnesses/m2cgen) - A CLI tool to transpile trained classic ML models into a native Go code with zero dependencies, written in Python with Go language support. +- [neat](https://github.com/jinyeom/neat) - Plug-and-play, parallel Go framework for NeuroEvolution of Augmenting Topologies (NEAT). +- [neural-go](https://github.com/schuyler/neural-go) - Multilayer perceptron network implemented in Go, with training via backpropagation. +- [ocrserver](https://github.com/otiai10/ocrserver) - A simple OCR API server, seriously easy to be deployed by Docker and Heroku. +- [onnx-go](https://github.com/owulveryck/onnx-go) - Go Interface to Open Neural Network Exchange (ONNX). +- [probab](https://github.com/ThePaw/probab) - Probability distribution functions. Bayesian inference. Written in pure Go. +- [randomforest](https://github.com/malaschitz/randomForest) - Easy to use Random Forest library for Go. +- [regommend](https://github.com/muesli/regommend) - Recommendation & collaborative filtering engine. +- [shield](https://github.com/eaigner/shield) - Bayesian text classifier with flexible tokenizers and storage backends for Go. +- [tfgo](https://github.com/galeone/tfgo) - Easy to use Tensorflow bindings: simplifies the usage of the official Tensorflow Go bindings. Define computational graphs in Go, load and execute models trained in Python. +- [Varis](https://github.com/Xamber/Varis) - Golang Neural Network. + +**[⬆ back to top](#contents)** ## Messaging -*Libraries that implement messaging systems* - -* [dbus](https://github.com/godbus/dbus) - Native Go bindings for D-Bus. -* [EventBus](https://github.com/asaskevich/EventBus) - The lightweight event bus with async compatibility. -* [go-notify](https://github.com/TheCreeper/go-notify) - Native implementation of the freedesktop notification spec. -* [go-nsq](https://github.com/bitly/go-nsq) - the official Go package for NSQ -* [gopush-cluster](https://github.com/Terry-Mao/gopush-cluster) - gopush-cluster is a go push server cluster. -* [NATS](https://github.com/apcera/nats) - A lightweight and highly performant publish-subscribe and distributed queueing messaging system. -* [sarama](https://github.com/Shopify/sarama) - A Go library for Apache Kafka. -* [Uniqush-Push](https://github.com/uniqush/uniqush-push) - A redis backed unified push service for server-side notifications to mobile devices. -* [zmq4](https://github.com/pebbe/zmq4) - A Go interface to ZeroMQ version 4. Also available for [version 3](https://github.com/pebbe/zmq3) and [version 2](https://github.com/pebbe/zmq2). - +_Libraries that implement messaging systems._ + +- [ami](https://github.com/kak-tus/ami) - Go client to reliable queues based on Redis Cluster Streams. +- [amqp](https://github.com/rabbitmq/amqp091-go) - Go RabbitMQ Client Library. +- [APNs2](https://github.com/sideshow/apns2) - HTTP/2 Apple Push Notification provider for Go — Send push notifications to iOS, tvOS, Safari and OSX apps. +- [Asynq](https://github.com/hibiken/asynq) - A simple, reliable, and efficient distributed task queue for Go built on top of Redis. +- [Beaver](https://github.com/Clivern/Beaver) - A real time messaging server to build a scalable in-app notifications, multiplayer games, chat apps in web and mobile apps. +- [Bus](https://github.com/mustafaturan/bus) - Minimalist message bus implementation for internal communication. +- [Centrifugo](https://github.com/centrifugal/centrifugo) - Real-time messaging (Websockets or SockJS) server in Go. +- [Chanify](https://github.com/chanify/chanify) - A push notification server send message to your iOS devices. +- [Commander](https://github.com/jeroenrinzema/commander) - A high-level event driven consumer/producer supporting various "dialects" such as Apache Kafka. +- [Confluent Kafka Golang Client](https://github.com/confluentinc/confluent-kafka-go) - confluent-kafka-go is Confluent's Golang client for Apache Kafka and the Confluent Platform. +- [dbus](https://github.com/godbus/dbus) - Native Go bindings for D-Bus. +- [drone-line](https://github.com/appleboy/drone-line) - Sending [Line](https://at.line.me/en) notifications using a binary, docker or Drone CI. +- [emitter](https://github.com/olebedev/emitter) - Emits events using Go way, with wildcard, predicates, cancellation possibilities and many other good wins. +- [event](https://github.com/agoalofalife/event) - Implementation of the pattern observer. +- [EventBus](https://github.com/asaskevich/EventBus) - The lightweight event bus with async compatibility. +- [gaurun-client](https://github.com/osamingo/gaurun-client) - Gaurun Client written in Go. +- [Glue](https://github.com/desertbit/glue) - Robust Go and Javascript Socket Library (Alternative to Socket.io). +- [go-eventbus](https://github.com/stanipetrosyan/go-eventbus) - Simple Event Bus package for Go. +- [Go-MediatR](https://github.com/mehdihadeli/Go-MediatR) - A library for handling mediator patterns and simplified CQRS patterns within an event-driven architecture, inspired by csharp MediatR library. +- [go-mq](https://github.com/cheshir/go-mq) - RabbitMQ client with declarative configuration. +- [go-notify](https://github.com/TheCreeper/go-notify) - Native implementation of the freedesktop notification spec. +- [go-nsq](https://github.com/nsqio/go-nsq) - the official Go package for NSQ. +- [go-res](https://github.com/jirenius/go-res) - Package for building REST/real-time services where clients are synchronized seamlessly, using NATS and Resgate. +- [go-socket.io](https://github.com/googollee/go-socket.io) - socket.io library for golang, a realtime application framework. +- [go-vitotrol](https://github.com/maxatome/go-vitotrol) - Client library to Viessmann Vitotrol web service. +- [Gollum](https://github.com/trivago/gollum) - A n:m multiplexer that gathers messages from different sources and broadcasts them to a set of destinations. +- [golongpoll](https://github.com/jcuga/golongpoll) - HTTP longpoll server library that makes web pub-sub simple. +- [gopush-cluster](https://github.com/Terry-Mao/gopush-cluster) - gopush-cluster is a go push server cluster. +- [gorush](https://github.com/appleboy/gorush) - Push notification server using [APNs2](https://github.com/sideshow/apns2) and google [GCM](https://github.com/google/go-gcm). +- [gosd](https://github.com/alexsniffin/gosd) - A library for scheduling when to dispatch a message to a channel. +- [guble](https://github.com/smancke/guble) - Messaging server using push notifications (Google Firebase Cloud Messaging, Apple Push Notification services, SMS) as well as websockets, a REST API, featuring distributed operation and message-persistence. +- [hare](https://github.com/leozz37/hare) - A user friendly library for sending messages and listening to TCP sockets. +- [hub](https://github.com/leandro-lugaresi/hub) - A Message/Event Hub for Go applications, using publish/subscribe pattern with support for alias like rabbitMQ exchanges. +- [hypermatch](https://github.com/SchwarzIT/hypermatch) - A very fast and efficient Go library for matching events to a large set of rules +- [jazz](https://github.com/socifi/jazz) - A simple RabbitMQ abstraction layer for queue administration and publishing and consuming of messages. +- [machinery](https://github.com/RichardKnop/machinery) - Asynchronous task queue/job queue based on distributed message passing. +- [mangos](https://github.com/nanomsg/mangos) - Pure go implementation of the Nanomsg ("Scalability Protocols") with transport interoperability. +- [melody](https://github.com/olahol/melody) - Minimalist framework for dealing with websocket sessions, includes broadcasting and automatic ping/pong handling. +- [Mercure](https://github.com/dunglas/mercure) - Server and library to dispatch server-sent updates using the Mercure protocol (built on top of Server-Sent Events). +- [messagebus](https://github.com/vardius/message-bus) - messagebus is a Go simple async message bus, perfect for using as event bus when doing event sourcing, CQRS, DDD. +- [NATS Go Client](https://github.com/nats-io/nats) - Lightweight and high performance publish-subscribe and distributed queueing messaging system - this is the Go library. +- [nsq-event-bus](https://github.com/rafaeljesus/nsq-event-bus) - A tiny wrapper around NSQ topic and channel. +- [oplog](https://github.com/dailymotion/oplog) - Generic oplog/replication system for REST APIs. +- [pubsub](https://github.com/tuxychandru/pubsub) - Simple pubsub package for go. +- [Quamina](https://github.com/timbray/quamina) - Fast pattern-matching for filtering messages and events. +- [rabbitroutine](https://github.com/furdarius/rabbitroutine) - Lightweight library that handles RabbitMQ auto-reconnect and publishing retries. The library takes into account the need to re-declare entities in RabbitMQ after reconnection. +- [rabbus](https://github.com/rafaeljesus/rabbus) - A tiny wrapper over amqp exchanges and queues. +- [rabtap](https://github.com/jandelgado/rabtap) - RabbitMQ swiss army knife cli app. +- [RapidMQ](https://github.com/sybrexsys/RapidMQ) - RapidMQ is a lightweight and reliable library for managing of the local messages queue. +- [Ratus](https://github.com/hyperonym/ratus) - Ratus is a RESTful asynchronous task queue server. +- [redisqueue](https://github.com/robinjoseph08/redisqueue) - redisqueue provides a producer and consumer of a queue that uses Redis streams. +- [rmqconn](https://github.com/sbabiv/rmqconn) - RabbitMQ Reconnection. Wrapper over amqp.Connection and amqp.Dial. Allowing to do a reconnection when the connection is broken before forcing the call to the Close () method to be closed. +- [sarama](https://github.com/Shopify/sarama) - Go library for Apache Kafka. +- [Uniqush-Push](https://github.com/uniqush/uniqush-push) - Redis backed unified push service for server-side notifications to mobile devices. +- [Watermill](https://github.com/ThreeDotsLabs/watermill) - Working efficiently with message streams. Building event driven applications, enabling event sourcing, RPC over messages, sagas. Can use conventional pub/sub implementations like Kafka or RabbitMQ, but also HTTP or MySQL binlog. +- [zmq4](https://github.com/pebbe/zmq4) - Go interface to ZeroMQ version 4. Also available for [version 3](https://github.com/pebbe/zmq3) and [version 2](https://github.com/pebbe/zmq2). + +**[⬆ back to top](#contents)** + +## Microsoft Office + +- [unioffice](https://github.com/unidoc/unioffice) - Pure go library for creating and processing Office Word (.docx), Excel (.xlsx) and Powerpoint (.pptx) documents. + +### Microsoft Excel + +_Libraries for working with Microsoft Excel._ + +- [excelize](https://github.com/xuri/excelize) - Golang library for reading and writing Microsoft Excel™ (XLSX) files. +- [exl](https://github.com/go-the-way/exl) - Excel binding to struct written in Go.(Only supports Go1.18+) +- [go-excel](https://github.com/szyhf/go-excel) - A simple and light reader to read a relate-db-like excel as a table. +- [goxlsxwriter](https://github.com/fterrag/goxlsxwriter) - Golang bindings for libxlsxwriter for writing XLSX (Microsoft Excel) files. +- [xlsx](https://github.com/tealeg/xlsx) - Library to simplify reading the XML format used by recent version of Microsoft Excel in Go programs. +- [xlsx](https://github.com/plandem/xlsx) - Fast and safe way to read/update your existing Microsoft Excel files in Go programs. + +### Microsoft Word + +_Libraries for working with Microsoft Word._ + +- [godocx](https://github.com/gomutex/godocx) - Library for reading and writing Microsoft Word (Docx) files. + +**[⬆ back to top](#contents)** ## Miscellaneous -*These libraries were placed here because none of the other categories seemed to fit* - -* [autoflags](https://github.com/artyom/autoflags) - Go package to automatically define command line flags from struct fields. -* [browscap_go](https://github.com/fromYukki/browscap_go) - GoLang Library for [Browser Capabilities Project](http://browscap.org/). -* [gopsutil](https://github.com/shirou/gopsutil) - A cross-platform library for retrieving process and system utilization(CPU, Memory, Disks, etc). -* [notify](https://github.com/rjeczalik/notify) - File system event notification library with simple API, similar to os/signal. -* [xstrings](https://github.com/huandu/xstrings) - A collection of useful string functions ported from other languages. +### Dependency Injection + +_Libraries for working with dependency injection._ + +- [alice](https://github.com/magic003/alice) - Additive dependency injection container for Golang. +- [autowire](https://github.com/tiendc/autowire) - Dependency injection using Generics and reflection. +- [boot-go](http://github.com/boot-go/boot) - Component-based development with dependency injection using reflections for Go developers. +- [componego](https://github.com/componego/componego) - A dependency injection framework based on components, allowing dynamic dependency replacement without duplicating code in tests. +- [cosban/di](https://gitlab.com/cosban/di) - A code generation based dependency injection wiring tool. +- [di](https://github.com/goava/di) - A dependency injection container for go programming language. +- [dig](https://github.com/uber-go/dig) - A reflection based dependency injection toolkit for Go. +- [dingo](https://github.com/i-love-flamingo/dingo) - A dependency injection toolkit for Go, based on Guice. +- [do](https://github.com/samber/do) - A dependency injection framework based on Generics. +- [fx](https://github.com/uber-go/fx) - A dependency injection based application framework for Go (built on top of dig). +- [gocontainer](https://github.com/vardius/gocontainer) - Simple Dependency Injection Container. +- [goioc/di](https://github.com/goioc/di) - Spring-inspired Dependency Injection Container. +- [GoLobby/Container](https://github.com/golobby/container) - GoLobby Container is a lightweight yet powerful IoC dependency injection container for the Go programming language. +- [gontainer](https://github.com/NVIDIA/gontainer) - A dependency injection service container for Go projects. +- [gontainer/gontainer](https://github.com/gontainer/gontainer) - A YAML-based Dependency Injection container for GO. It supports dependencies' scopes, and auto-detection of circular dependencies. Gontainer is concurrent-safe. +- [google/wire](https://github.com/google/wire) - Automated Initialization in Go. +- [HnH/di](https://github.com/HnH/di) - DI container library that is focused on clean API and flexibility. +- [kinit](https://github.com/go-kata/kinit) - Customizable dependency injection container with the global mode, cascade initialization and panic-safe finalization. +- [kod](https://github.com/go-kod/kod) - A generics based dependency injection framework for Go. +- [linker](https://github.com/logrange/linker) - A reflection based dependency injection and inversion of control library with components lifecycle support. +- [nject](https://github.com/muir/nject) - A type safe, reflective framework for libraries, tests, http endpoints, and service startup. +- [ore](https://github.com/firasdarwish/ore) - Lightweight, generic & simple dependency injection (DI) container. +- [wire](https://github.com/Fs02/wire) - Strict Runtime Dependency Injection for Golang. + +**[⬆ back to top](#contents)** + +### Project Layout + +_**Unofficial** set of patterns for structuring projects._ + +- [ardanlabs/service](https://github.com/ardanlabs/service) - A [starter kit](https://github.com/ardanlabs/service/wiki) for building production grade scalable web service applications. +- [cookiecutter-golang](https://github.com/lacion/cookiecutter-golang) - A Go application boilerplate template for quick starting projects following production best practices. +- [go-blueprint](https://github.com/Melkeydev/go-blueprint) - Allows users to spin up a quick Go project using a popular framework. +- [go-module](https://github.com/octomation/go-module) - Template for a typical module written on Go. +- [go-sample](https://github.com/zitryss/go-sample) - A sample layout for Go application projects with the real code. +- [go-starter](https://github.com/allaboutapps/go-starter) - An opinionated production-ready RESTful JSON backend template, highly integrated with VSCode DevContainers. +- [go-todo-backend](https://github.com/Fs02/go-todo-backend) - Go Todo Backend example using modular project layout for product microservice. +- [gobase](https://github.com/wajox/gobase) - A simple skeleton for golang application with basic setup for real golang application. +- [golang-standards/project-layout](https://github.com/golang-standards/project-layout) - Set of common historical and emerging project layout patterns in the Go ecosystem. Note: despite the org-name they do not represent official golang standards, see [this issue](https://github.com/golang-standards/project-layout/issues/117) for more information. Nonetheless, some may find the layout useful. +- [golang-templates/seed](https://github.com/golang-templates/seed) - Go application GitHub repository template. +- [goxygen](https://github.com/shpota/goxygen) - Generate a modern Web project with Go and Angular, React, or Vue in seconds. +- [insidieux/inizio](https://github.com/insidieux/inizio) - Golang project layout generator with plugins. +- [modern-go-application](https://github.com/sagikazarmark/modern-go-application) - Go application boilerplate and example applying modern practices. +- [nunu](https://github.com/go-nunu/nunu) - Nunu is a scaffolding tool for building Go applications. +- [pagoda](https://github.com/mikestefanello/pagoda) - Rapid, easy full-stack web development starter kit built in Go. +- [scaffold](https://github.com/catchplay/scaffold) - Scaffold generates a starter Go project layout. Lets you focus on business logic implemented. +- [wangyoucao577/go-project-layout](https://github.com/wangyoucao577/go-project-layout) - Set of practices and discussions on how to structure Go project layout. + +**[⬆ back to top](#contents)** + +### Strings + +_Libraries for working with strings._ + +- [bexp](https://github.com/happy-sdk/happy/tree/main/pkg/strings/bexp) - Go implementation of Brace Expansion mechanism to generate arbitrary strings. +- [caps](https://github.com/chanced/caps) - A case conversion library. +- [go-formatter](https://gitlab.com/tymonx/go-formatter) - Implements **replacement fields** surrounded by curly braces `{}` format strings. +- [gobeam/Stringy](https://github.com/gobeam/Stringy) - String manipulation library to convert string to camel case, snake case, kebab case / slugify etc. +- [strutil](https://github.com/ozgio/strutil) - String utilities. +- [sttr](https://github.com/abhimanyu003/sttr) - cross-platform, cli app to perform various operations on string. +- [xstrings](https://github.com/huandu/xstrings) - Collection of useful string functions ported from other languages. + +**[⬆ back to top](#contents)** + +### Uncategorized + +_These libraries were placed here because none of the other categories seemed to fit._ + +- [anagent](https://github.com/mudler/anagent) - Minimalistic, pluggable Golang evloop/timer handler with dependency-injection. +- [antch](https://github.com/antchfx/antch) - A fast, powerful and extensible web crawling & scraping framework. +- [archiver](https://github.com/mholt/archiver) - Library and command for making and extracting .zip and .tar.gz archives. +- [autoflags](https://github.com/artyom/autoflags) - Go package to automatically define command line flags from struct fields. +- [avgRating](https://github.com/kirillDanshin/avgRating) - Calculate average score and rating based on Wilson Score Equation. +- [banner](https://github.com/dimiro1/banner) - Add beautiful banners into your Go applications. +- [base64Captcha](https://github.com/mojocn/base64Captcha) - Base64captch supports digit, number, alphabet, arithmetic, audio and digit-alphabet captcha. +- [basexx](https://github.com/bobg/basexx) - Convert to, from, and between digit strings in various number bases. +- [battery](https://github.com/distatus/battery) - Cross-platform, normalized battery information library. +- [bitio](https://github.com/icza/bitio) - Highly optimized bit-level Reader and Writer for Go. +- [browscap_go](https://github.com/digitalcrab/browscap_go) - GoLang Library for [Browser Capabilities Project](https://browscap.org/). +- [captcha](https://github.com/steambap/captcha) - Package captcha provides an easy to use, unopinionated API for captcha generation. +- [common](https://github.com/kubeservice-stack/common) - A library for server framework. +- [conv](https://github.com/cstockton/go-conv) - Package conv provides fast and intuitive conversions across Go types. +- [datacounter](https://github.com/miolini/datacounter) - Go counters for readers/writer/http.ResponseWriter. +- [faker](https://github.com/neotoolkit/faker) - Fake data generator. +- [faker](https://github.com/pioz/faker) - Random fake data and struct generator for Go. +- [ffmt](https://github.com/go-ffmt/ffmt) - Beautify data display for Humans. +- [gatus](https://github.com/TwinProduction/gatus) - Automated service health dashboard. +- [go-commandbus](https://github.com/lana/go-commandbus) - A slight and pluggable command-bus for Go. +- [go-commons-pool](https://github.com/jolestar/go-commons-pool) - Generic object pool for Golang. +- [go-openapi](https://github.com/go-openapi) - Collection of packages to parse and utilize open-api schemas. +- [go-resiliency](https://github.com/eapache/go-resiliency) - Resiliency patterns for golang. +- [go-unarr](https://github.com/gen2brain/go-unarr) - Decompression library for RAR, TAR, ZIP and 7z archives. +- [gofakeit](https://github.com/brianvoe/gofakeit) - Random data generator written in go. +- [gommit](https://github.com/antham/gommit) - Analyze git commit messages to ensure they follow defined patterns. +- [gopsutil](https://github.com/shirou/gopsutil) - Cross-platform library for retrieving process and system utilization(CPU, Memory, Disks, etc). +- [gosh](https://github.com/osamingo/gosh) - Provide Go Statistics Handler, Struct, Measure Method. +- [gosms](https://github.com/haxpax/gosms) - Your own local SMS gateway in Go that can be used to send SMS. +- [gotoprom](https://github.com/cabify/gotoprom) - Type-safe metrics builder wrapper library for the official Prometheus client. +- [gountries](https://github.com/pariz/gountries) - Package that exposes country and subdivision data. +- [gtree](https://github.com/ddddddO/gtree) - Provide CLI, Package and Web for tree output and directories creation from Markdown or programmatically. +- [health](https://github.com/alexliesenfeld/health) - A simple and flexible health check library for Go. +- [health](https://github.com/dimiro1/health) - Easy to use, extensible health check library. +- [healthcheck](https://github.com/etherlabsio/healthcheck) - An opinionated and concurrent health-check HTTP handler for RESTful services. +- [hostutils](https://github.com/Wing924/hostutils) - A golang library for packing and unpacking FQDNs list. +- [indigo](https://github.com/osamingo/indigo) - Distributed unique ID generator of using Sonyflake and encoded by Base58. +- [lk](https://github.com/hyperboloide/lk) - A simple licensing library for golang. +- [llvm](https://github.com/llir/llvm) - Library for interacting with LLVM IR in pure Go. +- [metrics](https://github.com/pascaldekloe/metrics) - Library for metrics instrumentation and Prometheus exposition. +- [morse](https://github.com/alwindoss/morse) - Library to convert to and from morse code. +- [numa](https://github.com/lrita/numa) - NUMA is a utility library, which is written in go. It help us to write some NUMA-AWARED code. +- [openapi](https://github.com/neotoolkit/openapi) - OpenAPI 3.x parser. +- [pdfgen](https://github.com/hyperboloide/pdfgen) - HTTP service to generate PDF from Json requests. +- [persian](https://github.com/mavihq/persian) - Some utilities for Persian language in go. +- [sandid](https://github.com/aofei/sandid) - Every grain of sand on earth has its own ID. +- [shellwords](https://github.com/Wing924/shellwords) - A Golang library to manipulate strings according to the word parsing rules of the UNIX Bourne shell. +- [shortid](https://github.com/teris-io/shortid) - Distributed generation of super short, unique, non-sequential, URL friendly IDs. +- [shoutrrr](https://github.com/containrrr/shoutrrr) - Notification library providing easy access to various messaging services like slack, mattermost, gotify and smtp among others. +- [sitemap-format](https://github.com/mingard/sitemap-format) - A simple sitemap generator, with a little syntactic sugar. +- [stateless](https://github.com/qmuntal/stateless) - A fluent library for creating state machines. +- [stats](https://github.com/go-playground/stats) - Monitors Go MemStats + System stats such as Memory, Swap and CPU and sends via UDP anywhere you want for logging etc... +- [turtle](https://github.com/hackebrot/turtle) - Emojis for Go. +- [url-shortener](https://github.com/pantrif/url-shortener) - A modern, powerful, and robust URL shortener microservice with mysql support. +- [VarHandler](https://github.com/azr/generators/tree/master/varhandler) - Generate boilerplate http input and output handling. +- [varint](https://github.com/chmike/varint) - A faster varying length integer encoder/decoder than the one provided in the standard library. +- [xdg](https://github.com/rkoesters/xdg) - FreeDesktop.org (xdg) Specs implemented in Go. +- [xkg](https://github.com/go-xkg/xkg) - X Keyboard Grabber. +- [xz](https://github.com/ulikunitz/xz) - Pure golang package for reading and writing xz-compressed files. + +**[⬆ back to top](#contents)** ## Natural Language Processing -*Libraries for working with human languages.* - -* [go-eco](https://code.google.com/p/go-eco/) - Similarity, dissimilarity and distance matrices; diversity, equitability and inequality measures; species richness estimators; coenocline models. -* [go-nlp](https://github.com/nuance/go-nlp) - Utilities for working with discrete probability distributions and other tools useful for doing NLP work. -* [go-porterstemmer](https://github.com/reiver/go-porterstemmer) - A native Go clean room implementation of the Porter Stemming algorithm. -* [go-stem](https://github.com/agonopol/go-stem) - Implementation of the porter stemming algorithm. -* [golibstemmer](https://github.com/rjohnsondev/golibstemmer) - Go bindings for the snowball libstemmer library including porter 2 -* [gounidecode](https://github.com/fiam/gounidecode) - Unicode transliterator (also known as unidecode) for Go -* [icu](https://github.com/goodsign/icu) - Cgo binding for icu4c C library detection and conversion functions. Guaranteed compatibility with version 50.1. -* [libtextcat](https://github.com/goodsign/libtextcat) - Cgo binding for libtextcat C library. Guaranteed compatibility with version 2.2. -* [MMSEGO](https://github.com/awsong/MMSEGO) - This is a GO implementation of [MMSEG](http://technology.chtsai.org/mmseg/) which a Chinese word splitting algorithm. -* [paicehusk](https://github.com/Rookii/paicehusk) - Golang implementation of the Paice/Husk Stemming Algorithm -* [porter](https://github.com/a2800276/porter) - This is a fairly straighforward port of Martin Porter's C implementation of the Porter stemming algorithm. -* [porter2](https://github.com/surge/porter2) - Really fast Porter 2 stemmer. -* [segment](https://github.com/blevesearch/segment) - A Go library for performing Unicode Text Segmentation as described in [Unicode Standard Annex #29](http://www.unicode.org/reports/tr29/) -* [snowball](https://github.com/goodsign/snowball) - Snowball stemmer port (cgo wrapper) for Go. Provides word stem extraction functionality [Snowball native](http://snowball.tartarus.org/). -* [stemmer](https://github.com/dchest/stemmer) - Stemmer packages for Go programming language. Includes English and German stemmers. -* [textcat](https://github.com/pebbe/textcat) - A Go package for n-gram based text categorization, with support for utf-8 and raw text +_Libraries for working with human languages._ + +See also [Text Processing](#text-processing) and [Text Analysis](#text-analysis). + +### Language Detection + +- [detectlanguage](https://github.com/detectlanguage/detectlanguage-go) - Language Detection API Go Client. Supports batch requests, short phrase or single word language detection. +- [getlang](https://github.com/rylans/getlang) - Fast natural language detection package. +- [guesslanguage](https://github.com/endeveit/guesslanguage) - Functions to determine the natural language of a unicode text. +- [lingua-go](https://github.com/pemistahl/lingua-go) - An accurate natural language detection library, suitable for long and short text alike. Supports detecting multiple languages in mixed-language text. +- [whatlanggo](https://github.com/abadojack/whatlanggo) - Natural language detection package for Go. Supports 84 languages and 24 scripts (writing systems e.g. Latin, Cyrillic, etc). + +### Morphological Analyzers + +- [go-stem](https://github.com/agonopol/go-stem) - Implementation of the porter stemming algorithm. +- [go2vec](https://github.com/danieldk/go2vec) - Reader and utility functions for word2vec embeddings. +- [golibstemmer](https://github.com/rjohnsondev/golibstemmer) - Go bindings for the snowball libstemmer library including porter 2. +- [gosentiwordnet](https://github.com/dinopuguh/gosentiwordnet) - Sentiment analyzer using sentiwordnet lexicon in Go. +- [govader](https://github.com/jonreiter/govader) - Go implementation of [VADER Sentiment Analysis](https://github.com/cjhutto/vaderSentiment). +- [govader-backend](https://github.com/PIMPfiction/govader_backend) - Microservice implementation of [GoVader](https://github.com/jonreiter/govader). +- [kagome](https://github.com/ikawaha/kagome) - JP morphological analyzer written in pure Go. +- [libtextcat](https://github.com/goodsign/libtextcat) - Cgo binding for libtextcat C library. Guaranteed compatibility with version 2.2. +- [nlp](https://github.com/Shixzie/nlp) - Extract values from strings and fill your structs with nlp. +- [nlp](https://github.com/james-bowman/nlp) - Go Natural Language Processing library supporting LSA (Latent Semantic Analysis). +- [paicehusk](https://github.com/rookii/paicehusk) - Golang implementation of the Paice/Husk Stemming Algorithm. +- [porter](https://github.com/a2800276/porter) - This is a fairly straightforward port of Martin Porter's C implementation of the Porter stemming algorithm. +- [porter2](https://github.com/zhenjl/porter2) - Really fast Porter 2 stemmer. +- [RAKE.go](https://github.com/afjoseph/RAKE.Go) - Go port of the Rapid Automatic Keyword Extraction Algorithm (RAKE). +- [snowball](https://github.com/goodsign/snowball) - Snowball stemmer port (cgo wrapper) for Go. Provides word stem extraction functionality [Snowball native](http://snowball.tartarus.org/). +- [spaGO](https://github.com/nlpodyssey/spago) - Self-contained Machine Learning and Natural Language Processing library in Go. +- [spelling-corrector](https://github.com/jorelosorio/spellingcorrector) - A spelling corrector for the Spanish language or create your own. + +### Slugifiers + +- [go-slugify](https://github.com/mozillazg/go-slugify) - Make pretty slug with multiple languages support. +- [slug](https://github.com/gosimple/slug) - URL-friendly slugify with multiple languages support. +- [Slugify](https://github.com/avelino/slugify) - Go slugify application that handles string. + +### Tokenizers + +- [gojieba](https://github.com/yanyiwu/gojieba) - This is a Go implementation of [jieba](https://github.com/fxsjy/jieba) which a Chinese word splitting algorithm. +- [gotokenizer](https://github.com/xujiajun/gotokenizer) - A tokenizer based on the dictionary and Bigram language models for Golang. (Now only support chinese segmentation) +- [gse](https://github.com/go-ego/gse) - Go efficient text segmentation; support english, chinese, japanese and other. +- [MMSEGO](https://github.com/awsong/MMSEGO) - This is a GO implementation of [MMSEG](http://technology.chtsai.org/mmseg/) which a Chinese word splitting algorithm. +- [prose](https://github.com/jdkato/prose) - Library for text processing that supports tokenization, part-of-speech tagging, named-entity extraction, and more. English only. +- [segment](https://github.com/blevesearch/segment) - Go library for performing Unicode Text Segmentation as described in [Unicode Standard Annex #29](https://www.unicode.org/reports/tr29/) +- [sentences](https://github.com/neurosnap/sentences) - Sentence tokenizer: converts text into a list of sentences. +- [shamoji](https://github.com/osamingo/shamoji) - The shamoji is word filtering package written in Go. +- [stemmer](https://github.com/dchest/stemmer) - Stemmer packages for Go programming language. Includes English and German stemmers. +- [textcat](https://github.com/pebbe/textcat) - Go package for n-gram based text categorization, with support for utf-8 and raw text. + +### Translation + +- [ctxi18n](https://github.com/invopop/ctxi18n/) - Context aware i18n with a short and consise API, pluralization, interpolation, and `fs.FS` support. YAML locale definitions are based on [Rails i18n](https://guides.rubyonrails.org/i18n.html). +- [go-i18n](https://github.com/nicksnyder/go-i18n/) - Package and an accompanying tool to work with localized text. +- [go-mystem](https://github.com/dveselov/mystem) - CGo bindings to Yandex.Mystem - russian morphology analyzer. +- [go-pinyin](https://github.com/mozillazg/go-pinyin) - CN Hanzi to Hanyu Pinyin converter. +- [go-words](https://github.com/saleh-rahimzadeh/go-words) - A words table and text resource library for Golang projects. +- [gotext](https://github.com/leonelquinteros/gotext) - GNU gettext utilities for Go. +- [iuliia-go](https://github.com/mehanizm/iuliia-go) - Transliterate Cyrillic → Latin in every possible way. +- [spreak](https://github.com/vorlif/spreak) - Flexible translation and humanization library for Go, based on the concepts behind gettext. +- [t](https://github.com/youthlin/t) - Another i18n pkg for golang, which follows GNU gettext style and supports .po/.mo files: `t.T (gettext)`, `t.N (ngettext)`, etc. And it contains a cmd tool [xtemplate](https://github.com/youthlin/t/blob/main/cmd/xtemplate), which can extract messages as a pot file from text/html template. + +### Transliteration + +- [enca](https://github.com/endeveit/enca) - Minimal cgo bindings for [libenca](https://cihar.com/software/enca/), which detects character encodings. +- [go-unidecode](https://github.com/mozillazg/go-unidecode) - ASCII transliterations of Unicode text. +- [gounidecode](https://github.com/fiam/gounidecode) - Unicode transliterator (also known as unidecode) for Go. +- [transliterator](https://github.com/alexsergivan/transliterator) - Provides one-way string transliteration with supporting of language-specific transliteration rules. + +**[⬆ back to top](#contents)** ## Networking -*Libraries for working with various layers of the network* - -* [dns](https://github.com/miekg/dns) - Go library for working with DNS -* [ftp](https://github.com/jlaffaye/ftp) - Package ftp implements a FTP client as described in [RFC 959](http://tools.ietf.org/html/rfc959). -* [gopacket](https://github.com/google/gopacket) - A Go library for packet processing with libpacp bindings -* [gopcap](https://github.com/akrennmair/gopcap) - A Go wrapper for libpcap -* [gosnmp](https://github.com/soniah/gosnmp) - Native Go library for performing SNMP actions -* [gotcp](https://github.com/gansidui/gotcp) - A Go package for quickly writing tcp applications -* [graval](https://github.com/koofr/graval) - An experimental FTP server framework. -* [linkio](https://github.com/ian-kent/linkio) - Network link speed simulation for Reader/Writer interfaces -* [portproxy](https://github.com/aybabtme/portproxy) - Simple TCP proxy which adds CORS support to API's which don't support it. -* [sftp](https://github.com/pkg/sftp) - Package sftp implements the SSH File Transfer Protocol as described in https://filezilla-project.org/specs/draft-ietf-secsh-filexfer-02.txt. -* [tcp_server](https://github.com/firstrow/tcp_server) - A Go library for building tcp servers faster +_Libraries for working with various layers of the network._ + +- [arp](https://github.com/mdlayher/arp) - Package arp implements the ARP protocol, as described in RFC 826. +- [buffstreams](https://github.com/stabbycutyou/buffstreams) - Streaming protocolbuffer data over TCP made easy. +- [canopus](https://github.com/zubairhamed/canopus) - CoAP Client/Server implementation (RFC 7252). +- [cidranger](https://github.com/yl2chen/cidranger) - Fast IP to CIDR lookup for Go. +- [dhcp6](https://github.com/mdlayher/dhcp6) - Package dhcp6 implements a DHCPv6 server, as described in RFC 3315. +- [dns](https://github.com/miekg/dns) - Go library for working with DNS. +- [dnsmonster](https://github.com/mosajjal/dnsmonster) - Passive DNS Capture/Monitoring Framework. +- [easytcp](https://github.com/DarthPestilane/easytcp) - A light-weight TCP framework written in Go (Golang), built with message router. EasyTCP helps you build a TCP server easily fast and less painful. +- [ether](https://github.com/songgao/ether) - Cross-platform Go package for sending and receiving ethernet frames. +- [ethernet](https://github.com/mdlayher/ethernet) - Package ethernet implements marshaling and unmarshalling of IEEE 802.3 Ethernet II frames and IEEE 802.1Q VLAN tags. +- [event](https://github.com/cheng-zhongliang/event) - Simple I/O event notification library written in Golang. +- [fasthttp](https://github.com/valyala/fasthttp) - Package fasthttp is a fast HTTP implementation for Go, up to 10 times faster than net/http. +- [fortio](https://github.com/fortio/fortio) - Load testing library and command line tool, advanced echo server and web UI. Allows to specify a set query-per-second load and record latency histograms and other useful stats and graph them. Tcp, Http, gRPC. +- [ftp](https://github.com/jlaffaye/ftp) - Package ftp implements a FTP client as described in [RFC 959](https://tools.ietf.org/html/rfc959). +- [ftpserverlib](https://github.com/fclairamb/ftpserverlib) - Fully featured FTP server library. +- [fullproxy](https://github.com/shoriwe/fullproxy) - A fully featured scriptable and daemon configurable proxy and pivoting toolkit with SOCKS5, HTTP, raw ports and reverse proxy protocols. +- [fwdctl](https://github.com/alegrey91/fwdctl) - A simple and intuitive CLI to manage IPTables forwards in your Linux server. +- [gaio](https://github.com/xtaci/gaio) - High performance async-io networking for Golang in proactor mode. +- [gev](https://github.com/Allenxuxu/gev) - gev is a lightweight, fast non-blocking TCP network library based on Reactor mode. +- [gldap](https://github.com/jimlambrt/gldap) - gldap provides an ldap server implementation and you provide handlers for its ldap operations. +- [gmqtt](https://github.com/DrmagicE/gmqtt) - Gmqtt is a flexible, high-performance MQTT broker library that fully implements the MQTT protocol V3.1.1. +- [gnet](https://github.com/panjf2000/gnet) - `gnet` is a high-performance, lightweight, non-blocking, event-driven networking framework written in pure Go. +- [gnet](https://github.com/fish-tennis/gnet) - `gnet` is a high-performance networking framework,especially for game servers. +- [gNxI](https://github.com/google/gnxi) - A collection of tools for Network Management that use the gNMI and gNOI protocols. +- [go-getter](https://github.com/hashicorp/go-getter) - Go library for downloading files or directories from various sources using a URL. +- [go-multiproxy](https://github.com/presbrey/go-multiproxy) - Library for making HTTP requests through a pool of proxies offering fault tolerance, load balancing, automatic retries, cookie management, and more, via http.Get/Post replacement or http.Client RoundTripper drop-in +- [go-powerdns](https://github.com/joeig/go-powerdns) - PowerDNS API bindings for Golang. +- [go-sse](https://github.com/lampctl/go-sse) - Go client and server implementation of HTML server-sent events. +- [go-stun](https://github.com/ccding/go-stun) - Go implementation of the STUN client (RFC 3489 and RFC 5389). +- [gobgp](https://github.com/osrg/gobgp) - BGP implemented in the Go Programming Language. +- [gopacket](https://github.com/google/gopacket) - Go library for packet processing with libpcap bindings. +- [gopcap](https://github.com/akrennmair/gopcap) - Go wrapper for libpcap. +- [goshark](https://github.com/sunwxg/goshark) - Package goshark use tshark to decode IP packet and create data struct to analyse packet. +- [gosnmp](https://github.com/soniah/gosnmp) - Native Go library for performing SNMP actions. +- [gotcp](https://github.com/gansidui/gotcp) - Go package for quickly writing tcp applications. +- [grab](https://github.com/cavaliercoder/grab) - Go package for managing file downloads. +- [graval](https://github.com/koofr/graval) - Experimental FTP server framework. +- [gws](https://github.com/lxzan/gws) - High-Performance WebSocket Server & Client With AsyncIO Supporting . +- [HTTPLab](https://github.com/gchaincl/httplab) - HTTPLabs let you inspect HTTP requests and forge responses. +- [httpproxy](https://github.com/wzshiming/httpproxy) - HTTP proxy handler and dialer. +- [iplib](https://github.com/c-robinson/iplib) - Library for working with IP addresses (net.IP, net.IPNet), inspired by python [ipaddress](https://docs.python.org/3/library/ipaddress.html) and ruby [ipaddr](https://ruby-doc.org/stdlib-2.5.1/libdoc/ipaddr/rdoc/IPAddr.html) +- [jazigo](https://github.com/udhos/jazigo) - Jazigo is a tool written in Go for retrieving configuration for multiple network devices. +- [kcp-go](https://github.com/xtaci/kcp-go) - KCP - Fast and Reliable ARQ Protocol. +- [kcptun](https://github.com/xtaci/kcptun) - Extremely simple & fast udp tunnel based on KCP protocol. +- [lhttp](https://github.com/fanux/lhttp) - Powerful websocket framework, build your IM server more easily. +- [linkio](https://github.com/ian-kent/linkio) - Network link speed simulation for Reader/Writer interfaces. +- [llb](https://github.com/kirillDanshin/llb) - It's a very simple but quick backend for proxy servers. Can be useful for fast redirection to predefined domain with zero memory allocation and fast response. +- [mdns](https://github.com/hashicorp/mdns) - Simple mDNS (Multicast DNS) client/server library in Golang. +- [mqttPaho](https://eclipse.org/paho/clients/golang/) - The Paho Go Client provides an MQTT client library for connection to MQTT brokers via TCP, TLS or WebSockets. +- [natiu-mqtt](https://github.com/soypat/natiu-mqtt) - A dead-simple, non-allocating, low level implementation of MQTT well suited for embedded systems. +- [nbio](https://github.com/lesismal/nbio) - Pure Go 1000k+ connections solution, support tls/http1.x/websocket and basically compatible with net/http, with high-performance and low memory cost, non-blocking, event-driven, easy-to-use. +- [net](https://golang.org/x/net) - This repository holds supplementary Go networking libraries. +- [netpoll](https://github.com/cloudwego/netpoll) - A high-performance non-blocking I/O networking framework, which focused on RPC scenarios, developed by ByteDance. +- [NFF-Go](https://github.com/intel-go/nff-go) - Framework for rapid development of performant network functions for cloud and bare-metal (former YANFF). +- [packet](https://github.com/aerogo/packet) - Send packets over TCP and UDP. It can buffer messages and hot-swap connections if needed. +- [peerdiscovery](https://github.com/schollz/peerdiscovery) - Pure Go library for cross-platform local peer discovery using UDP multicast. +- [portproxy](https://github.com/aybabtme/portproxy) - Simple TCP proxy which adds CORS support to API's which don't support it. +- [psql-wire](https://github.com/jeroenrinzema/psql-wire) - PostgreSQL server wire protocol. Build your own server and start serving connections.. +- [publicip](https://github.com/polera/publicip) - Package publicip returns your public facing IPv4 address (internet egress). +- [quic-go](https://github.com/lucas-clemente/quic-go) - An implementation of the QUIC protocol in pure Go. +- [raw](https://github.com/mdlayher/raw) - Package raw enables reading and writing data at the device driver level for a network interface. +- [sdns](https://github.com/semihalev/sdns) - A high-performance, recursive DNS resolver server with DNSSEC support, focused on preserving privacy. +- [sftp](https://github.com/pkg/sftp) - Package sftp implements the SSH File Transfer Protocol as described in . +- [ssh](https://github.com/gliderlabs/ssh) - Higher-level API for building SSH servers (wraps crypto/ssh). +- [sslb](https://github.com/eduardonunesp/sslb) - It's a Super Simples Load Balancer, just a little project to achieve some kind of performance. +- [stun](https://github.com/go-rtc/stun) - Go implementation of RFC 5389 STUN protocol. +- [tcp_server](https://github.com/firstrow/tcp_server) - Go library for building tcp servers faster. +- [tcpack](https://github.com/lim-yoona/tcpack) - tcpack is an application protocol based on TCP to Pack and Unpack bytes stream in go program. +- [tspool](https://github.com/two/tspool) - A TCP Library use worker pool to improve performance and protect your server. +- [tun2socks](https://github.com/xjasonlyu/tun2socks) - A pure go implementation of tun2socks powered by [gVisor](https://gvisor.dev/) TCP/IP stack. +- [utp](https://github.com/anacrolix/utp) - Go uTP micro transport protocol implementation. +- [vssh](https://github.com/yahoo/vssh) - Go library for building network and server automation over SSH protocol. +- [water](https://github.com/songgao/water) - Simple TUN/TAP library. +- [webhooked](https://github.com/42Atomys/webhooked) - A webhook receiver on steroids: handle, secure, format and store a Webhook payload has never been easier. +- [webrtc](https://github.com/pions/webrtc) - A pure Go implementation of the WebRTC API. +- [winrm](https://github.com/masterzen/winrm) - Go WinRM client to remotely execute commands on Windows machines. +- [xtcp](https://github.com/xfxdev/xtcp) - TCP Server Framework with simultaneous full duplex communication, graceful shutdown, and custom protocol. + +**[⬆ back to top](#contents)** + +### HTTP Clients + +_Libraries for making HTTP requests._ + +- [fast-shot](https://github.com/opus-domini/fast-shot) - Hit your API targets with rapid-fire precision using Go's fastest and simple HTTP Client. +- [gentleman](https://github.com/h2non/gentleman) - Full-featured plugin-driven HTTP client library. +- [go-cleanhttp](https://github.com/hashicorp/go-cleanhttp) - Get easily stdlib HTTP client, which does not share any state with other clients. +- [go-http-client](https://github.com/bozd4g/go-http-client) - Make http calls simply and easily. +- [go-otelroundtripper](https://github.com/NdoleStudio/go-otelroundtripper) - Go http.RoundTripper that emits open telemetry metrics for HTTP requests. +- [go-req](https://github.com/wenerme/go-req) - Declarative golang HTTP client. +- [go-retryablehttp](https://github.com/hashicorp/go-retryablehttp) - Retryable HTTP client in Go. +- [go-zoox/fetch](https://github.com/go-zoox/fetch) - A Powerful, Lightweight, Easy Http Client, inspired by Web Fetch API. +- [grequests](https://github.com/levigross/grequests) - A Go "clone" of the great and famous Requests library. +- [heimdall](https://github.com/gojektech/heimdall) - An enhanced http client with retry and hystrix capabilities. +- [httpretry](https://github.com/ybbus/httpretry) - Enriches the default go HTTP client with retry functionality. +- [pester](https://github.com/sethgrid/pester) - Go HTTP client calls with retries, backoff, and concurrency. +- [req](https://github.com/imroc/req) - Simple Go HTTP client with Black Magic (Less code and More efficiency). +- [request](https://github.com/monaco-io/request) - HTTP client for golang. If you have experience about axios or requests, you will love it. No 3rd dependency. +- [requests](https://github.com/carlmjohnson/requests) - HTTP requests for Gophers. Uses context.Context and doesn't hide the underlying net/http.Client, making it compatible with standard Go APIs. Also includes testing tools. +- [resty](https://github.com/go-resty/resty) - Simple HTTP and REST client for Go inspired by Ruby rest-client. +- [rq](https://github.com/ddo/rq) - A nicer interface for golang stdlib HTTP client. +- [sling](https://github.com/dghubble/sling) - Sling is a Go HTTP client library for creating and sending API requests. + +**[⬆ back to top](#contents)** ## OpenGL -*Libraries for using OpenGL in Go.* +_Libraries for using OpenGL in Go._ -* [gl](https://github.com/go-gl/gl) - Go bindings for OpenGL. Requires an external dependency GLEW. -* [glfw3](https://github.com/go-gl/glfw3) - Go bindings for GLFW 3. -* [glow](https://github.com/go-gl/glow) - Go binding generator and bindings for OpenGL. -* [mathgl](https://github.com/go-gl/mathgl) - Pure Go math package specialized for 3D math, with inspiration from GLM. +- [gl](https://github.com/go-gl/gl) - Go bindings for OpenGL (generated via glow). +- [glfw](https://github.com/go-gl/glfw) - Go bindings for GLFW 3. +- [go-glmatrix](https://github.com/technohippy/go-glmatrix) - Go port of [glMatrix](https://glmatrix.net/) library. +- [goxjs/gl](https://github.com/goxjs/gl) - Go cross-platform OpenGL bindings (OS X, Linux, Windows, browsers, iOS, Android). +- [goxjs/glfw](https://github.com/goxjs/glfw) - Go cross-platform glfw library for creating an OpenGL context and receiving events. +- [mathgl](https://github.com/go-gl/mathgl) - Pure Go math package specialized for 3D math, with inspiration from GLM. +**[⬆ back to top](#contents)** ## ORM -*Libraries that implement Object-Relational Mapping or datamapping techniques.* - -* [BeeDB](https://github.com/astaxie/beedb) - go ORM,support database/sql interface,pq/mysql/sqlite. -* [GORM](https://github.com/jinzhu/gorm) - The fantastic ORM library for Golang, aims to be developer friendly. -* [gorp](https://github.com/go-gorp/gorp) - Go Relational Persistence, ORM-ish library for Go. -* [hood](https://github.com/eaigner/hood) - Database agnostic ORM for Go. -* [QBS](https://github.com/coocood/qbs) - Stands for Query By Struct. A Go ORM. -* [upper.io/db](https://github.com/upper/db) - Single interface for interacting with different data sources through the use of adapters that wrap mature database drivers. -* [Xorm](https://github.com/go-xorm/xorm) - Simple and powerful ORM for Go. - +_Libraries that implement Object-Relational Mapping or datamapping techniques._ + +- [bob](https://github.com/stephenafamo/bob) - SQL query builder and ORM/Factory generator for Go. Successor of SQLBoiler. +- [bun](https://github.com/uptrace/bun) - SQL-first Golang ORM. Successor of go-pg. +- [cacheme](https://github.com/Yiling-J/cacheme-go) - Schema based, typed Redis caching/memoize framework for Go. +- [CQL](https://github.com/FrancoLiberali/cql) - Built on top of GORM, adds compile-time verified queries based on auto-generated code. +- [ent](https://github.com/facebook/ent) - An entity framework for Go. Simple, yet powerful ORM for modeling and querying data. +- [go-dbw](https://github.com/hashicorp/go-dbw) - A simple package that encapsulates database operations. +- [go-firestorm](https://github.com/jschoedt/go-firestorm) - A simple ORM for Google/Firebase Cloud Firestore. +- [go-sql](https://github.com/rushteam/gosql) - A easy ORM for mysql. +- [go-sqlbuilder](https://github.com/huandu/go-sqlbuilder) - A flexible and powerful SQL string builder library plus a zero-config ORM. +- [go-store](https://github.com/gosuri/go-store) - Simple and fast Redis backed key-value store library for Go. +- [golobby/orm](https://github.com/golobby/orm) - Simple, fast, type-safe, generic orm for developer happiness. +- [GORM](https://github.com/go-gorm/gorm) - The fantastic ORM library for Golang, aims to be developer friendly. +- [gormt](https://github.com/xxjwxc/gormt) - Mysql database to golang gorm struct. +- [gorp](https://github.com/go-gorp/gorp) - Go Relational Persistence, ORM-ish library for Go. +- [grimoire](https://github.com/Fs02/grimoire) - Grimoire is a database access layer and validation for golang. (Support: MySQL, PostgreSQL and SQLite3). +- [lore](https://github.com/abrahambotros/lore) - Simple and lightweight pseudo-ORM/pseudo-struct-mapping environment for Go. +- [marlow](https://github.com/marlow/marlow) - Generated ORM from project structs for compile time safety assurances. +- [pop/soda](https://github.com/gobuffalo/pop) - Database migration, creation, ORM, etc... for MySQL, PostgreSQL, and SQLite. +- [Prisma](https://github.com/prisma/prisma-client-go) - Prisma Client Go, Typesafe database access for Go. +- [reform](https://github.com/go-reform/reform) - Better ORM for Go, based on non-empty interfaces and code generation. +- [rel](https://github.com/go-rel/rel) - Modern Database Access Layer for Golang - Testable, Extendable and Crafted Into a Clean and Elegant API. +- [SQLBoiler](https://github.com/volatiletech/sqlboiler) - ORM generator. Generate a featureful and blazing-fast ORM tailored to your database schema. +- [upper.io/db](https://github.com/upper/db) - Single interface for interacting with different data sources through the use of adapters that wrap mature database drivers. +- [XORM](https://gitea.com/xorm/xorm) - Simple and powerful ORM for Go. (Support: MySQL, MyMysql, PostgreSQL, Tidb, SQLite3, MsSql and Oracle). +- [Zoom](https://github.com/albrow/zoom) - Blazing-fast datastore and querying engine built on Redis. + +**[⬆ back to top](#contents)** ## Package Management -*Libraries for package and dependency management.* - -* [godep](https://github.com/tools/godep) - dependency tool for go, godep helps build packages reproducibly by fixing their dependencies. -* [gom](https://github.com/mattn/gom) - Go Manager - bundle for go. -* [goop](https://github.com/nitrous-io/goop) - A simple dependency manager for Go (golang), inspired by Bundler. -* [gopm](https://github.com/gpmgo/gopm) - Go Package Manager -* [gpm](https://github.com/pote/gpm) - Barebones dependency manager for Go. -* [nut](https://github.com/jingweno/nut) - Vendor Go dependencies -* [VenGO](https://github.com/DamnWidget/VenGO) - create and manage exportable isolated go virtual environments - +_Official tooling for dependency and package management_ + +- [go modules](https://golang.org/cmd/go/#hdr-Modules__module_versions__and_more) - Modules are the unit of source code interchange and versioning. The go command has direct support for working with modules, including recording and resolving dependencies on other modules. + +_Official experimental tooling for package management_ + +- [dep](https://github.com/golang/dep) - Go dependency tool. +- [vgo](https://go.googlesource.com/vgo/) - Versioned Go. + +_Unofficial libraries for package and dependency management._ + +- [glide](https://github.com/Masterminds/glide) - Manage your golang vendor and vendored packages with ease. Inspired by tools like Maven, Bundler, and Pip. +- [godep](https://github.com/tools/godep) - dependency tool for go, godep helps build packages reproducibly by fixing their dependencies. +- [gom](https://github.com/mattn/gom) - Go Manager - bundle for go. +- [goop](https://github.com/nitrous-io/goop) - Simple dependency manager for Go (golang), inspired by Bundler. +- [gop](https://github.com/lunny/gop) - Build and manage your Go applications out of GOPATH. +- [gopm](https://github.com/gpmgo/gopm) - Go Package Manager. +- [govendor](https://github.com/kardianos/govendor) - Go Package Manager. Go vendor tool that works with the standard vendor file. +- [gpm](https://github.com/pote/gpm) - Barebones dependency manager for Go. +- [gup](https://github.com/nao1215/gup) - Update binaries installed by "go install". +- [johnny-deps](https://github.com/VividCortex/johnny-deps) - Minimal dependency version using Git. +- [modgv](https://github.com/lucasepe/modgv) - Converts 'go mod graph' output into Graphviz's DOT language. +- [mvn-golang](https://github.com/raydac/mvn-golang) - plugin that provides way for auto-loading of Golang SDK, dependency management and start build environment in Maven project infrastructure. +- [syft](https://github.com/anchore/syft) - A CLI tool and Go library for generating a Software Bill of Materials (SBOM) from container images and filesystems. +- [VenGO](https://github.com/DamnWidget/VenGO) - create and manage exportable isolated go virtual environments. + +**[⬆ back to top](#contents)** + +## Performance + +- [go-instrument](https://github.com/nikolaydubina/go-instrument) - Automatically add spans to all methods and functions. +- [jaeger](https://github.com/jaegertracing/jaeger) - A distributed tracing system. +- [mm-go](https://github.com/joetifa2003/mm-go) - Generic manual memory management for golang. +- [pixie](https://github.com/pixie-labs/pixie) - No instrumentation tracing for Golang applications via eBPF. +- [profile](https://github.com/pkg/profile) - Simple profiling support package for Go. +- [statsviz](https://github.com/arl/statsviz) - Live visualization of your Go application runtime statistics. +- [tracer](https://github.com/kamilsk/tracer) - Simple, lightweight tracing. + +**[⬆ back to top](#contents)** + +## Query Language + +- [api-fu](https://github.com/ccbrown/api-fu) - Comprehensive GraphQL implementation. +- [dasel](https://github.com/tomwright/dasel) - Query and update data structures using selectors from the command line. Comparable to jq/yq but supports JSON, YAML, TOML and XML with zero runtime dependencies. +- [gojsonq](https://github.com/thedevsaddam/gojsonq) - A simple Go package to Query over JSON Data. +- [goven](https://github.com/SeldonIO/goven) - A drop-in query language for any database schema. +- [gqlgen](https://github.com/99designs/gqlgen) - go generate based graphql server library. +- [grapher](https://github.com/reaganiwadha/grapher) - A GraphQL field builder utilizing Go generics with extra utilities and features. +- [graphql](https://github.com/tmc/graphql) - graphql parser + utilities. +- [graphql](https://github.com/neelance/graphql-go) - GraphQL server with a focus on ease of use. +- [graphql-go](https://github.com/graphql-go/graphql) - Implementation of GraphQL for Go. +- [gws](https://github.com/Zaba505/gws) - Apollos' "GraphQL over Websocket" client and server implementation. +- [jsonpath](https://github.com/AsaiYusuke/jsonpath) - A query library for retrieving part of JSON based on JSONPath syntax. +- [jsonql](https://github.com/elgs/jsonql) - JSON query expression library in Golang. +- [jsonslice](https://github.com/bhmj/jsonslice) - Jsonpath queries with advanced filters. +- [mql](https://github.com/hashicorp/mql) - Model Query Language (mql) is a query language for your database models. +- [rql](https://github.com/a8m/rql) - Resource Query Language for REST API. +- [rqp](https://github.com/timsolov/rest-query-parser) - Query Parser for REST API. Filtering, validations, both `AND`, `OR` operations are supported directly in the query. +- [straf](https://github.com/SonicRoshan/straf) - Easily Convert Golang structs to GraphQL objects. + +**[⬆ back to top](#contents)** + +## Reflection + +- [copy](https://github.com/gotidy/copy) - Package for fast copying structs of different types. +- [Deepcopier](https://github.com/ulule/deepcopier) - Simple struct copying for Go. +- [go-deepcopy](https://github.com/tiendc/go-deepcopy) - Fast deep copy library. +- [goenum](https://github.com/lvyahui8/goenum) - A common enumeration struct based on generics and reflection that allows you to quickly define enumerations and use a set of useful default methods. +- [gotype](https://github.com/wzshiming/gotype) - Golang source code parsing, usage like reflect package. +- [gpath](https://github.com/tenntenn/gpath) - Library to simplify access struct fields with Go's expression in reflection. +- [objwalker](https://github.com/rekby/objwalker) - Walk by go objects with reflection. +- [reflectutils](https://github.com/muir/reflectutils) - Helpers for working with reflection: struct tag parsing; recursive walking; fill value from string. + +**[⬆ back to top](#contents)** ## Resource Embedding -* [go-bindata](https://github.com/jteeuwen/go-bindata) - Package that converts any file into managable Go source code. -* [go-resources](https://github.com/omeid/go-resources) - Unfancy resources embedding with Go. -* [go.rice](https://github.com/GeertJohan/go.rice) - go.rice is a Go package that makes working with resources such as html,js,css,images and templates very easy. - +- [debme](https://github.com/leaanthony/debme) - Create an `embed.FS` from an existing `embed.FS` subdirectory. +- [esc](https://github.com/mjibson/esc) - Embeds files into Go programs and provides http.FileSystem interfaces to them. +- [fileb0x](https://github.com/UnnoTed/fileb0x) - Simple tool to embed files in go with focus on "customization" and ease to use. +- [go-resources](https://github.com/omeid/go-resources) - Unfancy resources embedding with Go. +- [go.rice](https://github.com/GeertJohan/go.rice) - go.rice is a Go package that makes working with resources such as HTML, JS, CSS, images, and templates very easy. +- [mule](https://github.com/wlbr/mule) - Embed external resources like images, movies ... into Go source code to create single file binaries using `go generate`. Focused on simplicity. +- [packr](https://github.com/gobuffalo/packr) - The simple and easy way to embed static files into Go binaries. +- [rebed](https://github.com/soypat/rebed) - Recreate folder structures and files from Go 1.16's `embed.FS` type +- [statics](https://github.com/go-playground/statics) - Embeds static resources into go files for single binary compilation + works with http.FileSystem + symlinks. +- [statik](https://github.com/rakyll/statik) - Embeds static files into a Go executable. +- [templify](https://github.com/wlbr/templify) - Embed external template files into Go code to create single file binaries. +- [vfsgen](https://github.com/shurcooL/vfsgen) - Generates a vfsdata.go file that statically implements the given virtual filesystem. + +**[⬆ back to top](#contents)** ## Science and Data Analysis -*Libraries for scientific computing and data analyzing.* - -* [blas](https://github.com/ziutek/blas) - Implementation of BLAS (Basic Linear Algebra Subprograms) -* [geom](https://github.com/skelterjohn/geom) - 2D geometry for golang -* [go-fn](https://code.google.com/p/go-fn/) - Mathematical functions written in Go language, that are not covered by math pkg -* [go-gt](https://code.google.com/p/go-gt/) - Graph theory algorithms written in "Go" language -* [go.matrix](https://github.com/skelterjohn/go.matrix) - linear algebra for go (has been stalled) -* [gocomplex](https://code.google.com/p/gocomplex/) - A complex number library for the Go programming language. -* [gofrac](https://github.com/anschelsc/gofrac) - A (goinstallable) fractions library for go with support for basic arithmetic. -* [gonum/mat64](https://github.com/gonum/matrix) - The general purpose package for matrix computation. Package mat64 provides basic linear algebra operations for float64 matrices. -* [gonum/plot](https://github.com/gonum/plot) - gonum/plot provides an API for building and drawing plots in Go. -* [goraph](https://github.com/gyuho/goraph) - A pure Go graph theory library(data structure, algorith visualization) -* [gostat](https://code.google.com/p/gostat/) - A statistics library for the go language -* [mudlark-go](https://code.google.com/p/mudlark-go-pkgs/) - A collection of packages providing (hopefully) useful code for use in software using Google's Go programming language. -* [streamtools](https://github.com/nytlabs/streamtools) - general purpose, graphical tool for dealing with streams of data. -* [vectormath](https://github.com/spate/vectormath) - Vectormath for Go, an adaptation of the scalar C functions from Sony's Vector Math library, as found in the Bullet-2.79 source code. (currently inactive) +_Libraries for scientific computing and data analyzing._ + +- [assocentity](https://github.com/ndabAP/assocentity) - Package assocentity returns the average distance from words to a given entity. +- [bradleyterry](https://github.com/seanhagen/bradleyterry) - Provides a Bradley-Terry Model for pairwise comparisons. +- [calendarheatmap](https://github.com/nikolaydubina/calendarheatmap) - Calendar heatmap in plain Go inspired by Github contribution activity. +- [chart](https://github.com/vdobler/chart) - Simple Chart Plotting library for Go. Supports many graphs types. +- [dataframe-go](https://github.com/rocketlaunchr/dataframe-go) - Dataframes for machine-learning and statistics (similar to pandas). +- [decimal](https://github.com/db47h/decimal) - Package decimal implements arbitrary-precision decimal floating-point arithmetic. +- [evaler](https://github.com/soniah/evaler) - Simple floating point arithmetic expression evaluator. +- [ewma](https://github.com/VividCortex/ewma) - Exponentially-weighted moving averages. +- [geom](https://github.com/skelterjohn/geom) - 2D geometry for golang. +- [go-dsp](https://github.com/mjibson/go-dsp) - Digital Signal Processing for Go. +- [go-estimate](https://github.com/milosgajdos/go-estimate) - State estimation and filtering algorithms in Go. +- [go-gt](https://github.com/ThePaw/go-gt) - Graph theory algorithms written in "Go" language. +- [go-hep](https://github.com/go-hep/hep) - A set of libraries and tools for performing High Energy Physics analyses with ease. +- [godesim](https://github.com/soypat/godesim) - Extended/multivariable ODE solver framework for event-based simulations with simple API. +- [goent](https://github.com/kzahedi/goent) - GO Implementation of Entropy Measures. +- [gograph](https://github.com/hmdsefi/gograph) - A golang generic graph library that provides mathematical graph-theory and algorithms. +- [gohistogram](https://github.com/VividCortex/gohistogram) - Approximate histograms for data streams. +- [gonum](https://github.com/gonum/gonum) - Gonum is a set of numeric libraries for the Go programming language. It contains libraries for matrices, statistics, optimization, and more. +- [gonum/plot](https://github.com/gonum/plot) - gonum/plot provides an API for building and drawing plots in Go. +- [goraph](https://github.com/gyuho/goraph) - Pure Go graph theory library(data structure, algorithm visualization). +- [gosl](https://github.com/cpmech/gosl) - Go scientific library for linear algebra, FFT, geometry, NURBS, numerical methods, probabilities, optimisation, differential equations, and more. +- [GoStats](https://github.com/OGFris/GoStats) - GoStats is an Open Source GoLang library for math statistics mostly used in Machine Learning domains, it covers most of the Statistical measures functions. +- [graph](https://github.com/yourbasic/graph) - Library of basic graph algorithms. +- [jsonl-graph](https://github.com/nikolaydubina/jsonl-graph) - Tool to manipulate JSONL graphs with graphviz support. +- [ode](https://github.com/ChristopherRabotin/ode) - Ordinary differential equation (ODE) solver which supports extended states and channel-based iteration stop conditions. +- [orb](https://github.com/paulmach/orb) - 2D geometry types with clipping, GeoJSON and Mapbox Vector Tile support. +- [pagerank](https://github.com/alixaxel/pagerank) - Weighted PageRank algorithm implemented in Go. +- [piecewiselinear](https://github.com/sgreben/piecewiselinear) - Tiny linear interpolation library. +- [PiHex](https://github.com/claygod/PiHex) - Implementation of the "Bailey-Borwein-Plouffe" algorithm for the hexadecimal number Pi. +- [Poly](https://github.com/bebop/poly) - A Go package for engineering organisms. +- [rootfinding](https://github.com/khezen/rootfinding) - root-finding algorithms library for finding roots of quadratic functions. +- [sparse](https://github.com/james-bowman/sparse) - Go Sparse matrix formats for linear algebra supporting scientific and machine learning applications, compatible with gonum matrix libraries. +- [stats](https://github.com/montanaflynn/stats) - Statistics package with common functions missing from the Golang standard library. +- [streamtools](https://github.com/nytlabs/streamtools) - general purpose, graphical tool for dealing with streams of data. +- [TextRank](https://github.com/DavidBelicza/TextRank) - TextRank implementation in Golang with extendable features (summarization, weighting, phrase extraction) and multithreading (goroutine) support. +- [topk](https://github.com/keilerkonzept/topk) - Sliding-window and regular top-K sketches, based on the HeavyKeeper algorithm. +- [triangolatte](https://github.com/tchayen/triangolatte) - 2D triangulation library. Allows translating lines and polygons (both based on points) to the language of GPUs. + +**[⬆ back to top](#contents)** + +## Security + +_Libraries that are used to help make your application more secure._ + +- [acmetool](https://github.com/hlandau/acme) - ACME (Let's Encrypt) client tool with automatic renewal. +- [acopw-go](https://sr.ht/~jamesponddotco/acopw-go/) - Small cryptographically secure password generator package for Go. +- [acra](https://github.com/cossacklabs/acra) - Network encryption proxy to protect database-based applications from data leaks: strong selective encryption, SQL injections prevention, intrusion detection system. +- [age](https://github.com/FiloSottile/age) - A simple, modern and secure encryption tool (and Go library) with small explicit keys, no config options, and UNIX-style composability. +- [argon2-hashing](https://github.com/andskur/argon2-hashing) - light wrapper around Go's argon2 package that closely mirrors with Go's standard library Bcrypt and simple-scrypt package. +- [argon2pw](https://github.com/raja/argon2pw) - Argon2 password hash generation with constant-time password comparison. +- [autocert](https://pkg.go.dev/golang.org/x/crypto/acme/autocert) - Auto provision Let's Encrypt certificates and start a TLS server. +- [BadActor](https://github.com/jaredfolkins/badactor) - In-memory, application-driven jailer built in the spirit of fail2ban. +- [beelzebub](https://github.com/mariocandela/beelzebub) - A secure low code honeypot framework, leveraging AI for System Virtualization. +- [booster](https://github.com/anatol/booster) - Fast initramfs generator with full-disk encryption support. +- [Cameradar](https://github.com/Ullaakut/cameradar) - Tool and library to remotely hack RTSP streams from surveillance cameras. +- [certificates](https://github.com/mvmaasakkers/certificates) - An opinionated tool for generating tls certificates. +- [CertMagic](https://github.com/caddyserver/certmagic) - Mature, robust, and powerful ACME client integration for fully-managed TLS certificate issuance and renewal. +- [Coraza](https://github.com/corazawaf/coraza) - Enterprise-ready, modsecurity and OWASP CRS compatible WAF library. +- [dongle](https://github.com/golang-module/dongle) - A simple, semantic and developer-friendly golang package for encoding&decoding and encryption&decryption. +- [encid](https://github.com/bobg/encid) - Encode and decode encrypted integer IDs. +- [firewalld-rest](https://github.com/prashantgupta24/firewalld-rest) - A rest application to dynamically update firewalld rules on a linux server. +- [go-generate-password](https://github.com/m1/go-generate-password) - Password generator that can be used on the cli or as a library. +- [go-htpasswd](https://github.com/tg123/go-htpasswd) - Apache htpasswd Parser for Go. +- [go-password-validator](https://github.com/lane-c-wagner/go-password-validator) - Password validator based on raw cryptographic entropy values. +- [go-peer](https://github.com/number571/go-peer) - A software library for creating secure and anonymous decentralized systems. +- [go-yara](https://github.com/hillu/go-yara) - Go Bindings for [YARA](https://github.com/plusvic/yara), the "pattern matching swiss knife for malware researchers (and everyone else)". +- [goArgonPass](https://github.com/dwin/goArgonPass) - Argon2 password hash and verification designed to be compatible with existing Python and PHP implementations. +- [goSecretBoxPassword](https://github.com/dwin/goSecretBoxPassword) - A probably paranoid package for securely hashing and encrypting passwords. +- [Interpol](https://github.com/avahidi/interpol) - Rule-based data generator for fuzzing and penetration testing. +- [lego](https://github.com/go-acme/lego) - Pure Go ACME client library and CLI tool (for use with Let's Encrypt). +- [luks.go](https://github.com/anatol/luks.go) - Pure Golang library to manage LUKS partitions. +- [memguard](https://github.com/awnumar/memguard) - A pure Go library for handling sensitive values in memory. +- [multikey](https://github.com/adrianosela/multikey) - An n-out-of-N keys encryption/decryption framework based on Shamir's Secret Sharing algorithm. +- [nacl](https://github.com/kevinburke/nacl) - Go implementation of the NaCL set of API's. +- [optimus-go](https://github.com/pjebs/optimus-go) - ID hashing and Obfuscation using Knuth's Algorithm. +- [passlib](https://github.com/hlandau/passlib) - Futureproof password hashing library. +- [passwap](https://github.com/zitadel/passwap) - Provides a unified implementation between different password hashing algorithms +- [secret](https://github.com/rsjethani/secret) - Prevent your secrets from leaking into logs, std\* etc. +- [secure](https://github.com/unrolled/secure) - HTTP middleware for Go that facilitates some quick security wins. +- [secureio](https://github.com/xaionaro-go/secureio) - An keyexchanging+authenticating+encrypting wrapper and multiplexer for `io.ReadWriteCloser` based on XChaCha20-poly1305, ECDH and ED25519. +- [simple-scrypt](https://github.com/elithrar/simple-scrypt) - Scrypt package with a simple, obvious API and automatic cost calibration built-in. +- [ssh-vault](https://github.com/ssh-vault/ssh-vault) - encrypt/decrypt using ssh keys. +- [sslmgr](https://github.com/adrianosela/sslmgr) - SSL certificates made easy with a high level wrapper around acme/autocert. +- [teler-waf](https://github.com/kitabisa/teler-waf) - teler-waf is a Go HTTP middleware that provide teler IDS functionality to protect against web-based attacks and improve the security of Go-based web applications. It is highly configurable and easy to integrate into existing Go applications. +- [themis](https://github.com/cossacklabs/themis) - high-level cryptographic library for solving typical data security tasks (secure data storage, secure messaging, zero-knowledge proof authentication), available for 14 languages, best fit for multi-platform apps. + +**[⬆ back to top](#contents)** ## Serialization -*Libraries and tools for binary serialization* - -* [cbor](https://github.com/2tvenom/cbor) - Golang library for working with cbor binary format -* [go-capnproto](https://github.com/glycerine/go-capnproto) - Cap'n Proto library and parser for go -* [gogoprotobuf](https://github.com/gogo/protobuf) - Protocol Buffers for Go with Gadgets -* [goprotobuf](https://github.com/golang/protobuf) - Go support, in the form of a library and protocol compiler plugin, for Google's protocol buffers. -* [mapstructure](https://github.com/mitchellh/mapstructure) - Go library for decoding generic map values into native Go structures. -* [php_session_decoder](https://github.com/yvasiyarov/php_session_decoder) - GoLang library for working with PHP session format and PHP Serialize/Unserialize functions - +_Libraries and tools for binary serialization._ + +- [asn1](https://github.com/PromonLogicalis/asn1) - Asn.1 BER and DER encoding library for golang. +- [bambam](https://github.com/glycerine/bambam) - generator for Cap'n Proto schemas from go. +- [bel](https://github.com/32leaves/bel) - Generate TypeScript interfaces from Go structs/interfaces. Useful for JSON RPC. +- [binstruct](https://github.com/ghostiam/binstruct) - Golang binary decoder for mapping data into the structure. +- [cbor](https://github.com/fxamacker/cbor) - Small, safe, and easy CBOR encoding and decoding library. +- [colfer](https://github.com/pascaldekloe/colfer) - Code generation for the Colfer binary format. +- [csvutil](https://github.com/jszwec/csvutil) - High Performance, idiomatic CSV record encoding and decoding to native Go structures. +- [elastic](https://github.com/epiclabs-io/elastic) - Convert slices, maps or any other unknown value across different types at run-time, no matter what. +- [fixedwidth](https://github.com/huydang284/fixedwidth) - Fixed-width text formatting (UTF-8 supported). +- [fwencoder](https://github.com/o1egl/fwencoder) - Fixed width file parser (encoding and decoding library) for Go. +- [go-capnproto](https://github.com/glycerine/go-capnproto) - Cap'n Proto library and parser for go. +- [go-codec](https://github.com/ugorji/go) - High Performance, feature-Rich, idiomatic encode, decode and rpc library for msgpack, cbor and json, with runtime-based OR code-generation support. +- [go-csvlib](https://github.com/tiendc/go-csvlib) - High level and rich functionalities CSV serialization/deserialization library. +- [gogoprotobuf](https://github.com/gogo/protobuf) - Protocol Buffers for Go with Gadgets. +- [goprotobuf](https://github.com/golang/protobuf) - Go support, in the form of a library and protocol compiler plugin, for Google's protocol buffers. +- [gotiny](https://github.com/raszia/gotiny) - Efficient Go serialization library, gotiny is almost as fast as serialization libraries that generate code. +- [jsoniter](https://github.com/json-iterator/go) - High-performance 100% compatible drop-in replacement of "encoding/json". +- [mapstructure](https://github.com/mitchellh/mapstructure) - Go library for decoding generic map values into native Go structures. +- [php_session_decoder](https://github.com/yvasiyarov/php_session_decoder) - GoLang library for working with PHP session format and PHP Serialize/Unserialize functions. +- [pletter](https://github.com/vimeda/pletter) - A standard way to wrap a proto message for message brokers. +- [structomap](https://github.com/tuvistavie/structomap) - Library to easily and dynamically generate maps from static structures. +- [unitpacking](https://github.com/recolude/unitpacking) - Library to pack unit vectors into as fewest bytes as possible. + +**[⬆ back to top](#contents)** ## Server Applications -* [algernon](https://github.com/xyproto/algernon) - HTTP/2 web server with built-in support for Lua, Markdown, GCSS and Amber. -* [etcd](https://github.com/coreos/etcd) - A highly-available key value store for shared configuration and service discovery. -* [nsq](http://nsq.io/) - A realtime distributed messaging platform - +- [algernon](https://github.com/xyproto/algernon) - HTTP/2 web server with built-in support for Lua, Markdown, GCSS and Amber. +- [Caddy](https://github.com/caddyserver/caddy) - Caddy is an alternative, HTTP/2 web server that's easy to configure and use. +- [consul](https://www.consul.io/) - Consul is a tool for service discovery, monitoring and configuration. +- [cortex-tenant](https://github.com/blind-oracle/cortex-tenant) - Prometheus remote write proxy that adds add Cortex tenant ID header based on metric labels. +- [devd](https://github.com/cortesi/devd) - Local webserver for developers. +- [discovery](https://github.com/Bilibili/discovery) - A registry for resilient mid-tier load balancing and failover. +- [dudeldu](https://github.com/krotik/dudeldu) - A simple SHOUTcast server. +- [dummy](https://github.com/neotoolkit/dummy) - Run mock server based off an API contract with one command. +- [Easegress](https://github.com/megaease/easegress) - A cloud native high availability/performance traffic orchestration system with observability and extensibility. +- [etcd](https://github.com/etcd-io/etcd) - Highly-available key value store for shared configuration and service discovery. +- [Euterpe](https://github.com/ironsmile/euterpe) - Self-hosted music streaming server with built-in web UI and REST API. +- [Fider](https://github.com/getfider/fider) - Fider is an open platform to collect and organize customer feedback. +- [Flagr](https://github.com/checkr/flagr) - Flagr is an open-source feature flagging and A/B testing service. +- [flipt](https://github.com/markphelps/flipt) - A self contained feature flag solution written in Go and Vue.js +- [go-feature-flag](https://github.com/thomaspoignant/go-feature-flag) - A simple, complete and lightweight self-hosted feature flag solution 100% Open Source. +- [go-proxy-cache](https://github.com/fabiocicerchia/go-proxy-cache) - Simple Reverse Proxy with Caching, written in Go, using Redis. +- [gondola](https://github.com/bmf-san/gondola) - A YAML based golang reverse proxy. +- [jackal](https://github.com/ortuman/jackal) - An XMPP server written in Go. +- [lets-proxy2](https://github.com/rekby/lets-proxy2) - Reverse proxy for handle https with issue certificates in fly from lets-encrypt. +- [minio](https://github.com/minio/minio) - Minio is a distributed object storage server. +- [Moxy](https://github.com/sinhashubham95/moxy) - Moxy is a simple mocker and proxy application server, you can create mock endpoints as well as proxy requests in case no mock exists for the endpoint. +- [nginx-prometheus](https://github.com/blind-oracle/nginx-prometheus) - Nginx log parser and exporter to Prometheus. +- [nsq](https://nsq.io/) - A realtime distributed messaging platform. +- [pocketbase](https://github.com/pocketbase/pocketbase) - PocketBase is a realtime backend in 1 file consisting of embedded database (SQLite) with realtime subscriptions, built-in auth management and much more. +- [protoxy](https://github.com/camgraff/protoxy) - A proxy server that converts JSON request bodies to Protocol Buffers. +- [psql-streamer](https://github.com/blind-oracle/psql-streamer) - Stream database events from PostgreSQL to Kafka. +- [riemann-relay](https://github.com/blind-oracle/riemann-relay) - Relay to load-balance Riemann events and/or convert them to Carbon. +- [RoadRunner](https://github.com/spiral/roadrunner) - High-performance PHP application server, load-balancer and process manager. +- [SFTPGo](https://github.com/drakkan/sftpgo) - Fully featured and highly configurable SFTP server with optional FTP/S and WebDAV support. It can serve local filesystem and Cloud Storage backends such as S3 and Google Cloud Storage. +- [simple-jwt-provider](https://github.com/leberKleber/simple-jwt-provider) - Simple and lightweight provider which exhibits JWTs, supports login, password-reset (via mail) and user management. +- [Trickster](https://github.com/tricksterproxy/trickster) - HTTP reverse proxy cache and time series accelerator. +- [Wish](https://github.com/charmbracelet/wish) - Make SSH apps, just like that! + +**[⬆ back to top](#contents)** + +## Stream Processing + +_Libraries and tools for stream processing and reactive programming._ + +- [go-streams](https://github.com/reugn/go-streams) - Go stream processing library. +- [goio](https://github.com/primetalk/goio) - An implementation of IO, Stream, Fiber for Golang, inspired by awesome Scala libraries cats and fs2. +- [machine](https://github.com/whitaker-io/machine) - Go library for writing and generating stream workers with built in metrics and traceability. +- [stream](https://github.com/youthlin/stream) - Go Stream, like Java 8 Stream: Filter/Map/FlatMap/Peek/Sorted/ForEach/Reduce... + +**[⬆ back to top](#contents)** ## Template Engines -*Libraries and tools for templating and lexing.* - -* [ace](https://github.com/yosssi/ace) - Ace is an HTML template engine for Go, inspired by Slim and Jade. Ace is a refinement of Gold. -* [amber](https://github.com/eknkc/amber) - Amber is an elegant templating engine for Go Programming Language It is inspired from HAML and Jade. -* [damsel](https://github.com/dskinner/damsel) - Markup language featuring html outlining via css-selectors, extensible via pkg html/template and others. -* [ego](https://github.com/benbjohnson/ego) - A lightweight templating language that lets you write templates in Go. Templates are translated into Go and compiled. -* [kasia.go](https://github.com/ziutek/kasia.go) - Templating system for HTML and other text documents - go implementation. -* [mustache](https://github.com/hoisie/mustache) - A Go implementation of the Mustache template language. -* [pongo2](https://github.com/flosch/pongo2) - A Django-like template-engine for Go. -* [Razor](https://github.com/sipin/gorazor) - Razor view engine for Golang. -* [Soy](https://github.com/robfig/soy) - Closure templates (aka Soy templates) for Go, following the [official spec](https://developers.google.com/closure/templates/) - +_Libraries and tools for templating and lexing._ + +- [ego](https://github.com/benbjohnson/ego) - Lightweight templating language that lets you write templates in Go. Templates are translated into Go and compiled. +- [extemplate](https://github.com/dannyvankooten/extemplate) - Tiny wrapper around html/template to allow for easy file-based template inheritance. +- [fasttemplate](https://github.com/valyala/fasttemplate) - Simple and fast template engine. Substitutes template placeholders up to 10x faster than [text/template](https://golang.org/pkg/text/template/). +- [gomponents](https://www.gomponents.com) - HTML 5 components in pure Go, that look something like this: `func(name string) g.Node { return Div(Class("headline"), g.Textf("Hi %v!", name)) }`. +- [gospin](https://github.com/m1/gospin) - Article spinning and spintax/spinning syntax engine, useful for A/B, testing pieces of text/articles and creating more natural conversations. +- [got](https://github.com/goradd/got) - A Go code generator inspired by Hero and Fasttemplate. Has include files, custom tag definitions, injected Go code, language translation, and more. +- [goview](https://github.com/foolin/goview) - Goview is a lightweight, minimalist and idiomatic template library based on golang html/template for building Go web application. +- [jet](https://github.com/CloudyKit/jet) - Jet template engine. +- [liquid](https://github.com/osteele/liquid) - Go implementation of Shopify Liquid templates. +- [maroto](https://github.com/johnfercher/maroto) - A maroto way to create PDFs. Maroto is inspired in Bootstrap and uses gofpdf. Fast and simple. +- [pongo2](https://github.com/flosch/pongo2) - Django-like template-engine for Go. +- [quicktemplate](https://github.com/valyala/quicktemplate) - Fast, powerful, yet easy to use template engine. Converts templates into Go code and then compiles it. +- [raymond](https://github.com/aymerick/raymond) - Complete handlebars implementation in Go. +- [Razor](https://github.com/sipin/gorazor) - Razor view engine for Golang. +- [Soy](https://github.com/robfig/soy) - Closure templates (aka Soy templates) for Go, following the [official spec](https://developers.google.com/closure/templates/). +- [sprout](https://github.com/go-sprout/sprout) - Useful template functions for Go templates. +- [tbd](https://github.com/lucasepe/tbd) - A really simple way to create text templates with placeholders - exposes extra builtin Git repo metadata. +- [templ](https://github.com/a-h/templ) - A HTML templating language that has great developer tooling. + +**[⬆ back to top](#contents)** ## Testing -*Libraries for testing codebases and generating test data.* - -* Testing Frameworks - * [assert](https://github.com/bmizerany/assert) - Asserts to Go testing - * [ginkgo](http://onsi.github.io/ginkgo/) - BDD Testing Framework for Go - * [go-mutesting](https://github.com/zimmski/go-mutesting) - Mutation testing for Go source code - * [goblin](https://github.com/franela/goblin) - Mocha like testing framework fo Go - * [gocheck](http://labix.org/gocheck) - A more advanced testing framework alternative to gotest. - * [GoConvey](https://github.com/smartystreets/goconvey/) - BDD-style framework with web UI and live reload - * [GoSpec](https://github.com/orfjackal/gospec) - BDD-style testing framework for the Go programming language. - * [gospecify](https://github.com/stesla/gospecify) - This provides a BDD syntax for testing your Go code. It should be familiar to anybody who has used libraries such as rspec. - * [Hamcrest](https://github.com/rdrdr/hamcrest) - fluent framework for declarative Matcher objects that, when applied to input values, produce self-describing results. - * [restit](https://github.com/yookoala/restit) - A Go micro framework to help writing RESTful API integration test. - * [Testify](https://github.com/stretchr/testify) - A sacred extension to the standard go testing package. - -* Mock - * [counterfeiter](https://github.com/maxbrunsfeld/counterfeiter) - Tool for generating self-contained mock objects - * [go-sqlmock](https://github.com/DATA-DOG/go-sqlmock) - Mock SQL driver for testing database interactions - * [gomock](https://code.google.com/p/gomock/) - Mocking framework for the Go programming language. - * [mockhttp.go](https://github.com/tv42/mockhttp.go) - Mock object for Go http.ResponseWriter - -* Fuzzing and delta-debugging/reducing/shrinking - * [gofuzz](https://github.com/google/gofuzz) - A library for populating go objects with random values - * [gogenerate](https://github.com/arschles/gogenerate) - A Scalacheck-like library for Go - * [Tavor](https://github.com/zimmski/tavor) - A generic fuzzing and delta-debugging framework +_Libraries for testing codebases and generating test data._ + +### Testing Frameworks + +- [apitest](https://apitest.dev) - Simple and extensible behavioural testing library for REST based services or HTTP handlers that supports mocking external http calls and rendering of sequence diagrams. +- [arch-go](https://github.com/fdaines/arch-go) - Architecture testing tool for Go projects. +- [assert](https://github.com/go-playground/assert) - Basic Assertion Library used along side native go testing, with building blocks for custom assertions. +- [baloo](https://github.com/h2non/baloo) - Expressive and versatile end-to-end HTTP API testing made easy. +- [be](https://github.com/carlmjohnson/be) - The minimalist generic test assertion library. +- [biff](https://github.com/fulldump/biff) - Bifurcation testing framework, BDD compatible. +- [charlatan](https://github.com/percolate/charlatan) - Tool to generate fake interface implementations for tests. +- [commander](https://github.com/SimonBaeumer/commander) - Tool for testing cli applications on windows, linux and osx. +- [cupaloy](https://github.com/bradleyjkemp/cupaloy) - Simple snapshot testing addon for your test framework. +- [dbcleaner](https://github.com/khaiql/dbcleaner) - Clean database for testing purpose, inspired by `database_cleaner` in Ruby. +- [dft](https://github.com/abecodes/dft) - Lightweight, zero dependency docker containers for testing (or more). +- [dsunit](https://github.com/viant/dsunit) - Datastore testing for SQL, NoSQL, structured files. +- [embedded-postgres](https://github.com/fergusstrange/embedded-postgres) - Run a real Postgres database locally on Linux, OSX or Windows as part of another Go application or test. +- [endly](https://github.com/viant/endly) - Declarative end to end functional testing. +- [envite](https://github.com/PerimeterX/envite) - Dev and testing environment management framework. +- [fixenv](https://github.com/rekby/fixenv) - Fixture manage engine, inspired by pytest fixtures. +- [fluentassert](https://github.com/fluentassert/verify) - Extensible, type-safe, fluent assertion Go library. +- [flute](https://github.com/suzuki-shunsuke/flute) - HTTP client testing framework. +- [frisby](https://github.com/verdverm/frisby) - REST API testing framework. +- [gherkingen](https://github.com/hedhyw/gherkingen) - BDD boilerplate generator and framework. +- [ginkgo](https://onsi.github.io/ginkgo/) - BDD Testing Framework for Go. +- [gnomock](https://github.com/orlangure/gnomock) - integration testing with real dependencies (database, cache, even Kubernetes or AWS) running in Docker, without mocks. +- [go-carpet](https://github.com/msoap/go-carpet) - Tool for viewing test coverage in terminal. +- [go-cmp](https://github.com/google/go-cmp) - Package for comparing Go values in tests. +- [go-hit](https://github.com/Eun/go-hit) - Hit is an http integration test framework written in golang. +- [go-mutesting](https://github.com/zimmski/go-mutesting) - Mutation testing for Go source code. +- [go-mysql-test-container](https://github.com/arikama/go-mysql-test-container) - Golang MySQL testcontainer to help with MySQL integration testing. +- [go-snaps](http://github.com/gkampitakis/go-snaps) - Jest-like snapshot testing in Golang. +- [go-testdeep](https://github.com/maxatome/go-testdeep) - Extremely flexible golang deep comparison, extends the go testing package. +- [go-testpredicate](https://github.com/maargenton/go-testpredicate) - Test predicate style assertions library with extensive diagnostics output. +- [go-vcr](https://github.com/dnaeon/go-vcr) - Record and replay your HTTP interactions for fast, deterministic and accurate tests. +- [goblin](https://github.com/franela/goblin) - Mocha like testing framework of Go. +- [goc](https://github.com/qiniu/goc) - Goc is a comprehensive coverage testing system for The Go Programming Language. +- [gocheck](https://labix.org/gocheck) - More advanced testing framework alternative to gotest. +- [GoConvey](https://github.com/smartystreets/goconvey/) - BDD-style framework with web UI and live reload. +- [gocrest](https://github.com/corbym/gocrest) - Composable hamcrest-like matchers for Go assertions. +- [godog](https://github.com/cucumber/godog) - Cucumber BDD framework for Go. +- [gofight](https://github.com/appleboy/gofight) - API Handler Testing for Golang Router framework. +- [gogiven](https://github.com/corbym/gogiven) - YATSPEC-like BDD testing framework for Go. +- [gomatch](https://github.com/jfilipczyk/gomatch) - library created for testing JSON against patterns. +- [gomega](https://onsi.github.io/gomega/) - Rspec like matcher/assertion library. +- [Gont](https://github.com/stv0g/gont) - Go network testing toolkit for testing building complex network topologies using Linux namespaces. +- [gospecify](https://github.com/stesla/gospecify) - This provides a BDD syntax for testing your Go code. It should be familiar to anybody who has used libraries such as rspec. +- [gosuite](https://github.com/pavlo/gosuite) - Brings lightweight test suites with setup/teardown facilities to `testing` by leveraging Go1.7's Subtests. +- [got](https://github.com/ysmood/got) - An enjoyable golang test framework. +- [gotest.tools](https://github.com/gotestyourself/gotest.tools) - A collection of packages to augment the go testing package and support common patterns. +- [Hamcrest](https://github.com/rdrdr/hamcrest) - fluent framework for declarative Matcher objects that, when applied to input values, produce self-describing results. +- [httpexpect](https://github.com/gavv/httpexpect) - Concise, declarative, and easy to use end-to-end HTTP and REST API testing. +- [is](https://github.com/matryer/is) - Professional lightweight testing mini-framework for Go. +- [jsonassert](https://github.com/kinbiko/jsonassert) - Package for verifying that your JSON payloads are serialized correctly. +- [keploy](https://github.com/keploy/keploy) - Generate Testcase and Data Mocks from API calls automatically. +- [omg.testingtools](https://github.com/dedalqq/omg.testingtools) - The simple library for change a values of private fields for testing. +- [restit](https://github.com/yookoala/restit) - Go micro framework to help writing RESTful API integration test. +- [schema](https://github.com/jgroeneveld/schema) - Quick and easy expression matching for JSON schemas used in requests and responses. +- [stop-and-go](https://github.com/elgohr/stop-and-go) - Testing helper for concurrency. +- [testcase](https://github.com/adamluzsi/testcase) - Idiomatic testing framework for Behavior Driven Development. +- [testcerts](https://github.com/madflojo/testcerts) - Dynamically generate self-signed certificates and certificate authorities within your test functions. +- [testcontainers-go](https://github.com/testcontainers/testcontainers-go) - A Go package that makes it simple to create and clean up container-based dependencies for automated integration/smoke tests. The clean, easy-to-use API enables developers to programmatically define containers that should be run as part of a test and clean up those resources when the test is done. +- [testfixtures](https://github.com/go-testfixtures/testfixtures) - A helper for Rails' like test fixtures to test database applications. +- [Testify](https://github.com/stretchr/testify) - Sacred extension to the standard go testing package. +- [testsql](https://github.com/zhulongcheng/testsql) - Generate test data from SQL files before testing and clear it after finished. +- [testza](https://github.com/MarvinJWendt/testza) - Full-featured test framework with nice colorized output. +- [trial](https://github.com/jgroeneveld/trial) - Quick and easy extendable assertions without introducing much boilerplate. +- [Tt](https://github.com/vcaesar/tt) - Simple and colorful test tools. +- [wstest](https://github.com/posener/wstest) - Websocket client for unit-testing a websocket http.Handler. + +### Mock + +- [counterfeiter](https://github.com/maxbrunsfeld/counterfeiter) - Tool for generating self-contained mock objects. +- [genmock](https://gitlab.com/so_literate/genmock) - Go mocking system with code generator for building calls of the interface methods. +- [go-localstack](https://github.com/elgohr/go-localstack) - Tool for using localstack in AWS testing. +- [go-sqlmock](https://github.com/DATA-DOG/go-sqlmock) - Mock SQL driver for testing database interactions. +- [go-txdb](https://github.com/DATA-DOG/go-txdb) - Single transaction based database driver mainly for testing purposes. +- [gock](https://github.com/h2non/gock) - Versatile HTTP mocking made easy. +- [gomock](https://github.com/golang/mock) - Mocking framework for the Go programming language. +- [govcr](https://github.com/seborama/govcr) - HTTP mock for Golang: record and replay HTTP interactions for offline testing. +- [hoverfly](https://github.com/SpectoLabs/hoverfly) - HTTP(S) proxy for recording and simulating REST/SOAP APIs with extensible middleware and easy-to-use CLI. +- [httpmock](https://github.com/jarcoal/httpmock) - Easy mocking of HTTP responses from external resources. +- [minimock](https://github.com/gojuno/minimock) - Mock generator for Go interfaces. +- [mockery](https://github.com/vektra/mockery) - Tool to generate Go interfaces. +- [mockhttp](https://github.com/tv42/mockhttp) - Mock object for Go http.ResponseWriter. +- [mooncake](https://github.com/GuilhermeCaruso/mooncake) - A simple way to generate mocks for multiple purposes. +- [moq](https://github.com/matryer/moq) - Utility that generates a struct from any interface. The struct can be used in test code as a mock of the interface. +- [timex](https://github.com/cabify/timex) - A test-friendly replacement for the native `time` package. +- [xgo](https://github.com/xhd2015/xgo) - A general pureposed function mocking library. + +### Fuzzing and delta-debugging/reducing/shrinking + +- [go-fuzz](https://github.com/dvyukov/go-fuzz) - Randomized testing system. +- [gofuzz](https://github.com/google/gofuzz) - Library for populating go objects with random values. +- [Tavor](https://github.com/zimmski/tavor) - Generic fuzzing and delta-debugging framework. + +### Selenium and browser control tools + +- [cdp](https://github.com/mafredri/cdp) - Type-safe bindings for the Chrome Debugging Protocol that can be used with browsers or other debug targets that implement it. +- [chromedp](https://github.com/knq/chromedp) - a way to drive/test Chrome, Safari, Edge, Android Webviews, and other browsers supporting the Chrome Debugging Protocol. +- [ggr](https://github.com/aerokube/ggr) - a lightweight server that routes and proxies Selenium WebDriver requests to multiple Selenium hubs. +- [playwright-go](https://github.com/mxschmitt/playwright-go) - browser automation library to control Chromium, Firefox and WebKit with a single API. +- [rod](https://github.com/go-rod/rod) - A Devtools driver to make web automation and scraping easy. +- [selenoid](https://github.com/aerokube/selenoid) - alternative Selenium hub server that launches browsers within containers. + +### Fail injection +- [failpoint](https://github.com/pingcap/failpoint) - An implementation of [failpoints](https://www.freebsd.org/cgi/man.cgi?query=fail) for Golang. + +**[⬆ back to top](#contents)** ## Text Processing -*Libraries for parsing and manipulating texts.* - -* Specific Formats - * [blackfriday](https://github.com/russross/blackfriday) - Markdown processor in Go - * [github_flavored_markdown](http://godoc.org/github.com/shurcooL/go/github_flavored_markdown) - GitHub Flavored Markdown renderer in Go. - * [bluemonday](https://github.com/microcosm-cc/bluemonday) - HTML Sanitizer - * [enca](https://github.com/endeveit/enca) - Minimal cgo bindings for [libenca](http://cihar.com/software/enca/). - * [go-humanize](https://github.com/dustin/go-humanize) - Formatters for time, numbers, and memory size to human readable format. - * [go-pkg-rss](https://github.com/jteeuwen/go-pkg-rss) - This package reads RSS and Atom feeds and provides a caching mechanism that adheres to the feed specs. - * [go-pkg-xmlx](https://github.com/jteeuwen/go-pkg-xmlx) - Extension to the standard Go XML package. Maintains a node tree that allows forward/backwards browsing and exposes some simple single/multi-node search functions. - * [go-runewidth](https://github.com/mattn/go-runewidth) - Functions to get fixed width of the character or string. - * [gographviz](https://github.com/awalterschulze/gographviz) - Parses the Graphviz DOT language. - * [GoQuery](https://github.com/PuerkitoBio/goquery) - GoQuery brings a syntax and a set of features similar to jQuery to the Go language. - * [goregen](https://github.com/zach-klippenstein/goregen) - A library for generating random strings from regular expressions. - * [guesslanguage](https://github.com/endeveit/guesslanguage) - Functions to determine the natural language of a unicode text. - * [slug](https://github.com/gosimple/slug) - URL-friendly slugify with multiple languages support. - * [Slugify](https://github.com/avelino/slugify) - A Go slugify application that handles string. - * [toml](https://github.com/BurntSushi/toml) - TOML configuration format (encoder/decoder with reflection). -* Utility - * [gotabulate](https://github.com/bndr/gotabulate) - Easily pretty-print your tabular data with Go. - * [govalidator](https://github.com/asaskevich/govalidator) - package of string validators and sanitizers for Go lang. - +_Libraries for parsing and manipulating texts._ + +See also [Natural Language Processing](#natural-language-processing) and [Text Analysis](#text-analysis). + +### Formatters + +- [address](https://github.com/bojanz/address) - Handles address representation, validation and formatting. +- [align](https://github.com/Guitarbum722/align) - A general purpose application that aligns text. +- [bytes](https://github.com/labstack/gommon/tree/master/bytes) - Formats and parses numeric byte values (10K, 2M, 3G, etc.). +- [go-fixedwidth](https://github.com/ianlopshire/go-fixedwidth) - Fixed-width text formatting (encoder/decoder with reflection). +- [go-humanize](https://github.com/dustin/go-humanize) - Formatters for time, numbers, and memory size to human readable format. +- [gotabulate](https://github.com/bndr/gotabulate) - Easily pretty-print your tabular data with Go. +- [textwrap](https://github.com/isbm/textwrap) - Wraps text at end of lines. Implementation of `textwrap` module from Python. + +### Markup Languages + +- [bafi](https://github.com/mmalcek/bafi) - Universal JSON, BSON, YAML, XML translator to ANY format using templates. +- [bbConvert](https://github.com/CalebQ42/bbConvert) - Converts bbCode to HTML that allows you to add support for custom bbCode tags. +- [blackfriday](https://github.com/russross/blackfriday) - Markdown processor in Go. +- [go-output-format](https://github.com/drewstinnett/go-output-format) - Output go structures into multiple formats (YAML/JSON/etc) in your command line app. +- [go-toml](https://github.com/pelletier/go-toml) - Go library for the TOML format with query support and handy cli tools. +- [goldmark](https://github.com/yuin/goldmark) - A Markdown parser written in Go. Easy to extend, standard (CommonMark) compliant, well structured. +- [goq](https://github.com/andrewstuart/goq) - Declarative unmarshalling of HTML using struct tags with jQuery syntax (uses GoQuery). +- [html-to-markdown](https://github.com/JohannesKaufmann/html-to-markdown) - Convert HTML to Markdown. Even works with entire websites and can be extended through rules. +- [htmlquery](https://github.com/antchfx/htmlquery) - An XPath query package for HTML, lets you extract data or evaluate from HTML documents by an XPath expression. +- [htmlyaml](https://github.com/nikolaydubina/htmlyaml) - Rich rendering of YAML as HTML in Go +- [htree](https://github.com/bobg/htree) - Traverse, navigate, filter, and otherwise process trees of [html.Node](https://pkg.go.dev/golang.org/x/net/html#Node) objects. +- [mxj](https://github.com/clbanning/mxj) - Encode / decode XML as JSON or map[string]interface{}; extract values with dot-notation paths and wildcards. Replaces x2j and j2x packages. +- [toml](https://github.com/BurntSushi/toml) - TOML configuration format (encoder/decoder with reflection). + +### Parsers/Encoders/Decoders + +- [allot](https://github.com/sbstjn/allot) - Placeholder and wildcard text parsing for CLI tools and bots. +- [codetree](https://github.com/aerogo/codetree) - Parses indented code (python, pixy, scarlet, etc.) and returns a tree structure. +- [commonregex](https://github.com/mingrammer/commonregex) - A collection of common regular expressions for Go. +- [did](https://github.com/ockam-network/did) - DID (Decentralized Identifiers) Parser and Stringer in Go. +- [doi](https://github.com/hscells/doi) - Document object identifier (doi) parser in Go. +- [editorconfig-core-go](https://github.com/editorconfig/editorconfig-core-go) - Editorconfig file parser and manipulator for Go. +- [encdec](https://github.com/mickep76/encdec) - Package provides a generic interface to encoders and decoders. +- [go-fasttld](https://github.com/elliotwutingfeng/go-fasttld) - High performance effective top level domains (eTLD) extraction module. +- [go-nmea](https://github.com/adrianmo/go-nmea) - NMEA parser library for the Go language. +- [go-querystring](https://github.com/google/go-querystring) - Go library for encoding structs into URL query parameters. +- [go-vcard](https://github.com/emersion/go-vcard) - Parse and format vCard. +- [godump](https://github.com/yassinebenaid/godump) - Pretty print any GO variable with ease, an alternative to Go's `fmt.Printf("%#v")`. +- [gofeed](https://github.com/mmcdole/gofeed) - Parse RSS and Atom feeds in Go. +- [gographviz](https://github.com/awalterschulze/gographviz) - Parses the Graphviz DOT language. +- [gonameparts](https://github.com/polera/gonameparts) - Parses human names into individual name parts. +- [ltsv](https://github.com/Wing924/ltsv) - High performance [LTSV (Labeled Tab Separated Value)](http://ltsv.org/) reader for Go. +- [normalize](https://github.com/avito-tech/normalize) - Sanitize, normalize and compare fuzzy text. +- [parseargs-go](https://github.com/nproc/parseargs-go) - string argument parser that understands quotes and backslashes. +- [parth](https://github.com/codemodus/parth) - URL path segmentation parsing. +- [prattle](https://github.com/askeladdk/prattle) - Scan and parse LL(1) grammars simply and efficiently. +- [sdp](https://github.com/gortc/sdp) - SDP: Session Description Protocol [[RFC 4566](https://tools.ietf.org/html/rfc4566)]. +- [sh](https://github.com/mvdan/sh) - Shell parser and formatter. +- [tokenizer](https://github.com/bzick/tokenizer) - Parse any string, slice or infinite buffer to any tokens. +- [when](https://github.com/olebedev/when) - Natural EN and RU language date/time parser with pluggable rules. +- [xj2go](https://github.com/stackerzzq/xj2go) - Convert xml or json to go struct. + +### Regular Expressions + +- [genex](https://github.com/alixaxel/genex) - Count and expand Regular Expressions into all matching Strings. +- [go-wildcard](https://github.com/IGLOU-EU/go-wildcard) - Simple and lightweight wildcard pattern matching. +- [goregen](https://github.com/zach-klippenstein/goregen) - Library for generating random strings from regular expressions. +- [regroup](https://github.com/oriser/regroup) - Match regex expression named groups into go struct using struct tags and automatic parsing. +- [rex](https://github.com/hedhyw/rex) - Regular expressions builder. + +### Sanitation + +- [bluemonday](https://github.com/microcosm-cc/bluemonday) - HTML Sanitizer. +- [gofuckyourself](https://github.com/JoshuaDoes/gofuckyourself) - A sanitization-based swear filter for Go. + +### Scrapers + +- [colly](https://github.com/asciimoo/colly) - Fast and Elegant Scraping Framework for Gophers. +- [dataflowkit](https://github.com/slotix/dataflowkit) - Web scraping Framework to turn websites into structured data. +- [go-recipe](https://github.com/kkyr/go-recipe) - A package for scraping recipes from websites. +- [GoQuery](https://github.com/PuerkitoBio/goquery) - GoQuery brings a syntax and a set of features similar to jQuery to the Go language. +- [pagser](https://github.com/foolin/pagser) - Pagser is a simple, extensible, configurable parse and deserialize html page to struct based on goquery and struct tags for golang crawler. +- [Tagify](https://github.com/zoomio/tagify) - Produces a set of tags from given source. +- [walker](https://github.com/cyucelen/walker) - Seamlessly fetch paginated data from any source. Simple and high performance API scraping included. +- [xurls](https://github.com/mvdan/xurls) - Extract urls from text. + +### RSS + +- [podcast](https://github.com/eduncan911/podcast) - iTunes Compliant and RSS 2.0 Podcast Generator in Golang + +### Utility/Miscellaneous + +- [go-runewidth](https://github.com/mattn/go-runewidth) - Functions to get fixed width of the character or string. +- [go-zero-width](https://github.com/trubitsyn/go-zero-width) - Zero-width character detection and removal for Go. +- [kace](https://github.com/codemodus/kace) - Common case conversions covering common initialisms. +- [petrovich](https://github.com/striker2000/petrovich) - Petrovich is the library which inflects Russian names to given grammatical case. +- [radix](https://github.com/yourbasic/radix) - Fast string sorting algorithm. +- [TySug](https://github.com/Dynom/TySug) - Alternative suggestions with respect to keyboard layouts. +- [w2vgrep](https://github.com/arunsupe/semantic-grep) - A semantic grep tool using word embeddings to find semantically similar matches. For example, searching for "death" will find "dead", "killing", "murder". + +**[⬆ back to top](#contents)** ## Third-party APIs -*Libraries for accessing third party APIs.* - -* [aws-sdk-go](https://github.com/awslabs/aws-sdk-go) - The official AWS SDK for the Go programming language. Caution: The SDK is currently in the process of being developed, and not everything may be working fully yet. -* [facebook](https://github.com/huandu/facebook) - Go Library that supports the Facebook Graph API -* [gami](https://github.com/bit4bit/gami) - Go library for Asterisk Manager Interface. -* [geo-golang](https://github.com/codingsince1985/geo-golang) - Go Library to access [Google Maps](https://developers.google.com/maps/documentation/geocoding/), [MapQuest](http://open.mapquestapi.com/geocoding/), [Nominatim](http://open.mapquestapi.com/nominatim/), [OpenCage](http://geocoder.opencagedata.com/api.html), [HERE](https://developer.here.com/rest-apis/documentation/geocoder) and [Bing](https://msdn.microsoft.com/en-us/library/ff701715.aspx) geocoding / reverse geocoding APIs. -* [github](https://github.com/google/go-github) - Go library for accessing the GitHub API. -* [goamz](https://github.com/mitchellh/goamz) - Popular fork of [goamz](https://launchpad.net/goamz) which adds some missing API calls to certain packages. -* [GoMusicBrainz](https://github.com/michiwend/gomusicbrainz) - a Go MusicBrainz WS2 client library -* [google](https://github.com/google/google-api-go-client) - Auto-generated Google APIs for Go -* [google-cloud](https://github.com/GoogleCloudPlatform/gcloud-golang) - Google Cloud APIs Go Client Library -* [gostorm](https://github.com/jsgilmore/gostorm) - GoStorm is a Go library that implements the communications protocol required to write Storm spouts and Bolts in Go that communicate with the Storm shells. -* [hipchat](https://github.com/andybons/hipchat) - This project implements a golang client library for the Hipchat API. -* [hipchat (xmpp)](https://github.com/daneharrigan/hipchat) - A golang package to communicate with HipChat over XMPP. -* [mixpanel](https://github.com/dukex/mixpanel) - Mixpanel is a library for tracking events and sending Mixpanel profile updates to Mixpanel from your go applications. -* [rrdaclient](https://github.com/Omie/rrdaclient) - Go Library to access statdns.com API, which is in turn RRDA API. DNS Queries over HTTP. -* [shopify](https://github.com/rapito/go-shopify) - Go Library to make CRUD request to the Shopify API. -* [smite](https://github.com/sergiotapia/smitego) - Go package to wraps access to the Smite game API. -* [snapchat](https://github.com/jamieomatthews/gosnap) - Go wrapper for the snapchat API -* [spotify](https://github.com/rapito/go-spotify) - Go Library to access Spotify WEB API. -* [steam](https://github.com/sostronk/go-steam) - Go Library to interact with Steam game servers. -* [stripe](https://github.com/stripe/stripe-go) - Go client for the Stripe API - +_Libraries for accessing third party APIs._ + +- [airtable](https://github.com/mehanizm/airtable) - Go client library for the [Airtable API](https://airtable.com/api). +- [amazon-product-advertising-api](https://github.com/ngs/go-amazon-product-advertising-api) - Go Client Library for [Amazon Product Advertising API](https://affiliate-program.amazon.com/gp/advertising/api/detail/main.html). +- [anaconda](https://github.com/ChimeraCoder/anaconda) - Go client library for the Twitter 1.1 API. +- [appstore-sdk-go](https://github.com/Kachit/appstore-sdk-go) - Unofficial Golang SDK for AppStore Connect API. +- [aws-sdk-go](https://github.com/aws/aws-sdk-go-v2) - The official AWS SDK for the Go programming language. +- [bqwriter](https://github.com/OTA-Insight/bqwriter) - High Level Go Library to write data into [Google BigQuery](https://cloud.google.com/bigquery) at a high throughout. +- [brewerydb](https://github.com/naegelejd/brewerydb) - Go library for accessing the BreweryDB API. +- [cachet](https://github.com/andygrunwald/cachet) - Go client library for [Cachet (open source status page system)](https://cachethq.io/). +- [circleci](https://github.com/jszwedko/go-circleci) - Go client library for interacting with CircleCI's API. +- [clarifai](https://github.com/samuelcouch/clarifai) - Go client library for interfacing with the Clarifai API. +- [codeship-go](https://github.com/codeship/codeship-go) - Go client library for interacting with Codeship's API v2. +- [coinpaprika-go](https://github.com/coinpaprika/coinpaprika-api-go-client) - Go client library for interacting with Coinpaprika's API. +- [device-check-go](https://github.com/rinchsan/device-check-go) - Go client library for interacting with [iOS DeviceCheck API](https://developer.apple.com/documentation/devicecheck) v1. +- [discordgo](https://github.com/bwmarrin/discordgo) - Go bindings for the Discord Chat API. +- [disgo](https://github.com/switchupcb/disgo) - Go API Wrapper for the Discord API. +- [dusupay-sdk-go](https://github.com/Kachit/dusupay-sdk-go) - Unofficial Dusupay payment gateway API Client for Go +- [ethrpc](https://github.com/onrik/ethrpc) - Go bindings for Ethereum JSON RPC API. +- [facebook](https://github.com/huandu/facebook) - Go Library that supports the Facebook Graph API. +- [fasapay-sdk-go](https://github.com/Kachit/fasapay-sdk-go) - Unofficial Fasapay payment gateway XML API Client for Golang. +- [fcm](https://github.com/maddevsio/fcm) - Go library for Firebase Cloud Messaging. +- [gads](https://github.com/emiddleton/gads) - Google Adwords Unofficial API. +- [gami](https://github.com/bit4bit/gami) - Go library for Asterisk Manager Interface. +- [gcm](https://github.com/Aorioli/gcm) - Go library for Google Cloud Messaging. +- [geo-golang](https://github.com/codingsince1985/geo-golang) - Go Library to access [Google Maps](https://developers.google.com/maps/documentation/geocoding/intro), [MapQuest](https://developer.mapquest.com/documentation/api/geocoding/), [Nominatim](https://nominatim.org/release-docs/latest/api/Overview/), [OpenCage](https://opencagedata.com/api), [Bing](https://msdn.microsoft.com/en-us/library/ff701715.aspx), [Mapbox](https://www.mapbox.com/developers/api/geocoding/), and [OpenStreetMap](https://wiki.openstreetmap.org/wiki/Nominatim) geocoding / reverse geocoding APIs. +- [github](https://github.com/google/go-github) - Go library for accessing the GitHub REST API v3. +- [githubql](https://github.com/shurcooL/githubql) - Go library for accessing the GitHub GraphQL API v4. +- [go-atlassian](https://github.com/ctreminiom/go-atlassian) - Go library for accessing the [Atlassian Cloud](https://www.atlassian.com/enterprise/cloud) services (Jira, Jira Service Management, Jira Agile, Confluence, Admin Cloud) +- [go-aws-news](https://github.com/circa10a/go-aws-news) - Go application and library to fetch what's new from AWS. +- [go-chronos](https://github.com/axelspringer/go-chronos) - Go library for interacting with the [Chronos](https://mesos.github.io/chronos/) Job Scheduler +- [go-hacknews](https://github.com/PaulRosset/go-hacknews) - Tiny Go client for HackerNews API. +- [go-here](https://github.com/abdullahselek/go-here) - Go client library around the HERE location based APIs. +- [go-hibp](https://github.com/wneessen/go-hibp) - Simple Go binding to the "Have I Been Pwned" APIs. +- [go-imgur](https://github.com/koffeinsource/go-imgur) - Go client library for [imgur](https://imgur.com) +- [go-jira](https://github.com/andygrunwald/go-jira) - Go client library for [Atlassian JIRA](https://www.atlassian.com/software/jira) +- [go-lark](https://github.com/go-lark/lark) - An easy-to-use unofficial SDK for [Feishu](https://open.feishu.cn/) and [Lark](https://open.larksuite.com/) Open Platform. +- [go-marathon](https://github.com/gambol99/go-marathon) - Go library for interacting with Mesosphere's Marathon PAAS. +- [go-myanimelist](https://github.com/nstratos/go-myanimelist) - Go client library for accessing the [MyAnimeList API](https://myanimelist.net/apiconfig/references/api/v2). +- [go-openai](https://github.com/sashabaranov/go-openai) - OpenAI ChatGPT, DALL·E, Whisper API library for Go. +- [go-openproject](https://github.com/manuelbcd/go-openproject) - Go client library for interacting with [OpenProject](https://docs.openproject.org/api/) API. +- [go-postman-collection](https://github.com/rbretecher/go-postman-collection) - Go module to work with [Postman Collections](https://learning.getpostman.com/docs/postman/collections/creating-collections/) (compatible with Insomnia). +- [go-redoc](https://github.com/mvrilo/go-redoc) - Embedded OpenAPI/Swagger documentation ui for Go using [ReDoc](https://redocly.com/). +- [go-restcountries](https://github.com/chriscross0/go-restcountries) - Go library for the [REST Countries API](https://countrylayer.com/). +- [go-salesforce](https://github.com/k-capehart/go-salesforce) - Go client library for interacting with the [Salesforce REST API](https://developer.salesforce.com/docs/atlas.en-us.api_rest.meta/api_rest/resources_list.htm). +- [go-sophos](https://github.com/esurdam/go-sophos) - Go client library for the [Sophos UTM REST API](https://www.sophos.com/en-us/medialibrary/PDFs/documentation/UTMonAWS/Sophos-UTM-RESTful-API.pdf?la=en) with zero dependencies. +- [go-swagger-ui](https://github.com/esurdam/go-swagger-ui) - Go library containing precompiled [Swagger UI](https://swagger.io/tools/swagger-ui/) for serving swagger json. +- [go-telegraph](https://gitlab.com/toby3d/telegraph) - Telegraph publishing platform API client. +- [go-trending](https://github.com/andygrunwald/go-trending) - Go library for accessing [trending repositories](https://github.com/trending) and [developers](https://github.com/trending/developers) at Github. +- [go-twitter](https://github.com/dghubble/go-twitter) - Go client library for the Twitter v1.1 APIs. +- [go-unsplash](https://github.com/hbagdi/go-unsplash) - Go client library for the [Unsplash.com](https://unsplash.com) API. +- [go-xkcd](https://github.com/nishanths/go-xkcd) - Go client for the xkcd API. +- [go-yapla](https://gitlab.com/adrienK/go-yapla) - Go client library for the Yapla v2.0 API. +- [goagi](https://github.com/staskobzar/goagi) - Go library to build Asterisk PBX agi/fastagi applications. +- [goami2](https://github.com/staskobzar/goami2) - AMI v2 library for Asterisk PBX. +- [GoFreeDB](https://github.com/FreeLeh/GoFreeDB) - Golang library providing common and simple database abstractions on top of Google Sheets. +- [gogtrends](https://github.com/groovili/gogtrends) - Google Trends Unofficial API. +- [golang-tmdb](https://github.com/cyruzin/golang-tmdb) - Golang wrapper for The Movie Database API v3. +- [golyrics](https://github.com/mamal72/golyrics) - Golyrics is a Go library to fetch music lyrics data from the Wikia website. +- [gomalshare](https://github.com/MonaxGT/gomalshare) - Go library MalShare API [malshare.com](https://www.malshare.com/) +- [GoMusicBrainz](https://github.com/michiwend/gomusicbrainz) - Go MusicBrainz WS2 client library. +- [google](https://github.com/google/google-api-go-client) - Auto-generated Google APIs for Go. +- [google-analytics](https://github.com/chonthu/go-google-analytics) - Simple wrapper for easy google analytics reporting. +- [google-cloud](https://github.com/GoogleCloudPlatform/gcloud-golang) - Google Cloud APIs Go Client Library. +- [google-email-audit-api](https://github.com/ngs/go-google-email-audit-api) - Go client library for [Google G Suite Email Audit API](https://developers.google.com/admin-sdk/email-audit/). +- [google-play-scraper](https://github.com/n0madic/google-play-scraper) - Get data from Google Play Store. +- [gopaapi5](https://github.com/utekaravinash/gopaapi5) - Go Client Library for [Amazon Product Advertising API 5.0](https://webservices.amazon.com/paapi5/documentation/). +- [gopensky](https://github.com/navidys/gopensky) - Go client implementation for [OpenSKY Network](https://opensky-network.org/) live's API (airspace ADS-B and Mode S data). +- [gosip](https://github.com/koltyakov/gosip) - Client library for SharePoint. +- [gostorm](https://github.com/jsgilmore/gostorm) - GoStorm is a Go library that implements the communications protocol required to write Storm spouts and Bolts in Go that communicate with the Storm shells. +- [hipchat](https://github.com/andybons/hipchat) - This project implements a golang client library for the Hipchat API. +- [hipchat (xmpp)](https://github.com/daneharrigan/hipchat) - A golang package to communicate with HipChat over XMPP. +- [igdb](https://github.com/Henry-Sarabia/igdb) - Go client for the [Internet Game Database API](https://api.igdb.com/). +- [ip2location-io-go](https://github.com/ip2location/ip2location-io-go) - Go wrapper for the IP2Location.io API [IP2Location.io](https://www.ip2location.io/). +- [jokeapi-go](https://github.com/icelain/jokeapi) - Go client for [JokeAPI](https://sv443.net/jokeapi/v2/). +- [lark](https://github.com/chyroc/lark) - [Feishu](https://open.feishu.cn/)/[Lark](https://open.larksuite.com/) Open API Go SDK, Support ALL Open API and Event Callback. +- [lastpass-go](https://github.com/ansd/lastpass-go) - Go client library for the [LastPass](https://www.lastpass.com/) API. +- [libgoffi](https://github.com/clevabit/libgoffi) - Library adapter toolbox for native [libffi](https://sourceware.org/libffi/) integration +- [Medium](https://github.com/Medium/medium-sdk-go) - Golang SDK for Medium's OAuth2 API. +- [megos](https://github.com/andygrunwald/megos) - Client library for accessing an [Apache Mesos](https://mesos.apache.org/) cluster. +- [minio-go](https://github.com/minio/minio-go) - Minio Go Library for Amazon S3 compatible cloud storage. +- [mixpanel](https://github.com/dukex/mixpanel) - Mixpanel is a library for tracking events and sending Mixpanel profile updates to Mixpanel from your go applications. +- [newsapi-go](https://github.com/jellydator/newsapi-go) - Go client for [NewsAPI](https://newsapi.org/). +- [openaigo](https://github.com/otiai10/openaigo) - OpenAI GPT3/GPT3.5 ChatGPT API client library for Go. +- [patreon-go](https://github.com/mxpv/patreon-go) - Go library for Patreon API. +- [paypal](https://github.com/logpacker/PayPal-Go-SDK) - Wrapper for PayPal payment API. +- [playlyfe](https://github.com/playlyfe/playlyfe-go-sdk) - The Playlyfe Rest API Go SDK. +- [pushover](https://github.com/gregdel/pushover) - Go wrapper for the Pushover API. +- [rawg-sdk-go](https://github.com/dimuska139/rawg-sdk-go) - Go library for the [RAWG Video Games Database](https://rawg.io/) API +- [rrdaclient](https://github.com/Omie/rrdaclient) - Go Library to access statdns.com API, which is in turn RRDA API. DNS Queries over HTTP. +- [shopify](https://github.com/rapito/go-shopify) - Go Library to make CRUD request to the Shopify API. +- [simples3](https://github.com/rhnvrm/simples3) - Simple no frills AWS S3 Library using REST with V4 Signing written in Go. +- [slack](https://github.com/slack-go/slack) - Slack API in Go. +- [smite](https://github.com/sergiotapia/smitego) - Go package to wraps access to the Smite game API. +- [spotify](https://github.com/rapito/go-spotify) - Go Library to access Spotify WEB API. +- [steam](https://github.com/sostronk/go-steam) - Go Library to interact with Steam game servers. +- [stripe](https://github.com/stripe/stripe-go) - Go client for the Stripe API. +- [swag](https://github.com/zc2638/swag) - No comments, simple go wrapper to create swagger 2.0 compatible APIs. Support most routing frameworks, such as built-in, gin, chi, mux, echo, httprouter, fasthttp and more. +- [textbelt](https://github.com/dietsche/textbelt) - Go client for the textbelt.com txt messaging API. +- [translate](https://github.com/poorny/translate) - Go online translation package. +- [Trello](https://github.com/adlio/trello) - Go wrapper for the Trello API. +- [TripAdvisor](https://github.com/mrbenosborne/tripadvisor-golang) - Go wrapper for the TripAdvisor API. +- [tumblr](https://github.com/mattcunningham/gumblr) - Go wrapper for the Tumblr v2 API. +- [twitter-scraper](https://github.com/n0madic/twitter-scraper) - Scrape the Twitter Frontend API without authentication and limits. +- [uptimerobot](https://github.com/bitfield/uptimerobot) - Go wrapper and command-line client for the Uptime Robot v2 API. +- [vl-go](https://github.com/verifid/vl-go) - Go client library around the VerifID identity verification layer API. +- [webhooks](https://github.com/go-playground/webhooks) - Webhook receiver for GitHub and Bitbucket. +- [wit-go](https://github.com/wit-ai/wit-go) - Go client for wit.ai HTTP API. +- [ynab](https://github.com/brunomvsouza/ynab.go) - Go wrapper for the YNAB API. +- [zooz](https://github.com/gojuno/go-zooz) - Go client for the Zooz API. + +**[⬆ back to top](#contents)** ## Utilities -*General utilities and tools to make your life easier.* - -* [coop](https://github.com/rakyll/coop) - Cheat sheet for some of the common concurrent flows in Go. -* [delve](https://github.com/derekparker/delve) - Go debugger. -* [fastlz](https://github.com/fromYukki/fastlz) - Wrap over [FastLz](http://fastlz.org/) (free, open-source, portable real-time compression library) for GoLang. -* [go-debug](https://github.com/visionmedia/go-debug) - Conditional debug logging for Golang libraries & applications -* [go-dry](https://github.com/ungerik/go-dry) - DRY (don't repeat yourself) package for Go. -* [go-underscore](https://github.com/tobyhede/go-underscore) - A useful collection of helpfully functional Go collection utilities. -* [goback](https://github.com/carlescere/goback) - Go simple exponential backoff package. -* [godropbox](https://github.com/dropbox/godropbox) - Common libraries for writing Go services/applications from Dropbox. -* [gopencils](https://github.com/bndr/gopencils) - Small and simple package to easily consume REST APIs. -* [goplaceholder](https://github.com/michiwend/goplaceholder) - a small golang lib to generate placeholder images -* [goreq](https://github.com/franela/goreq) - Minimal and simple request library for Go language. -* [gorequest](https://github.com/parnurzeal/gorequest) - Simplified HTTP client with rich features for Go. -* [gotenv](https://github.com/subosito/gotenv) - Load environment variables from `.env` or any `io.Reader` in Go -* [lrserver](https://github.com/jaschaephraim/lrserver) - LiveReload server for Go -* [mp](https://github.com/sanbornm/mp) - A simple cli email parser. It currently takes stdin and outputs JSON. -* [netbug](https://github.com/e-dard/netbug) - Easy remote profiling of your services. -* [ngrok](https://github.com/inconshreveable/ngrok) - Introspected tunnels to localhost. -* [okrun](https://github.com/xta/okrun) - go run error steamroller -* [peco](https://github.com/peco/peco) - Simplistic interactive filtering tool -* [profile](https://github.com/davecheney/profile) - Simple profiling support package for Go -* [request](https://github.com/mozillazg/request) - Go HTTP Requests for Humans™. -* [scheduler](https://github.com/carlescere/scheduler) - Cronjobs scheduling made easy. -* [spinner](https://github.com/briandowns/spinner) - Go package to easily provide a terminal spinner with options. -* [sqlx](https://github.com/jmoiron/sqlx) - provides a set of extensions on top of the excellent built-in database/sql package -* [xlsx](https://github.com/tealeg/xlsx) - Library to simplify reading the XML format used by recent version of Microsoft Excel in Go programs. - +_General utilities and tools to make your life easier._ + +- [apm](https://github.com/topfreegames/apm) - Process manager for Golang applications with an HTTP API. +- [backscanner](https://github.com/icza/backscanner) - A scanner similar to bufio.Scanner, but it reads and returns lines in reverse order, starting at a given position and going backward. +- [blank](https://github.com/Henry-Sarabia/blank) - Verify or remove blanks and whitespace from strings. +- [bleep](https://github.com/sinhashubham95/bleep) - Perform any number of actions on any set of OS signals in Go. +- [boilr](https://github.com/tmrts/boilr) - Blazingly fast CLI tool for creating projects from boilerplate templates. +- [changie](https://github.com/miniscruff/changie) - Automated changelog tool for preparing releases with lots of customization options. +- [chyle](https://github.com/antham/chyle) - Changelog generator using a git repository with multiple configuration possibilities. +- [circuit](https://github.com/cep21/circuit) - An efficient and feature complete Hystrix like Go implementation of the circuit breaker pattern. +- [circuitbreaker](https://github.com/rubyist/circuitbreaker) - Circuit Breakers in Go. +- [clipboard](https://github.com/golang-design/clipboard) - 📋 cross-platform clipboard package in Go. +- [clockwork](https://github.com/jonboulle/clockwork) - A simple fake clock for golang. +- [cmd](https://github.com/SimonBaeumer/cmd) - Library for executing shell commands on osx, windows and linux. +- [command](https://github.com/txgruppi/command) - Command pattern for Go with thread safe serial and parallel dispatcher. +- [config-file-validator](https://github.com/Boeing/config-file-validator) - Cross Platform tool to validate configuration files. +- [contextplus](https://github.com/contextplus/contextplus) - Package contextplus provide more easy to use functions for contexts. +- [cookie](https://github.com/syntaqx/cookie) - Cookie struct parsing and helper package. +- [copy-pasta](https://github.com/jutkko/copy-pasta) - Universal multi-workstation clipboard that uses S3 like backend for the storage. +- [countries](https://github.com/biter777/countries) - Full implementation of ISO-3166-1, ISO-4217, ITU-T E.164, Unicode CLDR and IANA ccTLD standards. +- [countries](https://github.com/pioz/countries) - All you need when you are working with countries in Go. +- [create-go-app](https://github.com/create-go-app/cli) - A powerful CLI for create a new production-ready project with backend (Golang), frontend (JavaScript, TypeScript) & deploy automation (Ansible, Docker) by running one command. +- [cryptgo](https://github.com/Gituser143/cryptgo) - Crytpgo is a TUI based application written purely in Go to monitor and observe cryptocurrency prices in real time! +- [ctop](https://github.com/bcicen/ctop) - [Top-like](https://ctop.sh) interface (e.g. htop) for container metrics. +- [ctxutil](https://github.com/posener/ctxutil) - A collection of utility functions for contexts. +- [cvt](https://github.com/shockerli/cvt) - Easy and safe convert any value to another type. +- [dbt](https://github.com/nikogura/dbt) - A framework for running self-updating signed binaries from a central, trusted repository. +- [Death](https://github.com/vrecan/death) - Managing go application shutdown with signals. +- [delve](https://github.com/derekparker/delve) - Go debugger. +- [dive](https://github.com/wagoodman/dive) - A tool for exploring each layer in a Docker image. +- [dlog](https://github.com/kirillDanshin/dlog) - Compile-time controlled logger to make your release smaller without removing debug calls. +- [EaseProbe](https://github.com/megaease/easeprobe) - A simple, standalone, and lightWeight tool that can do health/status checking daemon, support HTTP/TCP/SSH/Shell/Client/... probes, and Slack/Discord/Telegram/SMS... notification. +- [equalizer](https://github.com/reugn/equalizer) - Quota manager and rate limiter collection for Go. +- [ergo](https://github.com/cristianoliveira/ergo) - The management of multiple local services running over different ports made easy. +- [evaluator](https://github.com/nullne/evaluator) - Evaluate an expression dynamically based on s-expression. It's simple and easy to extend. +- [Failsafe-go](https://github.com/failsafe-go/failsafe-go) - Fault tolerance and resilience patterns for Go. +- [filetype](https://github.com/h2non/filetype) - Small package to infer the file type checking the magic numbers signature. +- [filler](https://github.com/yaronsumel/filler) - small utility to fill structs using "fill" tag. +- [filter](https://github.com/gookit/filter) - provide filtering, sanitizing, and conversion of Go data. +- [fzf](https://github.com/junegunn/fzf) - Command-line fuzzy finder written in Go. +- [generate](https://github.com/go-playground/generate) - runs go generate recursively on a specified path or environment variable and can filter by regex. +- [ghokin](https://github.com/antham/ghokin) - Parallelized formatter with no external dependencies for gherkin (cucumber, behat...). +- [git-time-metric](https://github.com/git-time-metric/gtm) - Simple, seamless, lightweight time tracking for Git. +- [gitbatch](https://github.com/isacikgoz/gitbatch) - manage your git repositories in one place. +- [gitcs](https://github.com/knbr13/gitcs/) - Git Commits Visualizer, CLI tool to visualize your Git commits on your local machine. +- [go-actuator](https://github.com/sinhashubham95/go-actuator) - Production ready features for Go based web frameworks. +- [go-astitodo](https://github.com/asticode/go-astitodo) - Parse TODOs in your GO code. +- [go-bind-plugin](https://github.com/wendigo/go-bind-plugin) - go:generate tool for wrapping symbols exported by golang plugins (1.8 only). +- [go-bsdiff](https://github.com/gabstv/go-bsdiff) - Pure Go bsdiff and bspatch libraries and CLI tools. +- [go-clip](https://github.com/prashantgupta24/go-clip) - A minimalistic clipboard manager for Mac. +- [go-convert](https://github.com/Eun/go-convert) - Package go-convert enables you to convert a value into another type. +- [go-countries](https://github.com/mikekonan/go-countries) - Lightweight lookup over ISO-3166 codes. +- [go-dry](https://github.com/ungerik/go-dry) - DRY (don't repeat yourself) package for Go. +- [go-funk](https://github.com/thoas/go-funk) - Modern Go utility library which provides helpers (map, find, contains, filter, chunk, reverse, ...). +- [go-health](https://github.com/Talento90/go-health) - Health package simplifies the way you add health check to your services. +- [go-httpheader](https://github.com/mozillazg/go-httpheader) - Go library for encoding structs into Header fields. +- [go-lambda-cleanup](https://github.com/karl-cardenas-coding/go-lambda-cleanup) - A CLI for removing unused or previous versions of AWS Lambdas. +- [go-lock](https://github.com/viney-shih/go-lock) - go-lock is a lock library implementing read-write mutex and read-write trylock without starvation. +- [go-pattern-match](https://github.com/PhakornKiong/go-pattern-match) - A Pattern matching library inspired by ts-pattern. +- [go-pkg](https://github.com/chenquan/go-pkg) - A go toolkit. +- [go-problemdetails](https://github.com/mvmaasakkers/go-problemdetails) - Go package for working with Problem Details. +- [go-qr](https://github.com/piglig/go-qr) - A native, high-quality and minimalistic QR code generator. +- [go-rate](https://github.com/beefsack/go-rate) - Timed rate limiter for Go. +- [go-sitemap-generator](https://github.com/ikeikeikeike/go-sitemap-generator) - XML Sitemap generator written in Go. +- [go-trigger](https://github.com/sadlil/go-trigger) - Go-lang global event triggerer, Register Events with an id and trigger the event from anywhere from your project. +- [go-type](https://github.com/mikekonan/go-types) - Library providing Go types for store/validation and transfer of ISO-4217, ISO-3166, and other types. +- [goback](https://github.com/carlescere/goback) - Go simple exponential backoff package. +- [goctx](https://github.com/zerosnake0/goctx) - Get your context value with high performance. +- [godaemon](https://github.com/VividCortex/godaemon) - Utility to write daemons. +- [godropbox](https://github.com/dropbox/godropbox) - Common libraries for writing Go services/applications from Dropbox. +- [gofn](https://github.com/tiendc/gofn) - High performance utility functions written using Generics for Go 1.18+. +- [gohper](https://github.com/cosiner/gohper) - Various tools/modules help for development. +- [golarm](https://github.com/msempere/golarm) - Fire alarms with system events. +- [golog](https://github.com/mlimaloureiro/golog) - Easy and lightweight CLI tool to time track your tasks. +- [gopencils](https://github.com/bndr/gopencils) - Small and simple package to easily consume REST APIs. +- [goplaceholder](https://github.com/michiwend/goplaceholder) - a small golang lib to generate placeholder images. +- [goreadability](https://github.com/philipjkim/goreadability) - Webpage summary extractor using Facebook Open Graph and arc90's readability. +- [goreleaser](https://github.com/goreleaser/goreleaser) - Deliver Go binaries as fast and easily as possible. +- [goreporter](https://github.com/wgliang/goreporter) - Golang tool that does static analysis, unit testing, code review and generate code quality report. +- [goseaweedfs](https://github.com/linxGnu/goseaweedfs) - SeaweedFS client library with almost full features. +- [gostrutils](https://github.com/ik5/gostrutils) - Collections of string manipulation and conversion functions. +- [gotenv](https://github.com/subosito/gotenv) - Load environment variables from `.env` or any `io.Reader` in Go. +- [goval](https://github.com/maja42/goval) - Evaluate arbitrary expressions in Go. +- [graterm](https://github.com/skovtunenko/graterm) - Provides primitives to perform ordered (sequential/concurrent) GRAceful TERMination (aka shutdown) in Go application. +- [grofer](https://github.com/pesos/grofer) - A system and resource monitoring tool written in Golang! +- [gubrak](https://github.com/novalagung/gubrak) - Golang utility library with syntactic sugar. It's like lodash, but for golang. +- [handy](https://github.com/miguelpragier/handy) - Many utilities and helpers like string handlers/formatters and validators. +- [hostctl](https://github.com/guumaster/hostctl) - A CLI tool to manage /etc/hosts with easy commands. +- [htcat](https://github.com/htcat/htcat) - Parallel and Pipelined HTTP GET Utility. +- [hub](https://github.com/github/hub) - wrap git commands with additional functionality to interact with github from the terminal. +- [hystrix-go](https://github.com/afex/hystrix-go) - Implements Hystrix patterns of programmer-defined fallbacks aka circuit breaker. +- [immortal](https://github.com/immortal/immortal) - \*nix cross-platform (OS agnostic) supervisor. +- [intrinsic](https://github.com/mengzhuo/intrinsic) - Use x86 SIMD without writing any assembly code. +- [jsend](https://github.com/clevergo/jsend) - JSend's implementation written in Go. +- [json-log-viewer](https://github.com/hedhyw/json-log-viewer) - Interactive viewer for JSON logs. +- [jump](https://github.com/gsamokovarov/jump) - Jump helps you navigate faster by learning your habits. +- [just](https://github.com/kazhuravlev/just) - Just a collection of useful functions for working with generic data structures. +- [koazee](https://github.com/wesovilabs/koazee) - Library inspired in Lazy evaluation and functional programming that takes the hassle out of working with arrays. +- [lancet](https://github.com/duke-git/lancet) - A comprehensive, efficient, and reusable util function library of go. +- [lets-go](https://github.com/aplescia-chwy/lets-go) - Go module that provides common utilities for Cloud Native REST API development. Also contains AWS Specific utilities. +- [limiters](https://github.com/mennanov/limiters) - Rate limiters for distributed applications in Golang with configurable back-ends and distributed locks. +- [lo](https://github.com/samber/lo) - A Lodash like Go library based on Go 1.18+ Generics (map, filter, contains, find...) +- [loncha](https://github.com/kazu/loncha) - A high-performance slice Utilities. +- [lrserver](https://github.com/jaschaephraim/lrserver) - LiveReload server for Go. +- [mani](https://github.com/alajmo/mani) - CLI tool to help you manage multiple repositories. +- [mc](https://github.com/minio/mc) - Minio Client provides minimal tools to work with Amazon S3 compatible cloud storage and filesystems. +- [mergo](https://github.com/imdario/mergo) - Helper to merge structs and maps in Golang. Useful for configuration default values, avoiding messy if-statements. +- [mimemagic](https://github.com/zRedShift/mimemagic) - Pure Go ultra performant MIME sniffing library/utility. +- [mimesniffer](https://github.com/aofei/mimesniffer) - A MIME type sniffer for Go. +- [mimetype](https://github.com/gabriel-vasile/mimetype) - Package for MIME type detection based on magic numbers. +- [minify](https://github.com/tdewolff/minify) - Fast minifiers for HTML, CSS, JS, XML, JSON and SVG file formats. +- [minquery](https://github.com/icza/minquery) - MongoDB / mgo.v2 query that supports efficient pagination (cursors to continue listing documents where we left off). +- [moldova](https://github.com/StabbyCutyou/moldova) - Utility for generating random data based on an input template. +- [mole](https://github.com/davrodpin/mole) - cli app to easily create ssh tunnels. +- [mongo-go-pagination](https://github.com/gobeam/mongo-go-pagination) - Mongodb Pagination for official mongodb/mongo-go-driver package which supports both normal queries and Aggregation pipelines. +- [mssqlx](https://github.com/linxGnu/mssqlx) - Database client library, proxy for any master slave, master master structures. Lightweight and auto balancing in mind. +- [multitick](https://github.com/VividCortex/multitick) - Multiplexor for aligned tickers. +- [myhttp](https://github.com/inancgumus/myhttp) - Simple API to make HTTP GET requests with timeout support. +- [netbug](https://github.com/e-dard/netbug) - Easy remote profiling of your services. +- [nfdump](https://github.com/chrispassas/nfdump) - Read nfdump netflow files. +- [nostromo](https://github.com/pokanop/nostromo) - CLI for building powerful aliases. +- [okrun](https://github.com/xta/okrun) - go run error steamroller. +- [olaf](https://github.com/btnguyen2k/olaf) - Twitter Snowflake implemented in Go. +- [onecache](https://github.com/adelowo/onecache) - Caching library with support for multiple backend stores (Redis, Memcached, filesystem etc). +- [panicparse](https://github.com/maruel/panicparse) - Groups similar goroutines and colorizes stack dump. +- [pattern-match](https://github.com/alexpantyukhin/go-pattern-match) - Pattern matching library. +- [peco](https://github.com/peco/peco) - Simplistic interactive filtering tool. +- [pgo](https://github.com/arthurkushman/pgo) - Convenient functions for PHP community. +- [pm](https://github.com/VividCortex/pm) - Process (i.e. goroutine) manager with an HTTP API. +- [pointer](https://github.com/xorcare/pointer) - Package pointer contains helper routines for simplifying the creation of optional fields of basic type. +- [ptr](https://github.com/gotidy/ptr) - Package that provide functions for simplified creation of pointers from constants of basic types. +- [rclient](https://github.com/zpatrick/rclient) - Readable, flexible, simple-to-use client for REST APIs. +- [remote-touchpad](https://github.com/Unrud/remote-touchpad) - Control mouse and keyboard from a smartphone. +- [repeat](https://github.com/ssgreg/repeat) - Go implementation of different backoff strategies useful for retrying operations and heartbeating. +- [request](https://github.com/mozillazg/request) - Go HTTP Requests for Humans™. +- [rerun](https://github.com/ivpusic/rerun) - Recompiling and rerunning go apps when source changes. +- [rest-go](https://github.com/edermanoel94/rest-go) - A package that provide many helpful methods for working with rest api. +- [retry](https://github.com/kamilsk/retry) - The most advanced functional mechanism to perform actions repetitively until successful. +- [retry](https://github.com/percolate/retry) - A simple but highly configurable retry package for Go. +- [retry](https://github.com/thedevsaddam/retry) - Simple and easy retry mechanism package for Go. +- [retry](https://github.com/shafreeck/retry) - A pretty simple library to ensure your work to be done. +- [retry-go](https://github.com/avast/retry-go) - Simple library for retry mechanism. +- [retry-go](https://github.com/rafaeljesus/retry-go) - Retrying made simple and easy for golang. +- [robustly](https://github.com/VividCortex/robustly) - Runs functions resiliently, catching and restarting panics. +- [rospo](https://github.com/ferama/rospo) - Simple and reliable ssh tunnels with embedded ssh server in Golang. +- [scan](https://github.com/blockloop/scan) - Scan golang `sql.Rows` directly to structs, slices, or primitive types. +- [scan](https://github.com/wroge/scan) - Scan sql rows into any type powered by generics. +- [scany](https://github.com/georgysavva/scany) - Library for scanning data from a database into Go structs and more. +- [serve](https://github.com/syntaqx/serve) - A static http server anywhere you need. +- [set](https://github.com/nofeaturesonlybugs/set) - Performant and flexible struct mapping and loose type conversion. +- [shutdown](https://github.com/ztrue/shutdown) - App shutdown hooks for `os.Signal` handling. +- [silk](https://github.com/chrispassas/silk) - Read silk netflow files. +- [slice](https://github.com/psampaz/slice) - Type-safe functions for common Go slice operations. +- [sliceconv](https://github.com/Henry-Sarabia/sliceconv) - Slice conversion between primitive types. +- [slicer](https://github.com/leaanthony/slicer) - Makes working with slices easier. +- [sorty](https://github.com/jfcg/sorty) - Fast Concurrent / Parallel Sorting. +- [sqlx](https://github.com/jmoiron/sqlx) - provides a set of extensions on top of the excellent built-in database/sql package. +- [sshman](https://github.com/shoobyban/sshman) - SSH Manager for authorized_keys files on multiple remote servers. +- [statiks](https://github.com/janiltonmaciel/statiks) - Fast, zero-configuration, static HTTP filer server. +- [Storm](https://github.com/asdine/storm) - Simple and powerful toolkit for BoltDB. +- [structs](https://github.com/PumpkinSeed/structs) - Implement simple functions to manipulate structs. +- [throttle](https://github.com/yudppp/throttle) - Throttle is an object that will perform exactly one action per duration. +- [tik](https://github.com/andy2046/tik) - Simple and easy timing wheel package for Go. +- [tome](https://github.com/cyruzin/tome) - Tome was designed to paginate simple RESTful APIs. +- [toolbox](https://github.com/viant/toolbox) - Slice, map, multimap, struct, function, data conversion utilities. Service router, macro evaluator, tokenizer. +- [ugo](https://github.com/alxrm/ugo) - ugo is slice toolbox with concise syntax for Go. +- [UNIS](https://github.com/esemplastic/unis) - Common Architecture™ for String Utilities in Go. +- [upterm](https://github.com/owenthereal/upterm) - A tool for developers to share terminal/tmux sessions securely over the web. It’s perfect for remote pair programming, accessing computers behind NATs/firewalls, remote debugging, and more. +- [usql](https://github.com/knq/usql) - usql is a universal command-line interface for SQL databases. +- [util](https://github.com/shomali11/util) - Collection of useful utility functions. (strings, concurrency, manipulations, ...). +- [watchhttp](https://github.com/nikolaydubina/watchhttp) - Run command periodically and expose latest STDOUT or its rich delta as HTTP endpoint. +- [wifiqr](https://github.com/reugn/wifiqr) - Wi-Fi QR Code Generator. +- [wuzz](https://github.com/asciimoo/wuzz) - Interactive cli tool for HTTP inspection. +- [xferspdy](https://github.com/monmohan/xferspdy) - Xferspdy provides binary diff and patch library in golang. +- [yogo](https://github.com/antham/yogo) - Check yopmail mails from command line. + +**[⬆ back to top](#contents)** + +## UUID + +_Libraries for working with UUIDs._ + +- [fastuuid](https://github.com/rekby/fastuuid) - Fast generate UUIDv4 as string or bytes. +- [goid](https://github.com/jakehl/goid) - Generate and Parse RFC4122 compliant V4 UUIDs. +- [gouid](https://github.com/twharmon/gouid) - Generate cryptographically secure random string IDs with just one allocation. +- [nanoid](https://github.com/aidarkhanov/nanoid) - A tiny and efficient Go unique string ID generator. +- [sno](https://github.com/muyo/sno) - Compact, sortable and fast unique IDs with embedded metadata. +- [ulid](https://github.com/oklog/ulid) - Go implementation of ULID (Universally Unique Lexicographically Sortable Identifier). +- [uniq](https://gitlab.com/skilstak/code/go/uniq) - No hassle safe, fast unique identifiers with commands. +- [uuid](https://github.com/agext/uuid) - Generate, encode, and decode UUIDs v1 with fast or cryptographic-quality random node identifier. +- [uuid](https://github.com/gofrs/uuid) - Implementation of Universally Unique Identifier (UUID). Supports both creation and parsing of UUIDs. Actively maintained fork of satori uuid. +- [uuid](https://github.com/google/uuid) - Go package for UUIDs based on RFC 4122 and DCE 1.1: Authentication and Security Services. +- [wuid](https://github.com/edwingeng/wuid) - An extremely fast globally unique number generator. +- [xid](https://github.com/rs/xid) - Xid is a globally unique id generator library, ready to be safely used directly in your server code. + +**[⬆ back to top](#contents)** ## Validation -*Libraries for validation.* - -* [validator](https://github.com/bluesuncorp/validator) - Go Struct and Field validation supporting Cross Field and Cross Struct validation - +_Libraries for validation._ + +- [checkdigit](https://github.com/osamingo/checkdigit) - Provide check digit algorithms (Luhn, Verhoeff, Damm) and calculators (ISBN, EAN, JAN, UPC, etc.). +- [go-validator](https://github.com/tiendc/go-validator) - Validation library using Generics. +- [gody](https://github.com/guiferpa/gody) - :balloon: A lightweight struct validator for Go. +- [govalid](https://github.com/twharmon/govalid) - Fast, tag-based validation for structs. +- [govalidator](https://github.com/asaskevich/govalidator) - Validators and sanitizers for strings, numerics, slices and structs. +- [govalidator](https://github.com/thedevsaddam/govalidator) - Validate Golang request data with simple rules. Highly inspired by Laravel's request validation. +- [hvalid](https://github.com/lyonnee/hvalid) hvalid is a lightweight validation library written in Go language. It provides a custom validator interface and a series of common validation functions to help developers quickly implement data validation. +- [jio](https://github.com/faceair/jio) - jio is a json schema validator similar to [joi](https://github.com/hapijs/joi). +- [ozzo-validation](https://github.com/go-ozzo/ozzo-validation) - Supports validation of various data types (structs, strings, maps, slices, etc.) with configurable and extensible validation rules specified in usual code constructs instead of struct tags. +- [validate](https://github.com/gookit/validate) - Go package for data validation and filtering. support validate Map, Struct, Request(Form, JSON, url.Values, Uploaded Files) data and more features. +- [validate](https://github.com/gobuffalo/validate) - This package provides a framework for writing validations for Go applications. +- [validator](https://github.com/go-playground/validator) - Go Struct and Field validation, including Cross Field, Cross Struct, Map, Slice and Array diving. +- [Validator](https://github.com/go-the-way/validator) - A lightweight model validator written in Go.Contains VFs:Min, Max, MinLength, MaxLength, Length, Enum, Regex. +- [valix](https://github.com/marrow16/valix) Go package for validating requests + +**[⬆ back to top](#contents)** ## Version Control -*Libraries for version control.* +_Libraries for version control._ -* [gh](https://github.com/rjeczalik/gh) - Scriptable server and net/http middleware for GitHub Webhooks -* [git2go](https://github.com/libgit2/git2go) - Go bindings for libgit2. -* [go-vcs](https://github.com/sourcegraph/go-vcs) - manipulate and inspect VCS repositories in Go. -* [hgo](https://github.com/beyang/hgo) - Hgo is a collection of Go packages providing read-access to local Mercurial repositories. +- [cli](https://gitlab.com/gitlab-org/cli) - An open-source GitLab command line tool bringing GitLab's cool features to your command line. +- [froggit-go](https://github.com/jfrog/froggit-go) - Froggit-Go is a Go library, allowing to perform actions on VCS providers. +- [gh](https://github.com/rjeczalik/gh) - Scriptable server and net/http middleware for GitHub Webhooks. +- [git2go](https://github.com/libgit2/git2go) - Go bindings for libgit2. +- [githooks](https://github.com/gabyx/githooks) - Per-repo and shared Git hooks with version control and auto update. +- [go-git](https://github.com/go-git/go-git) - highly extensible Git implementation in pure Go. +- [go-vcs](https://github.com/sourcegraph/go-vcs) - manipulate and inspect VCS repositories in Go. +- [hercules](https://github.com/src-d/hercules) - gaining advanced insights from Git repository history. +- [hgo](https://github.com/beyang/hgo) - Hgo is a collection of Go packages providing read-access to local Mercurial repositories. +**[⬆ back to top](#contents)** ## Video -*Libraries for manipulating video.* +_Libraries for manipulating video._ -* [aac/h264](https://github.com/go-av/codec) - Golang aac/h264 encoder and decoder. -* [gmf](https://github.com/3d0c/gmf) - Go bindings for FFmpeg av\* libraries. -* [gst](https://github.com/ziutek/gst) - Go bindings for GStreamer. +- [gmf](https://github.com/3d0c/gmf) - Go bindings for FFmpeg av\* libraries. +- [go-astiav](https://github.com/asticode/go-astiav) - Better C bindings for ffmpeg in GO. +- [go-astisub](https://github.com/asticode/go-astisub) - Manipulate subtitles in GO (.srt, .stl, .ttml, .webvtt, .ssa/.ass, teletext, .smi, etc.). +- [go-astits](https://github.com/asticode/go-astits) - Parse and demux MPEG Transport Streams (.ts) natively in GO. +- [go-m3u8](https://github.com/etherlabsio/go-m3u8) - Parser and generator library for Apple m3u8 playlists. Actively maintained version of quangngotan95/go-m3u8 with improvements and latest HLS playlist parsing compatibility. +- [go-mpd](https://github.com/unki2aut/go-mpd) - Parser and generator library for MPEG-DASH manifest files. +- [goav](https://github.com/giorgisio/goav) - Comprehensive Go bindings for FFmpeg. +- [gortsplib](https://github.com/aler9/gortsplib) - Pure Go RTSP server and client library. +- [gst](https://github.com/ziutek/gst) - Go bindings for GStreamer. +- [libgosubs](https://github.com/wargarblgarbl/libgosubs) - Subtitle format support for go. Supports .srt, .ttml, and .ass. +- [libvlc-go](https://github.com/adrg/libvlc-go) - Go bindings for libvlc 2.X/3.X/4.X (used by the VLC media player). +- [m3u8](https://github.com/grafov/m3u8) - Parser and generator library of M3U8 playlists for Apple HLS. +- [v4l](https://github.com/korandiz/v4l) - Video capture library for Linux, written in Go. +**[⬆ back to top](#contents)** ## Web Frameworks -*Full stack web frameworks.* - -* [Beego](https://github.com/astaxie/beego) - beego is an open-source, high-performance web framework for the Go programming language. -* [Bone](https://github.com/go-zoo/bone) - Lightning Fast HTTP Multiplexer. -* [Echo](https://github.com/labstack/echo) - A fast HTTP router (zero memory allocation) + micro web framework in Go. -* [Gin](https://github.com/gin-gonic/gin) - Gin is a web framework written in Go! It features a martini-like API with much better performance, up to 40 times faster. If you need performance and good productivity. -* [go-json-rest](https://github.com/ant0ine/go-json-rest) - A quick and easy way to setup a RESTful JSON API -* [go-relax](https://github.com/codehack/go-relax) - A framework of pluggable components to build RESTful API's -* [go-rest](https://github.com/ungerik/go-rest) - A small and evil REST framework for Go -* [Goat](https://github.com/bahlo/goat) - A minimalistic REST API server in Go -* [gocraft/web](https://github.com/gocraft/web) - A mux and middleware package in Go. -* [Goji](https://github.com/zenazn/goji) - Goji is a minimalistic web framework for Golang that's high in antioxidants. -* [Gondola](https://github.com/rainycape/gondola) - The web framework for writing faster sites, faster -* [goose](https://github.com/ian-kent/goose) - Server Sent Events in Go -* [Gorilla](https://github.com/gorilla/) - Gorilla is a web toolkit for the Go programming language. -* [httprouter](https://github.com/julienschmidt/httprouter) - A high performance router. Use this and the standard http handlers to form a very high performance web framework. -* [Macaron](https://github.com/Unknwon/macaron) - Macaron is a high productive and modular design web framework in Go. -* [mango](https://github.com/paulbellamy/mango) - Mango is a modular web-application framework for Go, inspired by Rack, and PEP333. -* [Martini](https://github.com/go-martini/martini) - Martini is a powerful package for quickly writing modular web applications/services in Golang. -* [medeina](https://github.com/imdario/medeina) - Medeina is a HTTP routing tree based on HttpRouter, inspired by Roda and Cuba. -* [neo](https://github.com/ivpusic/neo) - Neo is minimal and fast Go Web Framework with extremely simple API. -* [pat](https://github.com/bmizerany/pat) - Sinatra style pattern muxer for Go’s net/http library, by the author of Sinatra. -* [Resoursea](https://github.com/resoursea/api) - A REST framework for quickly writing resource based services. -* [Revel](https://github.com/revel/revel) - A high-productivity web framework for the Go language. -* [sawsij](http://sawsij.com/) - lightweight, open-source web framework for building high-performance, data-driven web applications. -* [tango](https://github.com/lunny/tango) - Micro & pluggable web framework for Go. -* [tigertonic](https://github.com/rcrowley/go-tigertonic) - A Go framework for building JSON web services inspired by Dropwizard -* [traffic](https://github.com/pilu/traffic) - Sinatra inspired regexp/pattern mux and web framework for Go. -* [web.go](https://github.com/hoisie/web) - A simple framework to write webapps in Go. -* [zeus](https://github.com/daryl/zeus) - A very simple and fast HTTP router for Go. - +_Full stack web frameworks._ + +- [aah](https://aahframework.org) - Scalable, performant, rapid development Web framework for Go. +- [Aero](https://github.com/aerogo/aero) - High-performance web framework for Go, reaches top scores in Lighthouse. +- [Air](https://github.com/aofei/air) - An ideally refined web framework for Go. +- [anoweb](https://github.com/go-the-way/anoweb) - The lightweight and powerful web framework using the new way for Go.Another go the way. +- [appy](https://github.com/appist/appy) - An opinionated productive web framework that helps scaling business easier. +- [Atreugo](https://github.com/savsgio/atreugo) - High performance and extensible micro web framework with zero memory allocations in hot paths. +- [Banjo](https://github.com/nsheremet/banjo) - Very simple and fast web framework for Go. +- [Beego](https://github.com/beego/beego) - beego is an open-source, high-performance web framework for the Go programming language. +- [Buffalo](https://gobuffalo.io) - Bringing the productivity of Rails to Go! +- [Confetti Framework](https://confetti-framework.github.io/docs/) - Confetti is a Go web application framework with an expressive, elegant syntax. Confetti combines the elegance of Laravel and the simplicity of Go. +- [Don](https://github.com/abemedia/go-don) - A highly performant and simple to use API framework. +- [Echo](https://github.com/labstack/echo) - High performance, minimalist Go web framework. +- [Fastschema](https://github.com/fastschema/fastschema) - A flexible Go web framework and Headless CMS. +- [Fiber](https://github.com/gofiber/fiber) - An Express.js inspired web framework build on Fasthttp. +- [Fireball](https://github.com/zpatrick/fireball) - More "natural" feeling web framework. +- [Flamingo](https://github.com/i-love-flamingo/flamingo) - Framework for pluggable web projects. Including a concept for modules and offering features for DI, Configareas, i18n, template engines, graphql, observability, security, events, routing & reverse routing etc. +- [Flamingo Commerce](https://github.com/i-love-flamingo/flamingo-commerce) - Providing e-commerce features using clean architecture like DDD and ports and adapters, that you can use to build flexible e-commerce applications. +- [Fuego](https://github.com/go-fuego/fuego) - The framework for busy Go developers! Web framework generating OpenAPI 3 spec from source code. +- [Gearbox](https://github.com/abahmed/gearbox) - A web framework written in Go with a focus on high performance and memory optimization. +- [Gin](https://github.com/gin-gonic/gin) - Gin is a web framework written in Go! It features a martini-like API with much better performance, up to 40 times faster. If you need performance and good productivity. +- [Ginrpc](https://github.com/xxjwxc/ginrpc) - Gin parameter automatic binding tool,gin rpc tools. +- [Gizmo](https://github.com/NYTimes/gizmo) - Microservice toolkit used by the New York Times. +- [go-json-rest](https://github.com/ant0ine/go-json-rest) - Quick and easy way to setup a RESTful JSON API. +- [go-rest](https://github.com/ungerik/go-rest) - Small and evil REST framework for Go. +- [Goa](https://github.com/goadesign/goa) - Goa provides a holistic approach for developing remote APIs and microservices in Go. +- [goa](https://github.com/goa-go/goa) - goa is just like koajs for golang, it is a flexible, light, high-performance and extensible web framework based on middleware. +- [GoFr](https://github.com/gofr-dev/gofr) - Gofr is an opinionated microservice development framework. +- [GoFrame](https://github.com/gogf/gf) - GoFrame is a modular, powerful, high-performance and enterprise-class application development framework of Golang. +- [Goilerplate](https://github.com/axzilla/goilerplate) - Modern UI Components for Go & Templ. +- [golamb](https://github.com/twharmon/golamb) - Golamb makes it easier to write API endpoints for use with AWS Lambda and API Gateway. +- [Golax](https://github.com/fulldump/golax) - A non Sinatra fast HTTP framework with support for Google custom methods, deep interceptors, recursion and more. +- [Golf](https://github.com/dinever/golf) - Golf is a fast, simple and lightweight micro-web framework for Go. It comes with powerful features and has no dependencies other than the Go Standard Library. +- [Gondola](https://github.com/rainycape/gondola) - The web framework for writing faster sites, faster. +- [Gone](https://github.com/gone-io/gone) - A lightweight dependency injection and web framework inspired by Spring. +- [gongular](https://github.com/mustafaakin/gongular) - Fast Go web framework with input mapping/validation and (DI) Dependency Injection. +- [GoTuna](https://github.com/gotuna/gotuna) - Minimalistic web framework for Go with mux router, middlewares, sessions, templates, embedded views and static files. +- [goweb](https://github.com/twharmon/goweb) - Web framework with routing, websockets, logging, middleware, static file server (optional gzip), and automatic TLS. +- [Goyave](https://github.com/go-goyave/goyave) - Feature-complete REST API framework aimed at clean code and fast development, with powerful built-in functionalities. +- [Hertz](https://github.com/cloudwego/hertz) - A high-performance and strong-extensibility Go HTTP framework that helps developers build microservices. +- [hiboot](https://github.com/hidevopsio/hiboot) - hiboot is a high performance web application framework with auto configuration and dependency injection support. +- [Huma](https://github.com/danielgtaylor/huma/) - Framework for modern REST/GraphQL APIs with built-in OpenAPI 3, generated documentation, and a CLI. +- [iWF](https://github.com/indeedeng/iwf) - iWF is an all-in-one platform for developing long-running business processes. It offers a convenient abstraction for utilizing databases, ElasticSearch, message queues, durable timers, and more, with a clean, simple, and user-friendly interface. +- [Lit](https://github.com/jvcoutinho/lit) - Highly performant declarative web framework for Golang, aiming for simplicity and quality of life. +- [Macaron](https://github.com/go-macaron/macaron) - Macaron is a high productive and modular design web framework in Go. +- [mango](https://github.com/paulbellamy/mango) - Mango is a modular web-application framework for Go, inspired by Rack, and PEP333. +- [Microservice](https://github.com/claygod/microservice) - The framework for the creation of microservices, written in Golang. +- [neo](https://github.com/ivpusic/neo) - Neo is minimal and fast Go Web Framework with extremely simple API. +- [patron](https://github.com/beatlabs/patron) - Patron is a microservice framework following best cloud practices with a focus on productivity. +- [Pnutmux](https://gitlab.com/fruitygo/pnutmux) - Pnutmux is a powerful Go web framework that uses regex for matching and handling HTTP requests. It offers features such as CORS handling, structured logging, URL parameters extraction, middlewares, and concurrency limiting. +- [Pulse](https://github.com/gopulse/pulse) - Pulse is an HTTP web framework written in Go (Golang) +- [Resoursea](https://github.com/resoursea/api) - REST framework for quickly writing resource based services. +- [REST Layer](https://github.com/rs/rest-layer) - Framework to build REST/GraphQL API on top of databases with mostly configuration over code. +- [Revel](https://github.com/revel/revel) - High-productivity web framework for the Go language. +- [rex](https://github.com/goanywhere/rex) - Rex is a library for modular development built upon gorilla/mux, fully compatible with `net/http`. +- [rk-boot](https://github.com/rookie-ninja/rk-boot) - A bootstrapper library for building enterprise go microservice with Gin and gRPC quickly and easily. +- [rux](https://github.com/gookit/rux) - Simple and fast web framework for build golang HTTP applications. +- [tango](https://github.com/lunny/tango) - Micro & pluggable web framework for Go. +- [tigertonic](https://github.com/rcrowley/go-tigertonic) - Go framework for building JSON web services inspired by Dropwizard. +- [uAdmin](https://github.com/uadmin/uadmin) - Fully featured web framework for Golang, inspired by Django. +- [utron](https://github.com/gernest/utron) - Lightweight MVC framework for Go(Golang). +- [vox](https://github.com/aisk/vox) - A golang web framework for humans, inspired by Koa heavily. +- [WebGo](https://github.com/bnkamalesh/webgo) - A micro-framework to build web apps; with handler chaining, middleware and context injection. With standard library compliant HTTP handlers(i.e. http.HandlerFunc). +- [YARF](https://github.com/yarf-framework/yarf) - Fast micro-framework designed to build REST APIs and web services in a fast and simple way. +- [Yokai](https://github.com/ankorstore/yokai) - Simple, modular, and observable Go framework for backend applications. + +**[⬆ back to top](#contents)** ### Middlewares -*Libraries for creating HTTP middlewares.* +#### Actual middlewares + +- [client-timing](https://github.com/posener/client-timing) - An HTTP client for Server-Timing header. +- [CORS](https://github.com/rs/cors) - Easily add CORS capabilities to your API. +- [echo-middleware](https://github.com/faabiosr/echo-middleware) - Middleware for Echo framework with logging and metrics. +- [formjson](https://github.com/rs/formjson) - Transparently handle JSON input as a standard form POST. +- [go-fault](https://github.com/github/go-fault) - Fault injection middleware for Go. +- [go-server-timing](https://github.com/mitchellh/go-server-timing) - Add/parse Server-Timing header. +- [Limiter](https://github.com/ulule/limiter) - Dead simple rate limit middleware for Go. +- [ln-paywall](https://github.com/philippgille/ln-paywall) - Go middleware for monetizing APIs on a per-request basis with the Lightning Network (Bitcoin). +- [mid](https://github.com/bobg/mid) - Miscellaneous HTTP middleware features: idiomatic error return from handlers; receive/respond with JSON data; request tracing; and more. +- [rk-gin](https://github.com/rookie-ninja/rk-gin) - Middleware for Gin framework with logging, metrics, auth, tracing etc. +- [rk-grpc](https://github.com/rookie-ninja/rk-grpc) - Middleware for gRPC with logging, metrics, auth, tracing etc. +- [Tollbooth](https://github.com/didip/tollbooth) - Rate limit HTTP request handler. +- [XFF](https://github.com/sebest/xff) - Handle `X-Forwarded-For` header and friends. + +#### Libraries for creating HTTP middlewares + +- [alice](https://github.com/justinas/alice) - Painless middleware chaining for Go. +- [catena](https://github.com/codemodus/catena) - http.Handler wrapper catenation (same API as "chain"). +- [chain](https://github.com/codemodus/chain) - Handler wrapper chaining with scoped data (net/context-based "middleware"). +- [gores](https://github.com/alioygur/gores) - Go package that handles HTML, JSON, XML and etc. responses. Useful for RESTful APIs. +- [interpose](https://github.com/carbocation/interpose) - Minimalist net/http middleware for golang. +- [mediary](https://github.com/HereMobilityDevelopers/mediary) - add interceptors to `http.Client` to allow dumping/shaping/tracing/... of requests/responses. +- [muxchain](https://github.com/stephens2424/muxchain) - Lightweight middleware for net/http. +- [negroni](https://github.com/urfave/negroni) - Idiomatic HTTP middleware for Golang. +- [render](https://github.com/unrolled/render) - Go package for easily rendering JSON, XML, and HTML template responses. +- [renderer](https://github.com/thedevsaddam/renderer) - Simple, lightweight and faster response (JSON, JSONP, XML, YAML, HTML, File) rendering package for Go. +- [rye](https://github.com/InVisionApp/rye) - Tiny Go middleware library (with canned Middlewares) that supports JWT, CORS, Statsd, and Go 1.7 context. +- [stats](https://github.com/thoas/stats) - Go middleware that stores various information about your web application. + +**[⬆ back to top](#contents)** + +### Routers + +- [alien](https://github.com/gernest/alien) - Lightweight and fast http router from outer space. +- [bellt](https://github.com/GuilhermeCaruso/bellt) - A simple Go HTTP router. +- [Bone](https://github.com/go-zoo/bone) - Lightning Fast HTTP Multiplexer. +- [Bxog](https://github.com/claygod/Bxog) - Simple and fast HTTP router for Go. It works with routes of varying difficulty, length and nesting. And he knows how to create a URL from the received parameters. +- [chi](https://github.com/go-chi/chi) - Small, fast and expressive HTTP router built on net/context. +- [fasthttprouter](https://github.com/buaazp/fasthttprouter) - High performance router forked from `httprouter`. The first router fit for `fasthttp`. +- [FastRouter](https://github.com/razonyang/fastrouter) - a fast, flexible HTTP router written in Go. +- [goblin](https://github.com/bmf-san/goblin) - A golang http router based on trie tree. +- [gocraft/web](https://github.com/gocraft/web) - Mux and middleware package in Go. +- [Goji](https://github.com/goji/goji) - Goji is a minimalistic and flexible HTTP request multiplexer with support for `net/context`. +- [GoLobby/Router](https://github.com/golobby/router) - GoLobby Router is a lightweight yet powerful HTTP router for the Go programming language. +- [goroute](https://github.com/goroute/route) - Simple yet powerful HTTP request multiplexer. +- [GoRouter](https://github.com/vardius/gorouter) - GoRouter is a Server/API micro framework, HTTP request router, multiplexer, mux that provides request router with middleware supporting `net/context`. +- [gowww/router](https://github.com/gowww/router) - Lightning fast HTTP router fully compatible with the net/http.Handler interface. +- [httprouter](https://github.com/julienschmidt/httprouter) - High performance router. Use this and the standard http handlers to form a very high performance web framework. +- [httptreemux](https://github.com/dimfeld/httptreemux) - High-speed, flexible tree-based HTTP router for Go. Inspiration from httprouter. +- [lars](https://github.com/go-playground/lars) - Is a lightweight, fast and extensible zero allocation HTTP router for Go used to create customizable frameworks. +- [mux](https://github.com/gorilla/mux) - Powerful URL router and dispatcher for golang. +- [nchi](https://github.com/muir/nchi) - chi-like router built on httprouter with dependency injection based middleware wrappers +- [ngamux](https://github.com/ngamux/ngamux) - Simple HTTP router for Go. +- [ozzo-routing](https://github.com/go-ozzo/ozzo-routing) - An extremely fast Go (golang) HTTP router that supports regular expression route matching. Comes with full support for building RESTful APIs. +- [pure](https://github.com/go-playground/pure) - Is a lightweight HTTP router that sticks to the std "net/http" implementation. +- [Siesta](https://github.com/VividCortex/siesta) - Composable framework to write middleware and handlers. +- [vestigo](https://github.com/husobee/vestigo) - Performant, stand-alone, HTTP compliant URL Router for go web applications. +- [violetear](https://github.com/nbari/violetear) - Go HTTP router. +- [xmux](https://github.com/rs/xmux) - High performance muxer based on `httprouter` with `net/context` support. +- [xujiajun/gorouter](https://github.com/xujiajun/gorouter) - A simple and fast HTTP router for Go. + +**[⬆ back to top](#contents)** + +## WebAssembly + +- [dom](https://github.com/dennwc/dom) - DOM library. +- [Extism Go SDK](https://github.com/extism/go-sdk) - Universal, cross-language WebAssembly framework for building plug-in systems and polyglot apps. +- [go-canvas](https://github.com/markfarnan/go-canvas) - Library to use HTML5 Canvas, with all drawing within go code. +- [tinygo](https://github.com/tinygo-org/tinygo) - Go compiler for small places. Microcontrollers, WebAssembly, and command-line tools. Based on LLVM. +- [vert](https://github.com/norunners/vert) - Interop between Go and JS values. +- [wasmbrowsertest](https://github.com/agnivade/wasmbrowsertest) - Run Go WASM tests in your browser. +- [webapi](https://github.com/gowebapi/webapi) - Bindings for DOM and HTML generated from WebIDL. + +**[⬆ back to top](#contents)** -* [alice](https://github.com/justinas/alice) - Painless middleware chaining for Go. -* [go-wrap](https://github.com/go-on/wrap) - Small middlewares package for net/http. -* [interpose](https://github.com/carbocation/interpose) - Minimalist net/http middleware for golang -* [muxchain](https://github.com/stephens2424/muxchain) - Lightweight middleware for net/http. -* [negroni](https://github.com/codegangsta/negroni) - Idiomatic HTTP middleware for Golang. -* [render](https://github.com/unrolled/render) - Go package for easily rendering JSON, XML, and HTML template responses. +## Windows +- [d3d9](https://github.com/gonutz/d3d9) - Go bindings for Direct3D9. +- [go-ole](https://github.com/go-ole/go-ole) - Win32 OLE implementation for golang. +- [gosddl](https://github.com/MonaxGT/gosddl) - Converter from SDDL-string to user-friendly JSON. SDDL consist of four part: Owner, Primary Group, DACL, SACL. +**[⬆ back to top](#contents)** +## XML -# Tools +_Libraries and tools for manipulating XML._ -Go software and plugins. +- [XML-Comp](https://github.com/xml-comp/xml-comp) - Simple command line XML comparer that generates diffs of folders, files and tags. +- [xml2map](https://github.com/sbabiv/xml2map) - XML to MAP converter written Golang. +- [xmlwriter](https://github.com/shabbyrobe/xmlwriter) - Procedural XML generation API based on libxml2's xmlwriter module. +- [xpath](https://github.com/antchfx/xpath) - XPath package for Go. +- [xquery](https://github.com/antchfx/xquery) - XQuery lets you extract data from HTML/XML documents using XPath expression. +- [zek](https://github.com/miku/zek) - Generate a Go struct from XML. +## Zero Trust -## Code Analysis +_Libraries and tools to implement Zero Trust architectures._ -* [doc](http://godoc.org/robpike.io/cmd/doc) - Go documentation tool that produces an alternative doc format. -* [errcheck](https://github.com/kisielk/errcheck) - Errcheck is a program for checking for unchecked errors in Go programs. -* [gcvis](https://github.com/davecheney/gcvis) - Visualise Go program GC trace data in real time. -* [Go Metalinter](https://github.com/alecthomas/gometalinter) - Metalinter is a tool to automatically apply all static analysis tool and report their output in normalized form. -* [goast-viewer](https://github.com/yuroyoro/goast-viewer) - Web based Golang AST visualizer. -* [GoCover.io](http://gocover.io/) - GoCover.io offers the code coverage of any golang package as a service. -* [goimports](https://godoc.org/golang.org/x/tools/cmd/goimports) - Tool to fix (add, remove) your Go imports automatically. -* [GoLint](https://github.com/golang/lint) - Golint is a linter for Go source code. -* [Golint online](http://go-lint.appspot.com/) - Lints online Go source files on GitHub, Bitbucket and Google Project Hosting using the golint package. -* [validate](https://github.com/mccoyst/validate) - Automatically validates struct fields with tags. +- [Cosign](https://github.com/sigstore/cosign) - Container Signing, Verification and Storage in an OCI registry. +- [in-toto](https://github.com/in-toto/in-toto-golang) - Go implementation of the in-toto (provides a framework to protect the integrity of the software supply chain) python reference implementation. +- [Spiffe-Vault](https://github.com/philips-labs/spiffe-vault) - Utilizes Spiffe JWT authentication with Hashicorp Vault for secretless authentication. +- [Spire](https://github.com/spiffe/spire) - SPIRE (the SPIFFE Runtime Environment) is a toolchain of APIs for establishing trust between software systems across a wide variety of hosting platforms. +## Code Analysis -## Editor Plugins +_Source code analysis tools, also known as Static Application Security Testing (SAST) Tools._ + +- [apicompat](https://github.com/bradleyfalzon/apicompat) - Checks recent changes to a Go project for backwards incompatible changes. +- [asty](https://github.com/asty-org/asty) - Converts golang AST to JSON and JSON to AST. +- [blanket](https://gitlab.com/verygoodsoftwarenotvirus/blanket) - blanket is a tool that helps you catch functions which don't have direct unit tests in your Go packages. +- [ChainJacking](https://github.com/Checkmarx/chainjacking) - Find which of your Go lang direct GitHub dependencies is susceptible to ChainJacking attack. +- [Chronos](https://github.com/amit-davidson/Chronos) - Detects race conditions statically +- [dupl](https://github.com/mibk/dupl) - Tool for code clone detection. +- [errcheck](https://github.com/kisielk/errcheck) - Errcheck is a program for checking for unchecked errors in Go programs. +- [gcvis](https://github.com/davecheney/gcvis) - Visualise Go program GC trace data in real time. +- [go-checkstyle](https://github.com/qiniu/checkstyle) - checkstyle is a style check tool like java checkstyle. This tool inspired by java checkstyle, golint. The style referred to some points in Go Code Review Comments. +- [go-cleanarch](https://github.com/roblaszczak/go-cleanarch) - go-cleanarch was created to validate Clean Architecture rules, like a The Dependency Rule and interaction between packages in your Go projects. +- [go-critic](https://github.com/go-critic/go-critic) - source code linter that brings checks that are currently not implemented in other linters. +- [go-mod-outdated](https://github.com/psampaz/go-mod-outdated) - An easy way to find outdated dependencies of your Go projects. +- [go-outdated](https://github.com/firstrow/go-outdated) - Console application that displays outdated packages. +- [goast-viewer](https://github.com/yuroyoro/goast-viewer) - Web based Golang AST visualizer. +- [goimports](https://pkg.go.dev/golang.org/x/tools/cmd/goimports) - Tool to fix (add, remove) your Go imports automatically. +- [golang-ifood-sdk](https://github.com/arxdsilva/golang-ifood-sdk) - iFood API SDK. +- [golangci-lint](https://github.com/golangci/golangci-lint) – A fast Go linters runner. It runs linters in parallel, uses caching, supports `yaml` config, has integrations with all major IDE and has dozens of linters included. +- [golines](https://github.com/segmentio/golines) - Formatter that automatically shortens long lines in Go code. +- [GoPlantUML](https://github.com/jfeliu007/goplantuml) - Library and CLI that generates text plantump class diagram containing information about structures and interfaces with the relationship among them. +- [goreturns](https://github.com/sqs/goreturns) - Adds zero-value return statements to match the func return types. +- [gostatus](https://github.com/shurcooL/gostatus) - Command line tool, shows the status of repositories that contain Go packages. +- [lint](https://github.com/surullabs/lint) - Run linters as part of go test. +- [php-parser](https://github.com/z7zmey/php-parser) - A Parser for PHP written in Go. +- [revive](https://github.com/mgechev/revive) – ~6x faster, stricter, configurable, extensible, and beautiful drop-in replacement for `golint`. +- [staticcheck](https://github.com/dominikh/go-tools/tree/master/cmd/staticcheck) - staticcheck is `go vet` on steroids, applying a ton of static analysis checks you might be used to from tools like ReSharper for C#. +- [testifylint](https://github.com/Antonboom/testifylint) – A linter that checks usage of [github.com/stretchr/testify](https://github.com/stretchr/testify). +- [tickgit](https://github.com/augmentable-dev/tickgit) - CLI and go package for surfacing code comment TODOs (in any language) and applying a `git blame`to identify the author. +- [todocheck](https://github.com/preslavmihaylov/todocheck) - Static code analyser which links TODO comments in code with issues in your issue tracker. +- [unconvert](https://github.com/mdempsky/unconvert) - Remove unnecessary type conversions from Go source. +- [usestdlibvars](https://github.com/sashamelentyev/usestdlibvars) - A linter that detect the possibility to use variables/constants from the Go standard library. +- [vacuum](https://github.com/daveshanley/vacuum) - An ultra-super-fast, lightweight OpenAPI linter and quality checking tool. +- [validate](https://github.com/mccoyst/validate) - Automatically validates struct fields with tags. +- [wrapcheck](https://github.com/tomarrell/wrapcheck) - A linter to check that errors from external packages are wrapped. + +**[⬆ back to top](#contents)** -* [go-lang-idea-plugin](https://github.com/go-lang-plugin-org/go-lang-idea-plugin) Go plugin for IntelliJ IDEA. -* [gocode](https://github.com/nsf/gocode) - An autocompletion daemon for the Go programming language -* [GoSublime](https://github.com/DisposaBoy/GoSublime) - A Golang plugin collection for the text editor SublimeText 2 providing code completion and other IDE-like features. -* [velour](https://github.com/velour/velour) - An IRC client for the acme editor. -* [vim-compiler-go](https://github.com/rjohnsondev/vim-compiler-go) - A Vim plugin to highlight syntax errors on save. -* [vim-go](https://github.com/fatih/vim-go) - Go development plugin for Vim. -* [Watch](https://github.com/eaburns/Watch) - Runs a command in an acme win on file changes. +## Editor Plugins +_Plugin for text editors and IDEs._ + +- [coc-go language server extension for Vim/Neovim](https://github.com/josa42/coc-go) - This plugin adds [gopls](https://github.com/golang/tools/blob/master/gopls/README.md) features to Vim/Neovim. +- [Go Doc](https://github.com/msyrus/vscode-go-doc) - A Visual Studio Code extension for showing definition in output and generating go doc. +- [Go plugin for JetBrains IDEs](https://plugins.jetbrains.com/plugin/9568-go) - Go plugin for JetBrains IDEs. +- [go-language-server](https://github.com/theia-ide/go-language-server) - A wrapper to turn the VSCode go extension into a language server supporting the language-server-protocol. +- [go-mode](https://github.com/dominikh/go-mode.el) - Go mode for GNU/Emacs. +- [go-plus](https://github.com/joefitzgerald/go-plus) - Go (Golang) Package For Atom That Adds Autocomplete, Formatting, Syntax Checking, Linting and Vetting. +- [gocode](https://github.com/nsf/gocode) - Autocompletion daemon for the Go programming language. +- [goimports-reviser](https://github.com/incu6us/goimports-reviser) - Formatting tool for imports. +- [goprofiling](https://marketplace.visualstudio.com/items?itemName=MaxMedia.go-prof) - This extension adds benchmark profiling support for the Go language to VS Code. +- [GoSublime](https://github.com/DisposaBoy/GoSublime) - Golang plugin collection for the text editor SublimeText 3 providing code completion and other IDE-like features. +- [gounit-vim](https://github.com/hexdigest/gounit-vim) - Vim plugin for generating Go tests based on the function's or method's signature. +- [theia-go-extension](https://github.com/theia-ide/theia-go-extension) - Go language support for the Theia IDE. +- [vim-compiler-go](https://github.com/rjohnsondev/vim-compiler-go) - Vim plugin to highlight syntax errors on save. +- [vim-go](https://github.com/fatih/vim-go) - Go development plugin for Vim. +- [vscode-go](https://github.com/golang/vscode-go) - Extension for Visual Studio Code (VS Code) which provides support for the Go language. +- [Watch](https://github.com/eaburns/Watch) - Runs a command in an acme win on file changes. + +**[⬆ back to top](#contents)** + +## Go Generate Tools + +- [envdoc](https://github.com/g4s8/envdoc) - generate documentation for environment variables from Go source files. +- [generic](https://github.com/usk81/generic) - flexible data type for Go. +- [genny](https://github.com/cheekybits/genny) - Elegant generics for Go. +- [gocontracts](https://github.com/Parquery/gocontracts) - brings design-by-contract to Go by synchronizing the code with the documentation. +- [godal](https://github.com/mafulong/godal) - Generate orm models corresponding to golang by specifying sql ddl file, which can be used by gorm. +- [gonerics](https://github.com/bouk/gonerics) - Idiomatic Generics in Go. +- [gotests](https://github.com/cweill/gotests) - Generate Go tests from your source code. +- [gounit](https://github.com/hexdigest/gounit) - Generate Go tests using your own templates. +- [hasgo](https://github.com/DylanMeeus/hasgo) - Generate Haskell inspired functions for your slices. +- [options-gen](https://github.com/kazhuravlev/options-gen) - Functional options described by Dave Cheney's post "Functional options for friendly APIs". +- [re2dfa](https://gitlab.com/opennota/re2dfa) - Transform regular expressions into finite state machines and output Go source code. +- [sqlgen](https://github.com/anqiansong/sqlgen) - Generate gorm, xorm, sqlx, bun, sql code from SQL file or DSN. +- [TOML-to-Go](https://xuri.me/toml-to-go) - Translates TOML into a Go type in the browser instantly. +- [xgen](https://github.com/xuri/xgen) - XSD (XML Schema Definition) parser and Go/C/Java/Rust/TypeScript code generator. + +**[⬆ back to top](#contents)** + +## Go Tools + +- [colorgo](https://github.com/songgao/colorgo) - Wrapper around `go` command for colorized `go build` output. +- [decouple](https://github.com/bobg/decouple) - Find “overspecified” function parameters that could be generalized with interface types. +- [depth](https://github.com/KyleBanks/depth) - Visualize dependency trees of any package by analyzing imports. +- [docs](https://github.com/go-oas/docs) - Automatically generate RESTful API documentation for GO projects - aligned with Open API Specification standard. +- [go-callvis](https://github.com/TrueFurby/go-callvis) - Visualize call graph of your Go program using dot format. +- [go-size-analyzer](https://github.com/Zxilly/go-size-analyzer) - Analyze and visualize the size of dependencies in compiled Golang binaries, providing insight into their impact on the final build. +- [go-swagger](https://github.com/go-swagger/go-swagger) - Swagger 2.0 implementation for go. Swagger is a simple yet powerful representation of your RESTful API. +- [godbg](https://github.com/tylerwince/godbg) - Implementation of Rusts `dbg!` macro for quick and easy debugging during development. +- [gomodrun](https://github.com/dustinblackman/gomodrun/) - Go tool that executes and caches binaries included in go.mod files. +- [gotemplate.io](https://gotemplate.io/) - Online tool to preview `text/template` templates live. +- [gotestdox](https://github.com/bitfield/gotestdox) - Show Go test results as readable sentences. +- [gothanks](https://github.com/psampaz/gothanks) - GoThanks automatically stars your go.mod github dependencies, sending this way some love to their maintainers. +- [igo](https://github.com/rocketlaunchr/igo) - An igo to go transpiler (new language features for Go language!) +- [modver](https://github.com/bobg/modver) - Compare two versions of a Go module to check the version-number change required (major, minor, or patchlevel), according to [semver](https://semver.org/) rules. +- [MoniGO](https://github.com/iyashjayesh/monigo) - A performance monitoring library for Go applications. It provides real-time insights into application performance! 🚀 +- [OctoLinker](https://github.com/OctoLinker/browser-extension) - Navigate through go files efficiently with the OctoLinker browser extension for GitHub. +- [richgo](https://github.com/kyoh86/richgo) - Enrich `go test` outputs with text decorations. +- [roumon](https://github.com/becheran/roumon) - Monitor current state of all active goroutines via a command line interface. +- [rts](https://github.com/galeone/rts) - RTS: response to struct. Generates Go structs from server responses. +- [textra](https://github.com/ravsii/textra) - Extract Go struct field names, types and tags for filtering and exporting. +- [typex](https://github.com/dtgorski/typex) - Examine Go types and their transitive dependencies, alternatively export results as TypeScript value objects (or types) declaration. + + +**[⬆ back to top](#contents)** ## Software Packages -Software written in Go. +_Software written in Go._ +**[⬆ back to top](#contents)** ### DevOps Tools -* [aptly](https://github.com/smira/aptly) - aptly is a Debian repository management tool -* [Boom](https://github.com/rakyll/boom) - Boom is a tiny program that sends some load to a web application. -* [dogo](https://github.com/liudng/dogo) - Monitoring changes in the source file and automatically compile and run (restart). -* [EasySSH](https://github.com/hypersleep/easyssh) - Golang package for easy remote execution through SSH and SCP downloading. -* [gaudi](http://gaudi.io/) - Gaudi automates the setup of isolated and decoupled dev environments. -* [Go Metrics](https://github.com/rcrowley/go-metrics) - Go port of Coda Hale's Metrics library: https://github.com/codahale/metrics. -* [go-selfupdate](https://github.com/sanbornm/go-selfupdate) - Enable your Go applications to self update. -* [gobrew](https://github.com/cryptojuice/gobrew) - gobrew lets you easily switch between multiple versions of go. -* [GoBuild](http://gobuild.io/) - Online compile Go projects to Windows, Linux and MacOSX. -* [godbg](https://github.com/sirnewton01/godbg) - Web-based gdb front-end application. -* [Gogs](http://gogs.io/) - A Self Hosted Git Service in the Go Programming Language. -* [gonative](https://github.com/inconshreveable/gonative) - Tool which creates a build of Go that can cross compile to all platforms while still using the Cgo-enabled versions of the stdlib packages. -* [gox](https://github.com/mitchellh/gox) - A dead simple, no frills Go cross compile tool. -* [goxc](https://github.com/laher/goxc) - build tool for Go, with a focus on cross-compiling and packaging. -* [GVM](https://github.com/moovweb/gvm) - GVM provides an interface to manage Go versions. -* [hk](https://github.com/heroku/hk) - Heroku command-line interface in Go. -* [Mora](https://github.com/emicklei/mora) - REST server for accessing MongoDB documents and meta data. -* [ostent](https://github.com/ostrost/ostent) - collects and displays system metrics and optionally relays to Graphite and/or InfluxDB -* [Packer](https://github.com/mitchellh/packer) - Packer is a tool for creating identical machine images for multiple platforms from a single source configuration. -* [Rodent](https://github.com/alouche/rodent) - Rodent helps you manage Go versions, projects and track dependencies. -* [webhook](https://github.com/adnanh/webhook) - Tool which allows user to create HTTP endpoints (hooks) that execute commands on the server -* [Wide](https://wide.b3log.org) - A Web-based IDE for Teams using Golang. - +- [abbreviate](https://github.com/dnnrly/abbreviate) - abbreviate is a tool turning long strings in to shorter ones with configurable separators, for example to embed branch names in to deployment stack IDs. +- [alaz](https://github.com/ddosify/alaz) - Effortless, Low-Overhead, eBPF-based Kubernetes Monitoring. +- [aptly](https://github.com/smira/aptly) - aptly is a Debian repository management tool. +- [aurora](https://github.com/xuri/aurora) - Cross-platform web-based Beanstalkd queue server console. +- [awsenv](https://github.com/soniah/awsenv) - Small binary that loads Amazon (AWS) environment variables for a profile. +- [Balerter](https://github.com/balerter/balerter) - A self-hosted script-based alerting manager. +- [Blast](https://github.com/dave/blast) - A simple tool for API load testing and batch jobs. +- [bombardier](https://github.com/codesenberg/bombardier) - Fast cross-platform HTTP benchmarking tool. +- [bosun](https://github.com/bosun-monitor/bosun) - Time Series Alerting Framework. +- [cassowary](https://github.com/rogerwelin/cassowary) - Modern cross-platform HTTP load-testing tool written in Go. +- [Ddosify](https://github.com/ddosify/ddosify) - High-performance load testing tool, written in Golang. +- [decompose](https://github.com/s0rg/decompose) - tool to generate and process Docker containers connections graphs. +- [DepCharge](https://github.com/centerorbit/depcharge) - Helps orchestrating the execution of commands across the many dependencies in larger projects. +- [Docker](https://www.docker.com/) - Open platform for distributed applications for developers and sysadmins. +- [docker-go-mingw](https://github.com/x1unix/docker-go-mingw) - Docker image for building Go binaries for Windows with MinGW toolchain. +- [Dockerfile-Generator](https://github.com/ozankasikci/dockerfile-generator) - A go library and an executable that produces valid Dockerfiles using various input channels. +- [dogo](https://github.com/liudng/dogo) - Monitoring changes in the source file and automatically compile and run (restart). +- [drone-jenkins](https://github.com/appleboy/drone-jenkins) - Trigger downstream Jenkins jobs using a binary, docker or Drone CI. +- [drone-scp](https://github.com/appleboy/drone-scp) - Copy files and artifacts via SSH using a binary, docker or Drone CI. +- [Dropship](https://github.com/chrismckenzie/dropship) - Tool for deploying code via cdn. +- [easyssh-proxy](https://github.com/appleboy/easyssh-proxy) - Golang package for easy remote execution through SSH and SCP downloading via `ProxyCommand`. +- [fac](https://github.com/mkchoi212/fac) - Command-line user interface to fix git merge conflicts. +- [Flannel](https://github.com/flannel-io/flannel) - Flannel is a network fabric for containers, designed for Kubernetes. +- [Fleet device management](https://github.com/fleetdm/fleet) - Lightweight, programmable telemetry for servers and workstations. +- [gaia](https://github.com/gaia-pipeline/gaia) - Build powerful pipelines in any programming language. +- [ghorg](https://github.com/gabrie30/ghorg) - Quickly clone an entire org/users repositories into one directory - Supports GitHub, GitLab, Gitea, and Bitbucket. +- [Gitea](https://github.com/go-gitea/gitea) - Fork of Gogs, entirely community driven. +- [gitea-github-migrator](https://git.jonasfranz.software/JonasFranzDEV/gitea-github-migrator) - Migrate all your GitHub repositories, issues, milestones and labels to your Gitea instance. +- [go-furnace](https://github.com/go-furnace/go-furnace) - Hosting solution written in Go. Deploy your Application with ease on AWS, GCP or DigitalOcean. +- [go-rocket-update](https://github.com/mouuff/go-rocket-update) - A simple way to make self updating Go applications - Supports Github and Gitlab. +- [go-selfupdate](https://github.com/sanbornm/go-selfupdate) - Enable your Go applications to self update. +- [gobrew](https://github.com/cryptojuice/gobrew) - gobrew lets you easily switch between multiple versions of go. +- [gobrew](https://github.com/kevincobain2000/gobrew) - Go version manager. Super simple tool to install and manage Go versions. Install go without root. Gobrew doesn't require shell rehash. +- [godbg](https://github.com/sirnewton01/godbg) - Web-based gdb front-end application. +- [Gogs](https://gogs.io/) - A Self Hosted Git Service in the Go Programming Language. +- [gonative](https://github.com/inconshreveable/gonative) - Tool which creates a build of Go that can cross compile to all platforms while still using the Cgo-enabled versions of the stdlib packages. +- [govvv](https://github.com/ahmetalpbalkan/govvv) - “go build” wrapper to easily add version information into Go binaries. +- [gox](https://github.com/mitchellh/gox) - Dead simple, no frills Go cross compile tool. +- [goxc](https://github.com/laher/goxc) - build tool for Go, with a focus on cross-compiling and packaging. +- [grapes](https://github.com/yaronsumel/grapes) - Lightweight tool designed to distribute commands over ssh with ease. +- [GVM](https://github.com/moovweb/gvm) - GVM provides an interface to manage Go versions. +- [Hey](https://github.com/rakyll/hey) - Hey is a tiny program that sends some load to a web application. +- [httpref](https://github.com/dnnrly/httpref) - httpref is a handy CLI reference for HTTP methods, status codes, headers, and TCP and UDP ports. +- [jcli](https://github.com/jenkins-zh/jenkins-cli) - Jenkins CLI allows you manage your Jenkins as an easy way. +- [k3d](https://github.com/k3d-io/k3d) - Little helper to run CNCF's k3s in Docker. +- [k3s](https://github.com/k3s-io/k3s) - Lightweight Kubernetes. +- [k6](https://github.com/grafana/k6) - A modern load testing tool, using Go and JavaScript. +- [kala](https://github.com/ajvb/kala) - Simplistic, modern, and performant job scheduler. +- [kcli](https://github.com/cswank/kcli) - Command line tool for inspecting kafka topics/partitions/messages. +- [kind](https://github.com/kubernetes-sigs/kind) - Kubernetes IN Docker - local clusters for testing Kubernetes. +- [ko](https://github.com/google/ko) - Command line tool for building and deploying Go applications on Kubernetes +- [kool](https://github.com/kool-dev/kool) - Command line tool for managing Docker environments as an easy way. +- [kubeblocks](https://github.com/apecloud/kubeblocks) - KubeBlocks is an open-source control plane that runs and manages databases, message queues and other data infrastructure on K8s. +- [kubernetes](https://github.com/kubernetes/kubernetes) - Container Cluster Manager from Google. +- [kubeshark](https://github.com/kubeshark/kubeshark) - API traffic analyzer for Kubernetes, inspired by Wireshark, purposely built for Kubernetes. +- [KubeVela](https://github.com/kubevela/kubevela) - Cloud native application delivery. +- [KubeVPN](https://github.com/kubenetworks/kubevpn) - KubeVPN offers a Cloud-Native Dev Environment that seamlessly connects to your Kubernetes cluster network. +- [KusionStack](https://github.com/KusionStack/kusion) - A unified programmable configuration techstack to deliver modern app in 'platform as code' and 'infra as code' approach. +- [kwatch](https://github.com/abahmed/kwatch) - Monitor & detect crashes in your Kubernetes(K8s) cluster instantly. +- [lstags](https://github.com/ivanilves/lstags) - Tool and API to sync Docker images across different registries. +- [lwc](https://github.com/timdp/lwc) - A live-updating version of the UNIX wc command. +- [manssh](https://github.com/xwjdsh/manssh) - manssh is a command line tool for managing your ssh alias config easily. +- [Mantil](https://github.com/mantil-io/mantil) - Go specific framework for building serverless applications on AWS that enables you to focus on pure Go code while Mantil takes care of the infrastructure. +- [minikube](https://github.com/kubernetes/minikube) - Run Kubernetes locally. +- [Moby](https://github.com/moby/moby) - Collaborative project for the container ecosystem to assemble container-based systems. +- [Mora](https://github.com/emicklei/mora) - REST server for accessing MongoDB documents and meta data. +- [ostent](https://github.com/ostrost/ostent) - collects and displays system metrics and optionally relays to Graphite and/or InfluxDB. +- [Packer](https://github.com/mitchellh/packer) - Packer is a tool for creating identical machine images for multiple platforms from a single source configuration. +- [Pewpew](https://github.com/bengadbois/pewpew) - Flexible HTTP command line stress tester. +- [PipeCD](https://github.com/pipe-cd/pipecd) - A GitOps-style continuous delivery platform that provides consistent deployment and operations experience for any applications. +- [podinfo](https://github.com/stefanprodan/podinfo) - Podinfo is a tiny web application made with Go that showcases best practices of running microservices in Kubernetes. Podinfo is used by CNCF projects like Flux and Flagger for end-to-end testing and workshops. +- [Pomerium](https://github.com/pomerium/pomerium) - Pomerium is an identity-aware access proxy. +- [Rodent](https://github.com/alouche/rodent) - Rodent helps you manage Go versions, projects and track dependencies. +- [s3-proxy](https://github.com/oxyno-zeta/s3-proxy) - S3 Proxy with GET, PUT and DELETE methods and authentication (OpenID Connect and Basic Auth). +- [s3gof3r](https://github.com/rlmcpherson/s3gof3r) - Small utility/library optimized for high speed transfer of large objects into and out of Amazon S3. +- [s5cmd](https://github.com/peak/s5cmd) - Blazing fast S3 and local filesystem execution tool. +- [Scaleway-cli](https://github.com/scaleway/scaleway-cli) - Manage BareMetal Servers from Command Line (as easily as with Docker). +- [script](https://github.com/bitfield/script) - Making it easy to write shell-like scripts in Go for DevOps and system administration tasks. +- [sg](https://github.com/ChristopherRabotin/sg) - Benchmarks a set of HTTP endpoints (like ab), with possibility to use the response code and data between each call for specific server stress based on its previous response. +- [skm](https://github.com/TimothyYe/skm) - SKM is a simple and powerful SSH Keys Manager, it helps you to manage your multiple SSH keys easily! +- [StatusOK](https://github.com/sanathp/statusok) - Monitor your Website and REST APIs.Get Notified through Slack, E-mail when your server is down or response time is more than expected. +- [tau](https://github.com/taubyte/tau) - Easily build Cloud Computing Platforms with features like Serverless WebAssembly Functions, Frontend Hosting, CI/CD, Object Storage, K/V Database, and Pub-Sub Messaging. +- [terraform-provider-openapi](https://github.com/dikhan/terraform-provider-openapi) - Terraform provider plugin that dynamically configures itself at runtime based on an OpenAPI document (formerly known as swagger file) containing the definitions of the APIs exposed. +- [tf-profile](https://github.com/datarootsio/tf-profile) - Profiler for Terraform runs. Generate global stats, resource-level stats or visualizations. +- [tlm](https://github.com/yusufcanb/tlm) - Local cli copilot, powered by CodeLLaMa +- [traefik](https://github.com/containous/traefik) - Reverse proxy and load balancer with support for multiple backends. +- [trubka](https://github.com/xitonix/trubka) - A CLI tool to manage and troubleshoot Apache Kafka clusters with the ability of generically publishing/consuming protocol buffer and plain text events to/from Kafka. +- [uTask](https://github.com/ovh/utask) - Automation engine that models and executes business processes declared in yaml. +- [Vegeta](https://github.com/tsenart/vegeta) - HTTP load testing tool and library. It's over 9000! +- [wait-for](https://github.com/dnnrly/wait-for) - Wait for something to happen (from the command line) before continuing. Easy orchestration of Docker services and other things. +- [webhook](https://github.com/adnanh/webhook) - Tool which allows user to create HTTP endpoints (hooks) that execute commands on the server. +- [Wide](https://wide.b3log.org/login) - Web-based IDE for Teams using Golang. +- [winrm-cli](https://github.com/masterzen/winrm-cli) - Cli tool to remotely execute commands on Windows machines. + +**[⬆ back to top](#contents)** ### Other Software -* [Circuit](https://github.com/gocircuit/circuit) - Circuit is a programmable platform-as-a-service (PaaS) and/or Infrastructure-as-a-Service (IaaS), for management, discovery, synchronization and orchestration of services and hosts comprising cloud applications. -* [Comcast](https://github.com/tylertreat/Comcast) - Simulate bad network connections -* [confd](https://github.com/kelseyhightower/confd) - Manage local application configuration files using templates and data from etcd or consul. -* [Docker](http://www.docker.com/) - An open platform for distributed applications for developers and sysadmins. -* [fleet](https://github.com/coreos/fleet) - A Distributed init System. -* [gocc](https://code.google.com/p/gocc) - Gocc is a compiler kit for Go written in Go. -* [Gor] (https://github.com/buger/gor) - Http traffic replication tool, for replaying traffic from production to stage/dev environments in real-time. -* [heka] (https://github.com/mozilla-services/heka) - universal tool for data processing from Mozilla. Large collection of built-in plugins. Extendable via Go and Lua plugin API. -* [hugo](http://gohugo.io/) - A Fast and Modern Static Website Engine -* [Juju](https://juju.ubuntu.com/) - Cloud-agnostic service deployment and orchestration - supports EC2, Azure, Openstack, MAAS and more. -* [limetext](http://limetext.org/) Lime Text is a powerful and elegant text editor primarily developed in Go that aims to be a Free and open-source software successor to Sublime Text. -* [nes](https://github.com/fogleman/nes) - A Nintendo Entertainment System (NES) emulator written in Go. -* [orange-cat](https://github.com/noraesae/orange-cat) - A Markdown previewer written in Go. -* [peg](https://github.com/pointlander/peg) - Peg, Parsing Expression Grammar, is an implementation of a Packrat parser generator. -* [plubi](https://github.com/norwack/plubi) - A Golang Plugin Based IRC Bot. -* [Postman](https://github.com/zachlatta/postman) - Command-line utility for batch-sending email. -* [Seaweed File System](https://github.com/chrislusf/weed-fs) - Fast, Simple and Scalable Distributed File System with O(1) disk seek. -* [shell2http](https://github.com/msoap/shell2http) - Executing shell commands via http server (for prototyping or remote control) -* [syncthing](http://www.syncthing.net/) - An open, decentralized file synchronization tool and protocol. -* [Tenyks](https://github.com/kyleterry/tenyks) - Service oriented IRC bot using Redis and JSON for messaging. -* [tsuru](http://www.tsuru.io/) - An extensible and open source Platform as a Service software. -* [websysd](http://github.com/ian-kent/websysd) - Web based process manager (like Marathon or Upstart) - - - - - - +- [Better Go Playground](https://goplay.tools) - Go playground with syntax highlight, code completion and other features. +- [blocky](https://github.com/0xERR0R/blocky) - Fast and lightweight DNS proxy as ad-blocker for local network with many features. +- [borg](https://github.com/crufter/borg) - Terminal based search engine for bash snippets. +- [boxed](https://github.com/tejo/boxed) - Dropbox based blog engine. +- [Cherry](https://github.com/rafael-santiago/cherry) - Tiny webchat server in Go. +- [Circuit](https://github.com/gocircuit/circuit) - Circuit is a programmable platform-as-a-service (PaaS) and/or Infrastructure-as-a-Service (IaaS), for management, discovery, synchronization and orchestration of services and hosts comprising cloud applications. +- [Comcast](https://github.com/tylertreat/Comcast) - Simulate bad network connections. +- [confd](https://github.com/kelseyhightower/confd) - Manage local application configuration files using templates and data from etcd or consul. +- [crawley](https://github.com/s0rg/crawley) - Web scraper/crawler for cli. +- [croc](https://github.com/schollz/croc) - Easily and securely send files or folders from one computer to another. +- [Documize](https://github.com/documize/community) - Modern wiki software that integrates data from SaaS tools. +- [dp](https://github.com/scryinfo/dp) - Through SDK for data exchange with blockchain, developers can get easy access to DAPP development. +- [drive](https://github.com/odeke-em/drive) - Google Drive client for the commandline. +- [Duplicacy](https://github.com/gilbertchen/duplicacy) - A cross-platform network and cloud backup tool based on the idea of lock-free deduplication. +- [fjira](https://github.com/mk-5/fjira) - A fuzzy-search based terminal UI application for Attlasian Jira +- [Gebug](https://github.com/moshebe/gebug) - A tool that makes debugging of Dockerized Go applications super easy by enabling Debugger and Hot-Reload features, seamlessly. +- [gfile](https://github.com/Antonito/gfile) - Securely transfer files between two computers, without any third party, over WebRTC. +- [Go Package Store](https://github.com/shurcooL/Go-Package-Store) - App that displays updates for the Go packages in your GOPATH. +- [go-peerflix](https://github.com/Sioro-Neoku/go-peerflix) - Video streaming torrent client. +- [goblin](https://goblin.reaper.im) - Golang binaries in a curl, built by goblins. +- [GoBoy](https://github.com/Humpheh/goboy) - Nintendo Game Boy Color emulator written in Go. +- [gocc](https://github.com/goccmack/gocc) - Gocc is a compiler kit for Go written in Go. +- [GoDocTooltip](https://github.com/diankong/GoDocTooltip) - Chrome extension for Go Doc sites, which shows function description as tooltip at function list. +- [Gokapi](https://github.com/Forceu/gokapi) - Lightweight server to share files, which expire after a set amount of downloads or days. Similar to Firefox Send, but without public upload. +- [GoLand](https://jetbrains.com/go) - Full featured cross-platform Go IDE. +- [GoNB](https://github.com/janpfeifer/gonb) - Interactive Go programming with Jupyter Notebooks (also works in VSCode, Binder and Google's Colab). +- [Gor](https://github.com/buger/gor) - Http traffic replication tool, for replaying traffic from production to stage/dev environments in real-time. +- [Guora](https://github.com/meloalright/guora) - A self-hosted Quora like web application written in Go. +- [hoofli](https://github.com/dnnrly/hoofli) - Generate PlantUML diagrams from Chrome or Firefox network inspections. +- [hotswap](https://github.com/edwingeng/hotswap) - A complete solution to reload your go code without restarting your server, interrupting or blocking any ongoing procedure. +- [hugo](https://gohugo.io/) - Fast and Modern Static Website Engine. +- [ide](https://github.com/thestrukture/ide) - Browser accessible IDE. Designed for Go with Go. +- [ipe](https://github.com/dimiro1/ipe) - Open source Pusher server implementation compatible with Pusher client libraries written in GO. +- [joincap](https://github.com/assafmo/joincap) - Command-line utility for merging multiple pcap files together. +- [JuiceFS](https://github.com/juicedata/juicefs) - Distributed POSIX file system built on top of Redis and AWS S3. +- [Juju](https://jujucharms.com/) - Cloud-agnostic service deployment and orchestration - supports EC2, Azure, Openstack, MAAS and more. +- [Leaps](https://github.com/jeffail/leaps) - Pair programming service using Operational Transforms. +- [lgo](https://github.com/yunabe/lgo) - Interactive Go programming with Jupyter. It supports code completion, code inspection and 100% Go compatibility. +- [limetext](https://limetext.github.io) - Lime Text is a powerful and elegant text editor primarily developed in Go that aims to be a Free and open-source software successor to Sublime Text. +- [LiteIDE](https://github.com/visualfc/liteide) - LiteIDE is a simple, open source, cross-platform Go IDE. +- [mockingjay](https://github.com/quii/mockingjay-server) - Fake HTTP servers and consumer driven contracts from one configuration file. You can also make the server randomly misbehave to help do more realistic performance tests. +- [myLG](https://github.com/mehrdadrad/mylg) - Command Line Network Diagnostic tool written in Go. +- [naclpipe](https://github.com/unix4fun/naclpipe) - Simple NaCL EC25519 based crypto pipe tool written in Go. +- [Neo-cowsay](https://github.com/Code-Hex/Neo-cowsay) - 🐮 cowsay is reborn. for a New Era. +- [nes](https://github.com/fogleman/nes) - Nintendo Entertainment System (NES) emulator written in Go. +- [Orbit](https://github.com/gulien/orbit) - A simple tool for running commands and generating files from templates. +- [peg](https://github.com/pointlander/peg) - Peg, Parsing Expression Grammar, is an implementation of a Packrat parser generator. +- [Plik](https://github.com/root-gg/plik) - Plik is a temporary file upload system (Wetransfer like) in Go. +- [portal](https://github.com/SpatiumPortae/portal) - Portal is a quick and easy command-line file transfer utility from any computer to another. +- [protoncheck](https://github.com/servusdei2018/protoncheck) - ProtonMail module for waybar/polybar/yabar/i3blocks. +- [restic](https://github.com/restic/restic) - De-duplicating backup program. +- [sake](https://github.com/alajmo/sake) - sake is a command runner for local and remote hosts. +- [scc](https://github.com/boyter/scc) - Sloc Cloc and Code, a very fast accurate code counter with complexity calculations and COCOMO estimates. +- [Seaweed File System](https://github.com/chrislusf/seaweedfs) - Fast, Simple and Scalable Distributed File System with O(1) disk seek. +- [shell2http](https://github.com/msoap/shell2http) - Executing shell commands via http server (for prototyping or remote control). +- [Snitch](https://github.com/lucasgomide/snitch) - Simple way to notify your team and many tools when someone has deployed any application via Tsuru. +- [sonic](https://github.com/go-sonic/sonic) - Sonic is a Go Blogging Platform. Simple and Powerful. +- [Stack Up](https://github.com/pressly/sup) - Stack Up, a super simple deployment tool - just Unix - think of it like 'make' for a network of servers. +- [stew](https://github.com/marwanhawari/stew) - An independent package manager for compiled binaries. +- [syncthing](https://syncthing.net/) - Open, decentralized file synchronization tool and protocol. +- [tcpdog](https://github.com/mehrdadrad/tcpdog) - eBPF based TCP observability. +- [tcpprobe](https://github.com/mehrdadrad/tcpprobe) - TCP tool for network performance and path monitoring, including socket statistics. +- [term-quiz](https://github.com/crazcalm/term-quiz) - Quizzes for your terminal. +- [toxiproxy](https://github.com/shopify/toxiproxy) - Proxy to simulate network and system conditions for automated tests. +- [tsuru](https://tsuru.io/) - Extensible and open source Platform as a Service software. +- [vaku](https://github.com/lingrino/vaku) - CLI & API for folder-based functions in Vault like copy, move, and search. +- [vFlow](https://github.com/VerizonDigital/vflow) - High-performance, scalable and reliable IPFIX, sFlow and Netflow collector. +- [Wave Terminal](https://waveterm.dev) - Wave is an open-source, AI-native terminal built for seamless developer workflows with inline rendering, a modern UI, and persistent sessions. +- [wellington](https://github.com/wellington/wellington) - Sass project management tool, extends the language with sprite functions (like Compass). +- [woke](https://github.com/get-woke/woke) - Detect non-inclusive language in your source code. +- [yai](https://github.com/ekkinox/yai) - AI powered terminal assistant. +- [zs](https://git.mills.io/prologic/zs) - an extremely minimal static site generator. + +**[⬆ back to top](#contents)** # Resources -Where to discover new Go libraries. +_Where to discover new Go libraries._ +**[⬆ back to top](#contents)** ## Benchmarks -* [autobench](https://github.com/davecheney/autobench) - Framework to compare the performance between different Go versions. -* [go-http-routing-benchmark](https://github.com/julienschmidt/go-http-routing-benchmark) - Go HTTP request router benchmark and comparison. -* [go-type-assertion-benchmark](https://github.com/hgfischer/go-type-assertion-benchmark) - Naive performance test of two ways to do type assertion in Go. -* [go_serialization_benchmarks](https://github.com/alecthomas/go_serialization_benchmarks) - Benchmarks of Go serialization methods. -* [gocostmodel](https://github.com/PuerkitoBio/gocostmodel) - Benchmarks of common basic operations for the Go language. -* [golang-micro-benchmarks](https://github.com/amscanne/golang-micro-benchmarks) - Tiny collection of Go micro benchmarks. The intent is to compare some language features to others. -* [golang-sql-benchmark](https://github.com/tyler-smith/golang-sql-benchmark) - A collection of benchmarks for popular Go database/SQL utilities. -* [kvbench](https://github.com/jimrobinson/kvbench) - Key/Value database benchmark. -* [speedtest-resize](https://github.com/fawick/speedtest-resize) - Compare various Image resize algorithms for the Go language. - +- [autobench](https://github.com/davecheney/autobench) - Framework to compare the performance between different Go versions. +- [go-benchmark-app](https://github.com/mrLSD/go-benchmark-app) - Powerful HTTP-benchmark tool mixed with Аb, Wrk, Siege tools. Gathering statistics and various parameters for benchmarks and comparison results. +- [go-benchmarks](https://github.com/tylertreat/go-benchmarks) - Few miscellaneous Go microbenchmarks. Compare some language features to alternative approaches. +- [go-http-routing-benchmark](https://github.com/julienschmidt/go-http-routing-benchmark) - Go HTTP request router benchmark and comparison. +- [go-json-benchmark](https://github.com/zerosnake0/go-json-benchmark) - Go JSON benchmark. +- [go-ml-benchmarks](https://github.com/nikolaydubina/go-ml-benchmarks) - benchmarks for machine learning inference in Go. +- [go-web-framework-benchmark](https://github.com/smallnest/go-web-framework-benchmark) - Go web framework benchmark. +- [go_serialization_benchmarks](https://github.com/alecthomas/go_serialization_benchmarks) - Benchmarks of Go serialization methods. +- [gocostmodel](https://github.com/PuerkitoBio/gocostmodel) - Benchmarks of common basic operations for the Go language. +- [golang-benchmarks](https://github.com/SimonWaldherr/golang-benchmarks) - a collection of golang benchmarks. +- [golang-sql-benchmark](https://github.com/tyler-smith/golang-sql-benchmark) - Collection of benchmarks for popular Go database/SQL utilities. +- [gospeed](https://github.com/feyeleanor/GoSpeed) - Go micro-benchmarks for calculating the speed of language constructs. +- [kvbench](https://github.com/jimrobinson/kvbench) - Key/Value database benchmark. +- [skynet](https://github.com/atemerev/skynet) - Skynet 1M threads microbenchmark. +- [speedtest-resize](https://github.com/fawick/speedtest-resize) - Compare various Image resize algorithms for the Go language. + +**[⬆ back to top](#contents)** ## Conferences -* [dotGo](http://www.dotgo.io) -* [GopherCon](http://www.gophercon.com/) -* [GopherCon India](http://www.gophercon.in/) - +- [GoCon](https://gocon.connpass.com/) - Tokyo, Japan. +- [GoDays](https://www.godays.io/) - Berlin, Germany. +- [GoLab](https://golab.io/) - Florence, Italy. +- [GopherChina](https://gopherchina.org) - Shanghai, China. +- [GopherCon](https://www.gophercon.com/) - Denver, USA. +- [GopherCon Australia](https://gophercon.com.au/) - Sydney, Australia. +- [GopherCon Brazil](https://gopherconbr.org) - Florianópolis, Brazil. +- [GopherCon Europe](https://gophercon.eu/) - Berlin, Germany. +- [GopherCon India](https://gopherconindia.org/) - Pune, India. +- [GopherCon Israel](https://www.gophercon.org.il/) - Tel Aviv, Israel. +- [GopherCon Russia](https://www.gophercon-russia.ru) - Moscow, Russia. +- [GopherCon Singapore](https://gophercon.sg) - Mapletree Business City, Singapore. +- [GopherCon UK](https://www.gophercon.co.uk/) - London, UK. +- [GopherCon Vietnam](https://gophercon.vn/) - Ho Chi Minh City, Vietnam. +- [GoWest Conference](https://www.gowestconf.com/) - Lehi, USA. + +**[⬆ back to top](#contents)** ## E-Books -* [A Go Developer's Notebook](https://leanpub.com/GoNotebook/read) -* [An Introduction to Programming in Go](http://www.golang-book.com/) -* [Build Web Application with Golang](http://astaxie.gitbooks.io/build-web-application-with-golang/) -* [Building Web Apps With Go](http://codegangsta.gitbooks.io/building-web-apps-with-go/) -* [Go Bootcamp](http://golangbootcamp.com) -* [Learning Go](http://www.miek.nl/downloads/Go/Learning-Go-latest.pdf) -* [Network Programming With Go](http://jan.newmarch.name/go/) - - -## Twitter - -* [@golang](https://twitter.com/golang) -* [@golang_news](https://twitter.com/golang_news) -* [@golangweekly](https://twitter.com/golangweekly) - +### E-books for purchase + +- [100 Go Mistakes: How to Avoid Them](https://www.manning.com/books/100-go-mistakes-how-to-avoid-them) +- [Black Hat Go](https://nostarch.com/blackhatgo) - Go programming for hackers and pentesters. +- [Build an Orchestrator in Go](https://www.manning.com/books/build-an-orchestrator-in-go) +- [Continuous Delivery in Go](https://www.manning.com/books/continuous-delivery-in-go) - This practical guide to continuous delivery shows you how to rapidly establish an automated pipeline that will improve your testing, code quality, and final product. +- [Creative DIY Microcontroller Project With TinyGo and WebAssembly](https://www.packtpub.com/product/creative-diy-microcontroller-projects-with-tinygo-and-webassembly/9781800560208) - An introduction into the TinyGo compiler with projects involving Arduino and WebAssembly. +- [Effective Go: Elegant, efficient, and testable code](https://www.manning.com/books/effective-go) - Unlock Go’s unique perspective on program design, and start writing simple, maintainable, and testable Go code. +- [For the Love of Go](https://bitfieldconsulting.com/books/love) - An introductory book for Go beginners. +- [Go in Practice, Second Edition](https://www.manning.com/books/go-in-practice-second-edition) - Your practical guide on the ins-and-outs of Go development, covering the standard library and the most important tools from Go’s powerful ecosystem. +- [Know Go: Generics](https://bitfieldconsulting.com/books/generics) - A guide to understanding and using generics in Go. +- [Lets-Go](https://lets-go.alexedwards.net) - A step-by-step guide to creating fast, secure and maintanable web applications with Go. +- [Lets-Go-Further](https://lets-go-further.alexedwards.net) - Advanced patterns for building APIs and web applications in Go. +- [The Power of Go: Tests](https://bitfieldconsulting.com/books/tests) - A guide to testing in Go. +- [The Power of Go: Tools](https://bitfieldconsulting.com/books/tools) - A guide to writing command-line tools in Go. +- [Writing A Compiler In Go](https://compilerbook.com) +- [Writing An Interpreter In Go](https://interpreterbook.com) - Book that introduces dozens of techniques for writing idiomatic, expressive, and efficient Go code that avoids common pitfalls. + +### Free e-books + +- [A Go Developer's Notebook](https://leanpub.com/GoNotebook/read) +- [An Introduction to Programming in Go](http://www.golang-book.com/) +- [Build Web Application with Golang](https://astaxie.gitbooks.io/build-web-application-with-golang/content/en/) +- [Building Web Apps With Go](https://codegangsta.gitbooks.io/building-web-apps-with-go/content/) +- [Go 101](https://go101.org) - A book focusing on Go syntax/semantics and all kinds of details. +- [Go AST Book (Chinese)](https://github.com/chai2010/go-ast-book) - A book focusing on Go `go/*` packages. +- [Go Faster](https://leanpub.com/gofaster) - This book seeks to shorten your learning curve and help you become a proficient Go programmer, faster. +- [Go Succinctly](https://github.com/thedevsir/gosuccinctly) - in Persian. +- [Go with the domain](https://threedots.tech/go-with-the-domain/) - A book showing how to apply DDD, Clean Architecture, and CQRS by practical refactoring. +- [GoBooks](https://github.com/dariubs/GoBooks) - A curated list of Go books. +- [How To Code in Go eBook](https://www.digitalocean.com/community/books/how-to-code-in-go-ebook) - A 600 page introduction to Go aimed at first time developers. +- [Learning Go](https://www.miek.nl/downloads/Go/Learning-Go-latest.pdf) +- [Network Programming With Go](https://jan.newmarch.name/golang/) +- [Practical Go Lessons](https://www.practical-go-lessons.com/) +- [Spaceship Go A Journey to the Standard Library](https://blasrodri.github.io/spaceship-go-gh-pages/) +- [The Go Programming Language](https://www.gopl.io/) +- [The Golang Standard Library by Example (Chinese)](https://github.com/polaris1119/The-Golang-Standard-Library-by-Example) +- [Web Application with Go the Anti-Textbook](https://github.com/thewhitetulip/web-dev-golang-anti-textbook/) + +**[⬆ back to top](#contents)** + +## Gophers + +- [Free Gophers Pack](https://github.com/MariaLetta/free-gophers-pack) - Gopher graphics pack by Maria Letta with illustrations and emotional characters in vector and raster. +- [Go-gopher-Vector](https://github.com/keygx/Go-gopher-Vector) - Go gopher Vector Data [.ai, .svg]. +- [gopher-logos](https://github.com/GolangUA/gopher-logos) - adorable gopher logos. +- [gopher-stickers](https://github.com/tenntenn/gopher-stickers) +- [gophericons](https://github.com/shalakhin/gophericons) +- [gopherize.me](https://github.com/matryer/gopherize.me) - Gopherize yourself. +- [gophers](https://github.com/ashleymcnamara/gophers) - Gopher artworks by Ashley McNamara. +- [gophers](https://github.com/egonelbre/gophers) - Free gophers. +- [gophers](https://github.com/rogeralsing/gophers) - random gopher graphics. +- [gophers](https://github.com/sillecelik/go-gopher) - Gopher amigurumi toy pattern. +- [gophers](https://github.com/scraly/gophers) - Gophers by Aurélie Vache. + +**[⬆ back to top](#contents)** + +## Meetups + +- [Basel Go Meetup](https://www.meetup.com/Basel-Go-Meetup/) +- [Belfast Gophers](https://www.meetup.com/Belfast-Gophers/) +- [Belgrade Golang Meetup](https://www.meetup.com/golang-serbia/) +- [Berlin Golang](https://www.meetup.com/golang-users-berlin/) +- [Brisbane Gophers](https://www.meetup.com/Brisbane-Golang-Meetup/) +- [Bärner Go Meetup - Berne, Switzerland](https://www.meetup.com/berner-go-meetup/) +- [Go Language NYC](https://www.meetup.com/golanguagenewyork/) +- [Go London User Group](https://www.meetup.com/Go-London-User-Group/) +- [Go Remote Meetup](https://www.meetup.com/Go-Remote-Meetup/) +- [Go Toronto](https://www.meetup.com/go-toronto/) +- [Go User Group Atlanta](https://www.meetup.com/Go-Users-Group-Atlanta/) +- [GoBandung](https://www.meetup.com/GoBandung/) +- [GoBridge, San Francisco, CA](https://www.meetup.com/gobridge/) +- [GoCracow - Krakow, Poland](https://www.meetup.com/GoCracow/) +- [GoJakarta](https://www.meetup.com/GoJakarta/) +- [Golang Amsterdam](https://www.meetup.com/golang-amsterdam/) +- [Golang Argentina](https://www.meetup.com/Golang-Argentina/) +- [Golang Athens](https://www.meetup.com/Athens-Gophers/) +- [Golang Baltimore, MD](https://www.meetup.com/BaltimoreGolang/) +- [Golang Bangalore](https://www.meetup.com/Golang-Bangalore/) +- [Golang Belo Horizonte - Brazil](https://www.meetup.com/go-belo-horizonte/) +- [Golang Boston](https://www.meetup.com/bostongo/) +- [Golang Bulgaria](https://www.meetup.com/Golang-Bulgaria/) +- [Golang Cardiff, UK](https://www.meetup.com/Cardiff-Go-Meetup/) +- [Golang Copenhagen](https://www.meetup.com/Go-Cph/) +- [Golang Curitiba - Brazil](https://www.meetup.com/GolangCWB/) +- [Golang DC, Arlington, VA](https://www.meetup.com/Golang-DC/) +- [Golang Dorset, UK](https://www.meetup.com/golang-dorset/) +- [Golang Estonia](https://www.meetup.com/Golang-Estonia/) +- [Golang Gurgaon, India](https://www.meetup.com/Gurgaon-Go-Meetup/) +- [Golang Hamburg - Germany](https://www.meetup.com/Go-User-Group-Hamburg/) +- [Golang Israel](https://www.meetup.com/Go-Israel/) +- [Golang Kathmandu](https://www.meetup.com/Golang-Kathmandu/) +- [Golang Lima - Peru](https://www.meetup.com/Golang-Peru/) +- [Golang Lyon](https://www.meetup.com/Golang-Lyon/) +- [Golang Marseille](https://www.meetup.com/fr-FR/Golang-Marseille/) +- [Golang Melbourne](https://www.meetup.com/golang-mel/) +- [Golang North East](https://www.meetup.com/en-AU/Golang-North-East/) +- [Golang Paris](https://www.meetup.com/Golang-Paris/) +- [Golang Poland](https://www.meetup.com/Golang-Poland/) +- [Golang Pune](https://www.meetup.com/Golang-Pune/) +- [Golang Rotterdam](https://www.meetup.com/golang-rotterdam/) +- [Golang Singapore](https://www.meetup.com/golangsg/) +- [Golang Stockholm](https://www.meetup.com/Go-Stockholm/) +- [Golang Sydney, AU](https://www.meetup.com/golang-syd/) +- [Golang São Paulo - Brazil](https://www.meetup.com/golangbr/) +- [Golang Taipei](https://www.meetup.com/golang-taipei-meetup/) +- [Golang Thessaloniki](https://www.meetup.com/thessaloniki-golang-meetup/) +- [Golang Turkey](https://kommunity.com/goturkiye) +- [Golang Vancouver, BC](https://www.meetup.com/golangvan/) +- [Golang Vienna, Austria](https://www.meetup.com/viennago/) +- [Golang Москва](https://www.meetup.com/Golang-Moscow/) +- [GoSF - San Francisco, CA](https://www.meetup.com/golangsf) +- [Istanbul Golang](https://www.meetup.com/Istanbul-Golang/) +- [Lagos Gophers](https://www.meetup.com/GolangNigeria/) +- [Nairobi Gophers](https://www.meetup.com/nairobi-gophers/) +- [Seattle Go Programmers](https://www.meetup.com/golang/) +- [Ukrainian Golang User Groups](https://www.meetup.com/uagolang/) +- [Utah Go User Group](https://www.meetup.com/utahgophers/) +- [Women Who Go - San Francisco, CA](https://www.meetup.com/Women-Who-Go/) +- [Zürich Gophers - Zurich, Switzerland](https://www.meetup.com/zurich-gophers/) + +_Add the group of your city/country here (send **PR**)_ + +**[⬆ back to top](#contents)** + +## Style Guides + +- [bahlo/go-styleguide](https://github.com/bahlo/go-styleguide) +- [CockroachDB](https://github.com/cockroachdb/cockroach/blob/master/docs/style.md) +- [GitLab](https://docs.gitlab.com/ee/development/go_guide/) +- [Google](https://google.github.io/styleguide/go/) +- [Hyperledger](https://github.com/hyperledger/fabric/blob/release-1.4/docs/source/style-guides/go-style.rst) +- [Magnetico](https://github.com/boramalper/magnetico/wiki/magnetico-Design-Specification) +- [Thanos](https://thanos.io/tip/contributing/coding-style-guide.md/) +- [Trybe](https://github.com/betrybe/playbook-go/blob/main/README_EN.md) +- [Uber](https://github.com/uber-go/guide/blob/master/style.md) + +**[⬆ back to top](#contents)** + +## Social Media + +### Twitter + +- [@GoDiscussions](https://twitter.com/GoDiscussions) +- [@golang](https://twitter.com/golang) +- [@golang_news](https://twitter.com/golang_news) +- [@golangch](https://twitter.com/golangch) +- [@golangweekly](https://twitter.com/golangweekly) + +**[⬆ back to top](#contents)** + +### Reddit + +- [r/golang](https://www.reddit.com/r/golang/) + +**[⬆ back to top](#contents)** ## Websites -* [Awesome Remote Job](https://github.com/lukasz-madon/awesome-remote-job) - A curated list of awesome remote jobs. A lot of them is looking for Go hackers. -* [awesome-awesomeness](https://github.com/bayandin/awesome-awesomeness) - List of other amazingly awesome lists. -* [Flipboard - Go Magazine](https://flipboard.com/section/the-golang-magazine-bVP7nS) - A collection of Go articles and tutorials. -* [Go Blog](http://blog.golang.org) - The official Go blog -* [Go Projects](https://github.com/golang/go/wiki/Projects) - List of projects on the Go community wiki -* [godoc.org](http://godoc.org/) - Documentation for open source Go packages. -* [golang-graphics](https://github.com/mholt/golang-graphics) - A collection of Go images, graphics, and art -* [golang-nuts](https://groups.google.com/forum/#!forum/golang-nuts) - Go mailing list -* [gowalker.org](https://gowalker.org) - Go Project API documentation. -* [r/Golang](http://www.reddit.com/r/golang) - News about Go. -* [Trending Go repositories on GitHub today](https://github.com/trending?l=go) - Good place to find new Go libraries. - +- [Awesome Go @LibHunt](https://go.libhunt.com) - Your go-to Go Toolbox. +- [Awesome Golang Workshops](https://github.com/amit-davidson/awesome-golang-workshops) - A curated list of awesome golang workshops. +- [Awesome Remote Job](https://github.com/lukasz-madon/awesome-remote-job) - Curated list of awesome remote jobs. A lot of them are looking for Go hackers. +- [awesome-awesomeness](https://github.com/bayandin/awesome-awesomeness) - List of other amazingly awesome lists. +- [awesome-go-extra](https://github.com/xwjdsh/awesome-go-extra) - Parse awesome-go README file and generate a new README file with repo info. +- [Code with Mukesh](https://codewithmukesh.com/categories/golang) - Software Engineer and Blogs @ codewithmukesh.com. +- [Coding Mystery](https://codingmystery.com) - Solve exciting escape-room-inspired programming challenges using Go. +- [CodinGame](https://www.codingame.com/) - Learn Go by solving interactive tasks using small games as practical examples. +- [Go Blog](https://blog.golang.org) - The official Go blog. +- [Go Code Club](https://www.youtube.com/watch?v=nvoIPQYdx9g&list=PLEcwzBXTPUE_YQR7R0BRtHBYJ0LN3Y0i3) - A group of Gophers read and discuss a different Go project every week. +- [Go Community on Hashnode](https://hashnode.com/n/go) - Community of Gophers on Hashnode. +- [Go Forum](https://forum.golangbridge.org) - Forum to discuss Go. +- [Go Projects](https://github.com/golang/go/wiki/Projects) - List of projects on the Go community wiki. +- [Go Proverbs](https://go-proverbs.github.io/) - Go Proverbs by Rob Pike. +- [Go Report Card](https://goreportcard.com) - A report card for your Go package. +- [go.dev](https://go.dev/) - A hub for Go developers. +- [gocryforhelp](https://github.com/ninedraft/gocryforhelp) - Collection of Go projects that needs help. Good place to start your open-source way in Go. +- [Golang Developer Jobs](https://golangjob.xyz) - Developer Jobs exclusively for Golang related Roles. +- [Golang News](https://golangnews.com) - Links and news about Go programming. +- [Golang Resources](https://golangresources.com) - A curation of the best articles, exercises, talks and videos to learn Go. +- [Golang Weekly](https://discu.eu/weekly/golang/) - Each monday projects, tutorials and articles about Go. +- [golang-graphics](https://github.com/mholt/golang-graphics) - Collection of Go images, graphics, and art. +- [golang-nuts](https://groups.google.com/forum/#!forum/golang-nuts) - Go mailing list. +- [Google Plus Community](https://plus.google.com/communities/114112804251407510571) - The Google+ community for #golang enthusiasts. +- [Gopher Community Chat](https://invite.slack.golangbridge.org) - Join Our New Slack Community For Gophers ([Understand how it came](https://blog.gopheracademy.com/gophers-slack-community/)). +- [Gophercises](https://gophercises.com/) - Free coding exercises for budding gophers. +- [json2go](https://m-zajac.github.io/json2go) - Advanced JSON to Go struct conversion - online tool. +- [justforfunc](https://www.youtube.com/c/justforfunc) - Youtube channel dedicated to Go programming language tips and tricks, hosted by Francesc Campoy [@francesc](https://twitter.com/francesc). +- [Learn Go Programming](https://blog.learngoprogramming.com) - Learn Go concepts with illustrations. +- [Made with Golang](https://madewithgolang.com/?ref=awesome-go) +- [pkg.go.dev](https://pkg.go.dev/) - Documentation for open source Go packages. +- [r/Golang](https://www.reddit.com/r/golang) - News about Go. +- [studygolang](https://studygolang.com) - The community of studygolang in China. +- [Trending Go repositories on GitHub today](https://github.com/trending?l=go) - Good place to find new Go libraries. +- [TutorialEdge - Golang](https://tutorialedge.net/course/golang/) + +**[⬆ back to top](#contents)** ### Tutorials -* [A Tour of Go](http://tour.golang.org/) - Interactive tour of Go -* [Go By Example](https://gobyexample.com/) - A hands-on introduction to Go using annotated example programs -* [Working with Go](https://github.com/mkaz/working-with-go) - An intro to go for experienced programmers - - -## Windows - -* [go-ole](https://github.com/mattn/go-ole) - Win32 OLE implementation for golang - - +- [50 Shades of Go](https://devs.cloudimmunity.com/gotchas-and-common-mistakes-in-go-golang/) - Traps, Gotchas, and Common Mistakes for New Golang Devs. +- [A Comprehensive Guide to Structured Logging in Go](https://betterstack.com/community/guides/logging/logging-in-go/) - Delve deep into the world of structured logging in Go with a specific focus on recently accepted slog proposal which aims to bring high performance structured logging with levels to the standard library. +- [A Guide to Golang E-Commerce](https://snipcart.com/blog/golang-ecommerce-ponzu-cms-demo?utm_term=golang-ecommerce-ponzu-cms-demo) - Building a Golang site for e-commerce (demo included). +- [A Tour of Go](https://tour.golang.org/) - Interactive tour of Go. +- [Build a Database in 1000 lines of code]( https://link.medium.com/O9YQlx89Htb) - Build a NoSQL Database From Zero in 1000 Lines of Code. +- [Build web application with Golang](https://github.com/astaxie/build-web-application-with-golang) - Golang ebook intro how to build a web app with golang. +- [Building and Testing a REST API in Go with Gorilla Mux and PostgreSQL](https://semaphoreci.com/community/tutorials/building-and-testing-a-rest-api-in-go-with-gorilla-mux-and-postgresql) - We’ll write an API with the help of the powerful Gorilla Mux. +- [Building Go Web Applications and Microservices Using Gin](https://semaphoreci.com/community/tutorials/building-go-web-applications-and-microservices-using-gin) - Get familiar with Gin and find out how it can help you reduce boilerplate code and build a request handling pipeline. +- [Caching Slow Database Queries](https://medium.com/@rocketlaunchr.cloud/caching-slow-database-queries-1085d308a0c9) - How to cache slow database queries. +- [Canceling MySQL](https://medium.com/@rocketlaunchr.cloud/canceling-mysql-in-go-827ed8f83b30) - How to cancel MySQL queries. +- [CodeCrafters Golang Track](https://app.codecrafters.io/tracks/go) - Achieve mastery in advanced Go by building your own Redis, Docker, Git, and SQLite. Featuring goroutines, systems programming, file I/O, and more. +- [Design Patterns in Go](https://github.com/shubhamzanwar/design-patterns) - Collection of programming design patterns implemented in Go. +- [Ethereum Development with Go](https://github.com/miguelmota/ethereum-development-with-go-book) - A little e-book on Ethereum Development with Go. +- [Games With Go](https://www.youtube.com/watch?v=9D4yH7e_ea8&list=PLDZujg-VgQlZUy1iCqBbe5faZLMkA3g2x) - A video series teaching programming and game development. +- [Go By Example](https://gobyexample.com/) - Hands-on introduction to Go using annotated example programs. +- [Go Cheat Sheet](https://github.com/a8m/go-lang-cheat-sheet) - Go's reference card. +- [Go database/sql tutorial](http://go-database-sql.org/) - Introduction to database/sql. +- [Go in 7 days](https://github.com/harrytran103/7_days_of_go) - Learn everything about Go in 7 days (from a Nodejs developer). +- [Go Language Tutorial](https://www.javatpoint.com/go-tutorial) - Learn Go language Tutorial. +- [Go Tutorial](https://www.tutorialspoint.com/go/index.htm) - Learn Go programming. +- [Go WebAssembly Tutorial - Building a Simple Calculator](https://tutorialedge.net/golang/go-webassembly-tutorial/) +- [go-clean-template](https://github.com/evrone/go-clean-template) - Clean Architecture template for Golang services. +- [go-patterns](https://github.com/tmrts/go-patterns) - Curated list of Go design patterns, recipes and idioms. +- [goapp](https://github.com/naughtygopher/goapp) - An opinionated guideline to structure & develop a Go web application/service. +- [Golang for Node.js Developers](https://github.com/miguelmota/golang-for-nodejs-developers) - Examples of Golang compared to Node.js for learning. +- [Golang Tutorial Guide](https://www.freecodecamp.org/news/golang-tutorial-list-free-courses-learn-go-programming-language/) - A List of Free Courses to Learn the Go Programming Language. +- [golang-examples](https://github.com/SimonWaldherr/golang-examples) - Many examples to learn Golang. +- [Golangbot](https://golangbot.com/learn-golang-series/) - Tutorials to get started with programming in Go. +- [GopherCoding](https://gophercoding.com/) - Collection of code snippets and tutorials to help tackle every day issues. +- [GopherSnippets](https://gophersnippets.com/) - Code snippets with tests and testable examples for the Go programming language. +- [Gosamples](https://gosamples.dev/) - Collection of code snippets that let you solve everyday code problems. +- [GraphQL with Go](https://hasura.io/learn/graphql/backend-stack/languages/go/) - Learn how to create a Go GraphQL server and client with code generation. Also includes creating REST endpoints. +- [Hackr.io](https://hackr.io/tutorials/learn-golang) - Learn Go from the best online golang tutorials submitted & voted by the golang programming community. +- [Hex Monscape](https://github.com/Haraj-backend/hex-monscape) - Getting started guidelines in writing maintainable code using Hexagonal Architecture. +- [How to Benchmark: dbq vs sqlx vs GORM](https://medium.com/@rocketlaunchr.cloud/how-to-benchmark-dbq-vs-sqlx-vs-gorm-e814caacecb5) - Learn how to benchmark in Go. As a case-study, we will benchmark dbq, sqlx and GORM. +- [How To Deploy a Go Web Application with Docker](https://semaphoreci.com/community/tutorials/how-to-deploy-a-go-web-application-with-docker) - Learn how to use Docker for Go development and how to build production Docker images. +- [How to Use Godog for Behavior-driven Development in Go](https://semaphoreci.com/community/tutorials/how-to-use-godog-for-behavior-driven-development-in-go) - Get started with Godog — a Behavior-driven development framework for building and testing Go applications. +- [Learn Go with 1000+ Exercises](https://github.com/inancgumus/learngo) - Learn Go with thousands of examples, exercises, and quizzes. +- [Learn Go with TDD](https://github.com/quii/learn-go-with-tests) - Learn Go with test-driven development. +- [Learning Go by examples](https://dev.to/aurelievache/learning-go-by-examples-introduction-448n) - Series of articles in order to learn Golang language by concrete applications as example. +- [Microservices with Go](https://www.youtube.com/playlist?list=PLmD8u-IFdreyh6EUfevBcbiuCKzFk0EW_) - Dive deep into building microservices using Go, including gRPC. +- [package main](https://www.youtube.com/packagemain) - YouTube channel about Programming in Go. +- [Programming with Google Go](https://www.coursera.org/specializations/google-golang) - Coursera Specialization to learn about Go from scratch. +- [Scaling Go Applications](https://betterstack.com/community/guides/scaling-go/) - Everything about building, deploying and scaling Go applications in production. +- [The world’s easiest introduction to WebAssembly with Golang](https://medium.com/@martinolsansky/webassembly-with-golang-is-fun-b243c0e34f02) +- [Understanding Go in a visual way](https://dev.to/aurelievache/series/26234) - Learn Go visually +- [W3basic Go Tutorials](https://www.w3basic.com/golang/) - W3Basic provides an in-depth tutorial and well-organized content to learn Golang programming. +- [Working with Go](https://github.com/mkaz/working-with-go) - Intro to go for experienced programmers. +- [Your basic Go](https://yourbasic.org/golang) - Huge collection of tutorials and how to's. + +**[⬆ back to top](#contents)** + +### Guided Learning + +- [The Go Developer Roadmap](https://roadmap.sh/golang) - A visual roadmap that new Go developers can follow through to help them learn Go. +- [The Go Learning Path](https://tutorialedge.net/paths/golang/) - A guided learning path containing a mix of free and premium resources. + +**[⬆ back to top](#contents)** diff --git a/go.mod b/go.mod new file mode 100644 index 00000000000..9c0a0c9ae77 --- /dev/null +++ b/go.mod @@ -0,0 +1,22 @@ +module github.com/avelino/awesome-go + +go 1.21 + +require ( + github.com/PuerkitoBio/goquery v1.8.1 + github.com/avelino/slugify v0.0.0-20180501145920-855f152bd774 + github.com/otiai10/copy v1.14.0 + github.com/yuin/goldmark v1.6.0 + golang.org/x/oauth2 v0.15.0 +) + +require ( + github.com/andybalholm/cascadia v1.3.1 // indirect + github.com/golang/protobuf v1.5.3 // indirect + golang.org/x/net v0.23.0 // indirect + golang.org/x/sync v0.3.0 // indirect + golang.org/x/sys v0.18.0 // indirect + golang.org/x/text v0.14.0 // indirect + google.golang.org/appengine v1.6.7 // indirect + google.golang.org/protobuf v1.33.0 // indirect +) diff --git a/go.sum b/go.sum new file mode 100644 index 00000000000..95538c178ec --- /dev/null +++ b/go.sum @@ -0,0 +1,68 @@ +github.com/PuerkitoBio/goquery v1.8.1 h1:uQxhNlArOIdbrH1tr0UXwdVFgDcZDrZVdcpygAcwmWM= +github.com/PuerkitoBio/goquery v1.8.1/go.mod h1:Q8ICL1kNUJ2sXGoAhPGUdYDJvgQgHzJsnnd3H7Ho5jQ= +github.com/andybalholm/cascadia v1.3.1 h1:nhxRkql1kdYCc8Snf7D5/D3spOX+dBgjA6u8x004T2c= +github.com/andybalholm/cascadia v1.3.1/go.mod h1:R4bJ1UQfqADjvDa4P6HZHLh/3OxWWEqc0Sk8XGwHqvA= +github.com/avelino/slugify v0.0.0-20180501145920-855f152bd774 h1:HrMVYtly2IVqg9EBooHsakQ256ueojP7QuG32K71X/U= +github.com/avelino/slugify v0.0.0-20180501145920-855f152bd774/go.mod h1:5wi5YYOpfuAKwL5XLFYopbgIl/v7NZxaJpa/4X6yFKE= +github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= +github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= +github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg= +github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= +github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= +github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/otiai10/copy v1.14.0 h1:dCI/t1iTdYGtkvCuBG2BgR6KZa83PTclw4U5n2wAllU= +github.com/otiai10/copy v1.14.0/go.mod h1:ECfuL02W+/FkTWZWgQqXPWZgW9oeKCSQ5qVfSc4qc4w= +github.com/otiai10/mint v1.5.1 h1:XaPLeE+9vGbuyEHem1JNk3bYc7KKqyI/na0/mLd/Kks= +github.com/otiai10/mint v1.5.1/go.mod h1:MJm72SBthJjz8qhefc4z1PYEieWmy8Bku7CjcAqyUSM= +github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= +github.com/yuin/goldmark v1.6.0 h1:boZcn2GTjpsynOsC0iJHnBWa4Bi0qzfJjthwauItG68= +github.com/yuin/goldmark v1.6.0/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= +golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= +golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= +golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= +golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210916014120-12bc252f5db8/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= +golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= +golang.org/x/net v0.23.0 h1:7EYJ93RZ9vYSZAIb2x3lnuvqO5zneoD6IvWjuhfxjTs= +golang.org/x/net v0.23.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= +golang.org/x/oauth2 v0.15.0 h1:s8pnnxNVzjWyrvYdFUQq5llS1PX2zhPXmccZv99h7uQ= +golang.org/x/oauth2 v0.15.0/go.mod h1:q48ptWNTY5XWf+JNten23lcvHpLJ0ZSxF5ttTHKVCAM= +golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.3.0 h1:ftCYgMx6zT/asHUrPw8BLLscYtGznsLAnjq5RH9P66E= +golang.org/x/sync v0.3.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y= +golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4= +golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= +golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= +golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= +golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= +golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= +golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= +golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= +golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= +golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= +golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= +golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= +golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6c= +google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= +google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= +google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= +google.golang.org/protobuf v1.33.0 h1:uNO2rsAINq/JlFpSdYEKIZ0uKD/R9cpdv0T+yoGwGmI= +google.golang.org/protobuf v1.33.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= diff --git a/main.go b/main.go new file mode 100644 index 00000000000..5d65e75c640 --- /dev/null +++ b/main.go @@ -0,0 +1,365 @@ +// Package main contains code for generate static site. +package main + +import ( + "bytes" + "embed" + "errors" + "fmt" + template2 "html/template" + "net/url" + "os" + "path/filepath" + "text/template" + + "github.com/avelino/awesome-go/pkg/markdown" + cp "github.com/otiai10/copy" + + "github.com/PuerkitoBio/goquery" + "github.com/avelino/awesome-go/pkg/slug" +) + +// Link contains info about awesome url +type Link struct { + Title string + URL string + Description string +} + +// Category describe link category +type Category struct { + Title string + Slug string + Description string + Links []Link +} + +// Source files +const readmePath = "README.md" + +// This files should be copied 'as is' to outDir directory +var staticFiles = []string{ + "tmpl/assets", + "tmpl/robots.txt", +} + +// Templates +//go:embed tmpl/*.tmpl.html tmpl/*.tmpl.xml +var tplFs embed.FS + +var tpl = template.Must(template.ParseFS(tplFs, "tmpl/*.tmpl.html", "tmpl/*.tmpl.xml")) + +// Output files +const outDir = "out/" // NOTE: trailing slash is required + +var outIndexFile = filepath.Join(outDir, "index.html") +var outSitemapFile = filepath.Join(outDir, "sitemap.xml") + +func main() { + if err := buildStaticSite(); err != nil { + panic(err) + } +} + +func buildStaticSite() error { + if err := dropCreateDir(outDir); err != nil { + return fmt.Errorf("drop-create out dir: %w", err) + } + + if err := renderIndex(readmePath, outIndexFile); err != nil { + return fmt.Errorf("convert markdown to html: %w", err) + } + + input, err := os.ReadFile(outIndexFile) + if err != nil { + return fmt.Errorf("read converted html: %w", err) + } + + doc, err := goquery.NewDocumentFromReader(bytes.NewReader(input)) + if err != nil { + return fmt.Errorf("create goquery instance: %w", err) + } + + categories, err := extractCategories(doc) + if err != nil { + return fmt.Errorf("extract categories: %w", err) + } + + if err := renderCategories(categories); err != nil { + return fmt.Errorf("render categories: %w", err) + } + + if err := rewriteLinksInIndex(doc, categories); err != nil { + return fmt.Errorf("rewrite links in index: %w", err) + } + + if err := renderSitemap(categories); err != nil { + return fmt.Errorf("render sitemap: %w", err) + } + + for _, srcFilename := range staticFiles { + dstFilename := filepath.Join(outDir, filepath.Base(srcFilename)) + fmt.Printf("Copy static file: %s -> %s\n", srcFilename, dstFilename) + if err := cp.Copy(srcFilename, dstFilename); err != nil { + return fmt.Errorf("copy static file `%s` to `%s`: %w", srcFilename, dstFilename, err) + } + } + + return nil +} + +// dropCreateDir drop and create output directory +func dropCreateDir(dir string) error { + if err := os.RemoveAll(dir); err != nil { + return fmt.Errorf("remove dir: %w", err) + } + + if err := mkdirAll(dir); err != nil { + return fmt.Errorf("create dir: %w", err) + } + + return nil +} + +func mkdirAll(path string) error { + _, err := os.Stat(path) + // directory is exists + if err == nil { + return nil + } + + // unexpected error + if !os.IsNotExist(err) { + return fmt.Errorf("unexpected result of dir stat: %w", err) + } + + // directory is not exists + if err := os.MkdirAll(path, 0755); err != nil { + return fmt.Errorf("midirAll: %w", err) + } + + return nil +} + +func renderCategories(categories map[string]Category) error { + for _, category := range categories { + categoryDir := filepath.Join(outDir, category.Slug) + if err := mkdirAll(categoryDir); err != nil { + return fmt.Errorf("create category dir `%s`: %w", categoryDir, err) + } + + // FIXME: embed templates + categoryIndexFilename := filepath.Join(categoryDir, "index.html") + fmt.Printf("Write category Index file: %s\n", categoryIndexFilename) + + buf := bytes.NewBuffer(nil) + if err := tpl.Lookup("category-index.tmpl.html").Execute(buf, category); err != nil { + return fmt.Errorf("render category `%s`: %w", categoryDir, err) + } + + // Sanitize HTML. This is not necessary, but allows to have content + // of all html files in same style. + { + doc, err := goquery.NewDocumentFromReader(buf) + if err != nil { + return fmt.Errorf("create goquery instance for `%s`: %w", categoryDir, err) + } + + html, err := doc.Html() + if err != nil { + return fmt.Errorf("render goquery html for `%s`: %w", categoryDir, err) + } + + if err := os.WriteFile(categoryIndexFilename, []byte(html), 0644); err != nil { + return fmt.Errorf("write category file `%s`: %w", categoryDir, err) + } + } + } + + return nil +} + +func renderSitemap(categories map[string]Category) error { + f, err := os.Create(outSitemapFile) + if err != nil { + return fmt.Errorf("create sitemap file `%s`: %w", outSitemapFile, err) + } + + fmt.Printf("Render Sitemap to: %s\n", outSitemapFile) + + if err := tpl.Lookup("sitemap.tmpl.xml").Execute(f, categories); err != nil { + return fmt.Errorf("render sitemap: %w", err) + } + + return nil +} + +func extractCategories(doc *goquery.Document) (map[string]Category, error) { + categories := make(map[string]Category) + var rootErr error + + doc. + Find("body #contents"). + NextFiltered("ul"). + Find("ul"). + EachWithBreak(func(_ int, selUl *goquery.Selection) bool { + if rootErr != nil { + return false + } + + selUl. + Find("li a"). + EachWithBreak(func(_ int, s *goquery.Selection) bool { + selector, exists := s.Attr("href") + if !exists { + return true + } + + category, err := extractCategory(doc, selector) + if err != nil { + rootErr = fmt.Errorf("extract category: %w", err) + return false + } + + categories[selector] = *category + + return true + }) + + return true + }) + + if rootErr != nil { + return nil, fmt.Errorf("extract categories: %w", rootErr) + } + + return categories, nil +} + +func extractCategory(doc *goquery.Document, selector string) (*Category, error) { + var category Category + var err error + + doc.Find(selector).EachWithBreak(func(_ int, selCatHeader *goquery.Selection) bool { + selDescr := selCatHeader.NextFiltered("p") + // FIXME: bug. this would select links from all neighboring + // sub-categories until the next category. To prevent this we should + // find only first ul + ul := selCatHeader.NextFilteredUntil("ul", "h2") + + var links []Link + ul.Find("li").Each(func(_ int, selLi *goquery.Selection) { + selLink := selLi.Find("a") + url, _ := selLink.Attr("href") + link := Link{ + Title: selLink.Text(), + // FIXME(kazhuravlev): Title contains only title but + // description contains Title + description + Description: selLi.Text(), + URL: url, + } + links = append(links, link) + }) + + // FIXME: In this case we would have an empty category in main index.html with link to 404 page. + if len(links) == 0 { + err = errors.New("category does not contain links") + return false + } + + category = Category{ + Slug: slug.Generate(selCatHeader.Text()), + Title: selCatHeader.Text(), + Description: selDescr.Text(), + Links: links, + } + + return true + }) + + if err != nil { + return nil, fmt.Errorf("build a category: %w", err) + } + + return &category, nil +} + +func rewriteLinksInIndex(doc *goquery.Document, categories map[string]Category) error { + var iterErr error + doc. + Find("body #content ul li ul li a"). + EachWithBreak(func(_ int, s *goquery.Selection) bool { + href, hrefExists := s.Attr("href") + if !hrefExists { + // FIXME: looks like is an error. Tag `a` in our case always + // should have `href` attr. + return true + } + + // do not replace links if no page has been created for it + _, catExists := categories[href] + if !catExists { + return true + } + + linkURL, err := url.Parse(href) + if err != nil { + iterErr = err + return false + } + + if linkURL.Fragment != "" && linkURL.Fragment != "contents" { + s.SetAttr("href", linkURL.Fragment) + } + + return true + }) + + if iterErr != nil { + return iterErr + } + + fmt.Printf("Rewrite links in Index file: %s\n", outIndexFile) + resultHTML, err := doc.Html() + if err != nil { + return fmt.Errorf("render html: %w", err) + } + + if err := os.WriteFile(outIndexFile, []byte(resultHTML), 0644); err != nil { + return fmt.Errorf("rewrite index file: %w", err) + } + + return nil +} + +// renderIndex generate site html (index.html) from markdown file +func renderIndex(srcFilename, outFilename string) error { + input, err := os.ReadFile(srcFilename) + if err != nil { + return err + } + + body, err := markdown.ToHTML(input) + if err != nil { + return err + } + + f, err := os.Create(outFilename) + if err != nil { + return err + } + + fmt.Printf("Write Index file: %s\n", outIndexFile) + data := map[string]interface{}{ + "Body": template2.HTML(body), + } + if err := tpl.Lookup("index.tmpl.html").Execute(f, data); err != nil { + return err + } + + if err := f.Close(); err != nil { + return fmt.Errorf("close index file: %w", err) + } + + return nil +} diff --git a/main_test.go b/main_test.go new file mode 100644 index 00000000000..3d59d22a243 --- /dev/null +++ b/main_test.go @@ -0,0 +1,135 @@ +package main + +import ( + "bytes" + "github.com/avelino/awesome-go/pkg/markdown" + "os" + "regexp" + "sort" + "strings" + "testing" + + "github.com/PuerkitoBio/goquery" +) + +var ( + reContainsLink = regexp.MustCompile(`\* \[.*\]\(.*\)`) + reOnlyLink = regexp.MustCompile(`\* \[.*\]\([^()]*\)$`) + reLinkWithDescription = regexp.MustCompile(`\* \[.*\]\(.*\) - \S.*[\.\!]`) +) + +func requireNoErr(t *testing.T, err error, msg string) { + // FIXME: replace to github.com/stretchr/testify + t.Helper() + + if msg == "" { + msg = "unknown error" + } + + if err != nil { + t.Fatalf("Received unexpected error [%s]: %+v", msg, err) + } +} + +func goqueryFromReadme(t *testing.T) *goquery.Document { + t.Helper() + + input, err := os.ReadFile(readmePath) + requireNoErr(t, err, "readme file should be exists") + + html, err := markdown.ToHTML(input) + requireNoErr(t, err, "markdown should be rendered to html") + + buf := bytes.NewBuffer(html) + doc, err := goquery.NewDocumentFromReader(buf) + requireNoErr(t, err, "html must be valid for goquery") + + return doc +} + +func TestAlpha(t *testing.T) { + doc := goqueryFromReadme(t) + doc.Find("body > ul").Each(func(i int, s *goquery.Selection) { + if i != 0 { + // skip content menu + // TODO: the sub items (with 3 hash marks `###`) are staying in + // the main list, not respecting the hierarchy and making it + // impossible to test the alphabetical order + testList(t, s) + } + }) +} + +func TestDuplicatedLinks(t *testing.T) { + doc := goqueryFromReadme(t) + links := make(map[string]bool, 0) + doc.Find("body li > a:first-child").Each(func(_ int, s *goquery.Selection) { + t.Run(s.Text(), func(t *testing.T) { + href, ok := s.Attr("href") + if !ok { + t.Error("expected to have href") + } + if links[href] { + t.Fatalf("duplicated link '%s'", href) + } + links[href] = true + }) + }) +} + +// Test if an entry has description, it must be separated from link with ` - ` +func TestSeparator(t *testing.T) { + var matched, containsLink, noDescription bool + input, err := os.ReadFile(readmePath) + requireNoErr(t, err, "readme should be exists") + + lines := strings.Split(string(input), "\n") + for _, line := range lines { + line = strings.Trim(line, " ") + containsLink = reContainsLink.MatchString(line) + if containsLink { + noDescription = reOnlyLink.MatchString(line) + if noDescription { + continue + } + matched = reLinkWithDescription.MatchString(line) + if !matched { + t.Errorf("expected entry to be in form of `* [link] - description.`, got '%s'", line) + } + } + } +} + +func TestRenderIndex(t *testing.T) { + requireNoErr(t, mkdirAll(outDir), "output dir should exists") + + err := renderIndex(readmePath, outIndexFile) + requireNoErr(t, err, "html should be rendered") +} + +func testList(t *testing.T, list *goquery.Selection) { + list.Find("ul").Each(func(_ int, items *goquery.Selection) { + testList(t, items) + items.RemoveFiltered("ul") + }) + t.Run(list.Prev().Text(), func(t *testing.T) { + checkAlphabeticOrder(t, list) + }) +} + +func checkAlphabeticOrder(t *testing.T, s *goquery.Selection) { + items := s.Find("li > a:first-child").Map(func(_ int, li *goquery.Selection) string { + return strings.ToLower(li.Text()) + }) + sorted := make([]string, len(items)) + copy(sorted, items) + sort.Strings(sorted) + for k, item := range items { + if item != sorted[k] { + t.Errorf("expected '%s' but actual is '%s'", sorted[k], item) + } + } + if t.Failed() { + t.Logf("expected order is:\n%s", strings.Join(sorted, "\n")) + } +} diff --git a/netlify.toml b/netlify.toml new file mode 100644 index 00000000000..8a87f9546ec --- /dev/null +++ b/netlify.toml @@ -0,0 +1,47 @@ +# Settings in the [build] context are global and are applied to +# all contexts unless otherwise overridden by more specific contexts. +[build] +# Directory to change to before starting a build. +# This is where we will look for package.json/.nvmrc/etc. +# If not set, defaults to the root directory. +base = "./" + +# Directory that contains the deploy-ready HTML files and +# assets generated by the build. This is relative to the base +# directory if one has been set, or the root directory if +# a base has not been set. This sample publishes the directory +# located at the absolute path "root/project/build-output" + +publish = "out/" + +# Default build command. +command = "echo 'default context'" + +[[plugins]] +# Installs the Lighthouse Build Plugin for all deploy contexts +package = "@netlify/plugin-lighthouse" + +# Production context: all deploys from the Production branch +# set in your site’s Branches settings in the UI will inherit +# these settings. You can define environment variables +# here but we recommend using the Netlify UI for sensitive +# values to keep them out of your source repository. +[context.production] +publish = "out/" + +# Redirects and headers are GLOBAL for all builds – they do not +# get scoped to contexts no matter where you define them in the file. +# For context-specific rules, use _headers or _redirects files, +# which are PER-DEPLOY. + +[[redirects]] +from = "/awesome-cloud-native" +to = "/" +status = 302 +force = true + +[[redirects]] +from = "/awesome-go-fork" +to = "/" +status = 302 +force = true diff --git a/pkg/markdown/convert.go b/pkg/markdown/convert.go new file mode 100644 index 00000000000..31a77e5e508 --- /dev/null +++ b/pkg/markdown/convert.go @@ -0,0 +1,53 @@ +package markdown + +import ( + "bytes" + + "github.com/avelino/awesome-go/pkg/slug" + "github.com/yuin/goldmark" + "github.com/yuin/goldmark/ast" + "github.com/yuin/goldmark/extension" + "github.com/yuin/goldmark/parser" + "github.com/yuin/goldmark/renderer/html" + "github.com/yuin/goldmark/util" +) + +// ToHTML converts markdown byte slice to a HTML byte slice +func ToHTML(markdown []byte) ([]byte, error) { + md := goldmark.New( + goldmark.WithExtensions(extension.GFM), + goldmark.WithParserOptions( + parser.WithAutoHeadingID(), // generate heading IDs for content navigation + ), + goldmark.WithRendererOptions( + html.WithXHTML(), + html.WithUnsafe(), // allow inline HTML + ), + ) + + ctx := parser.NewContext( + parser.WithIDs(&IDGenerator{}), // register custom ID generator + ) + + var buf bytes.Buffer + if err := md.Convert(markdown, &buf, parser.WithContext(ctx)); err != nil { + return nil, err + } + + return buf.Bytes(), nil +} + +// IDGenerator for goldmark to provide IDs more similar to GitHub's IDs on markdown parsing +type IDGenerator struct { + used map[string]bool +} + +// Generate an ID +func (g *IDGenerator) Generate(value []byte, _ ast.NodeKind) []byte { + return []byte(slug.Generate(string(value))) +} + +// Put an ID to the list of already used IDs +func (g *IDGenerator) Put(value []byte) { + g.used[util.BytesToReadOnlyString(value)] = true +} diff --git a/pkg/markdown/convert_test.go b/pkg/markdown/convert_test.go new file mode 100644 index 00000000000..9f2c58c25bc --- /dev/null +++ b/pkg/markdown/convert_test.go @@ -0,0 +1,57 @@ +package markdown + +import ( + "strings" + "testing" +) + +func TestToHTML(t *testing.T) { + input := []byte( + `## some headline +followed by some paragraph with [a link](https://example.local) +and some list: +- first +- second + - nested on second level + - nested on third level + - ~~strikethrough~~ + - yet another second level item, **but** with a [a link](https://example.local) +- end + +### h3 headline/header + +embedded HTML is allowed + `, + ) + expected := []byte( + `

some headline

+

followed by some paragraph with a link +and some list:

+
    +
  • first
  • +
  • second +
      +
    • nested on second level +
        +
      • nested on third level
      • +
      • strikethrough
      • +
      +
    • +
    • yet another second level item, but with a a link
    • +
    +
  • +
  • end
  • +
+

h3 headline/header

+

embedded HTML is allowed

`, + ) + + got, err := ToHTML(input) + if err != nil { + t.Errorf("ToHTML() error = %v", err) + return + } + if strings.TrimSpace(string(got)) != strings.TrimSpace(string(expected)) { + t.Errorf("ToHTML() got = %v, want %v", string(got), string(expected)) + } +} diff --git a/pkg/slug/generator.go b/pkg/slug/generator.go new file mode 100644 index 00000000000..d2f79403c84 --- /dev/null +++ b/pkg/slug/generator.go @@ -0,0 +1,14 @@ +package slug + +import ( + "strings" + + "github.com/avelino/slugify" +) + +// Generate slugs similar to GitHub's slugs on markdown parsing +func Generate(text string) string { + // FIXME: this is should be like regexp.Replace(`[^-a-zA-Z\d]+`, ``) + s := strings.ReplaceAll(text, "/", "") + return slugify.Slugify(strings.TrimSpace(s)) +} diff --git a/pkg/slug/generator_test.go b/pkg/slug/generator_test.go new file mode 100644 index 00000000000..680ee332828 --- /dev/null +++ b/pkg/slug/generator_test.go @@ -0,0 +1,39 @@ +package slug + +import "testing" + +func TestGenerate(t *testing.T) { + tests := []struct { + name string + input string + expected string + }{ + { + name: "with spaces", + input: "some string with spaces", + expected: "some-string-with-spaces", + }, + { + name: "with out any non-literal chars", + input: "inputstring", + expected: "inputstring", + }, + { + name: "with whitespace prefix and suffix", + input: " inputstring ", + expected: "inputstring", + }, + { + name: "a mix of special characters", + input: " an input string (with.special/chars,such_as:§\\?$/§&!) ", + expected: "an-input-string-with-specialchars-such-as", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if got := Generate(tt.input); got != tt.expected { + t.Errorf("Generate() = %v, want %v", got, tt.expected) + } + }) + } +} diff --git a/repo.go b/repo.go deleted file mode 100644 index e0281bfd25d..00000000000 --- a/repo.go +++ /dev/null @@ -1 +0,0 @@ -package repo diff --git a/repo_test.go b/repo_test.go deleted file mode 100644 index 3386d7a3ee2..00000000000 --- a/repo_test.go +++ /dev/null @@ -1,66 +0,0 @@ -package repo - -import ( - "bytes" - "io/ioutil" - "log" - "sort" - "strings" - "testing" - - "github.com/PuerkitoBio/goquery" - "github.com/russross/blackfriday" -) - -func TestAlpha(t *testing.T) { - query := startQuery() - - query.Find("body > ul").Each(func(_ int, s *goquery.Selection) { - testList(t, s) - }) -} - -func testList(t *testing.T, list *goquery.Selection) { - list.Find("ul").Each(func(_ int, items *goquery.Selection) { - testList(t, items) - items.RemoveFiltered("ul") - }) - checkAlphabeticOrder(t, list) -} - -func readme() []byte { - input, err := ioutil.ReadFile("./README.md") - if err != nil { - panic(err) - } - html := append([]byte(""), blackfriday.MarkdownCommon(input)...) - html = append(html, []byte("")...) - return html -} - -func startQuery() *goquery.Document { - buf := bytes.NewBuffer(readme()) - query, err := goquery.NewDocumentFromReader(buf) - if err != nil { - panic(err) - } - - return query -} - -func checkAlphabeticOrder(t *testing.T, s *goquery.Selection) { - items := s.Find("li > a:first-child").Map(func(_ int, li *goquery.Selection) string { - return strings.ToLower(li.Text()) - }) - - sorted := make([]string, len(items)) - copy(sorted, items) - sort.Strings(sorted) - - for k, item := range items { - if item != sorted[k] { - log.Printf("expected '%s' but actual is '%s'", sorted[k], item) - t.Fail() - } - } -} diff --git a/stale_repositories_test.go b/stale_repositories_test.go new file mode 100644 index 00000000000..20b013ff55c --- /dev/null +++ b/stale_repositories_test.go @@ -0,0 +1,316 @@ +package main + +import ( + "bytes" + "context" + "encoding/json" + "fmt" + "log" + "net/http" + "os" + "regexp" + "strings" + "testing" + "text/template" + "time" + + "github.com/PuerkitoBio/goquery" + "golang.org/x/oauth2" +) + +const issueTemplateContent = ` +{{range .}} +- [ ] {{.}} +{{end}} +` + +var issueTemplate = template.Must(template.New("issue").Parse(issueTemplateContent)) + +// FIXME: use official github client +var reGithubRepo = regexp.MustCompile("https://github.com/[a-zA-Z0-9-._]+/[a-zA-Z0-9-._]+$") +var githubGETREPO = "https://api.github.com/repos%s" +var githubGETCOMMITS = "https://api.github.com/repos%s/commits" +var githubPOSTISSUES = "https://api.github.com/repos/avelino/awesome-go/issues" + +// FIXME: use https +var awesomeGoGETISSUES = "http://api.github.com/repos/avelino/awesome-go/issues" //only returns open issues +// FIXME: variable has type Duration, but contains a number. we should use +// +// time.Hour * ... or change type of variable +var numberOfYears time.Duration = 1 +var timeNow = time.Now() +var issueTitle = fmt.Sprintf("Investigate repositories with more than 1 year without update - %s", timeNow.Format(time.DateOnly)) + +const deadLinkMessage = " this repository might no longer exist! (status code >= 400 returned)" +const movedPermanently = " status code 301 received" +const status302 = " status code 302 received" +const archived = " repository has been archived" + +// LIMIT specifies the max number of repositories that are added in a single run of the script +var LIMIT = 10 +var ctr = 0 + +type tokenSource struct { + AccessToken string +} + +type issue struct { + Title string `json:"title"` + Body string `json:"body"` +} + +func (t *tokenSource) Token() (*oauth2.Token, error) { + return &oauth2.Token{ + AccessToken: t.AccessToken, + }, nil +} + +func getRepositoriesFromBody(body string) []string { + links := strings.Split(body, "- ") + for i, link := range links { + link = strings.ReplaceAll(link, "\r", "") + link = strings.ReplaceAll(link, "[ ]", "") + link = strings.ReplaceAll(link, "[x]", "") + link = strings.ReplaceAll(link, " ", "") + link = strings.ReplaceAll(link, "\n", "") + link = strings.ReplaceAll(link, deadLinkMessage, "") + link = strings.ReplaceAll(link, movedPermanently, "") + link = strings.ReplaceAll(link, status302, "") + link = strings.ReplaceAll(link, archived, "") + links[i] = link + } + + return links +} + +func generateIssueBody(t *testing.T, repositories []string) (string, error) { + t.Helper() + + buf := bytes.NewBuffer(nil) + err := issueTemplate.Execute(buf, repositories) + requireNoErr(t, err, "Failed to generate template") + + return buf.String(), nil +} + +func createIssue(t *testing.T, staleRepos []string, client *http.Client) { + t.Helper() + + if len(staleRepos) == 0 { + log.Print("NO STALE REPOSITORIES") + return + } + + body, err := generateIssueBody(t, staleRepos) + requireNoErr(t, err, "failed to generate issue body") + + newIssue := &issue{ + Title: issueTitle, + Body: body, + } + buf := bytes.NewBuffer(nil) + requireNoErr(t, json.NewEncoder(buf).Encode(newIssue), "failed to encode json req") + + req, err := http.NewRequest(http.MethodPost, githubPOSTISSUES, buf) + requireNoErr(t, err, "failed to create request") + + _, roundTripErr := client.Do(req) + requireNoErr(t, roundTripErr, "failed to send request") +} + +func getAllFlaggedRepositories(t *testing.T, client *http.Client) map[string]bool { + t.Helper() + + req, err := http.NewRequest(http.MethodGet, awesomeGoGETISSUES, nil) + requireNoErr(t, err, "failed to create request") + + res, err := client.Do(req) + requireNoErr(t, err, "failed to send request") + + defer res.Body.Close() + + var issues []issue + requireNoErr(t, json.NewDecoder(res.Body).Decode(&issues), "failed to unmarshal response") + + addressedRepositories := make(map[string]bool) + for _, issue := range issues { + if issue.Title != issueTitle { + continue + } + + repos := getRepositoriesFromBody(issue.Body) + for _, repo := range repos { + addressedRepositories[repo] = true + } + } + + return addressedRepositories +} + +func checkRepoAvailability(toRun bool, href string, client *http.Client) ([]string, bool) { + if !toRun { + return nil, false + } + + ownerRepo := strings.ReplaceAll(href, "https://github.com", "") + apiCall := fmt.Sprintf(githubGETREPO, ownerRepo) + req, err := http.NewRequest(http.MethodGet, apiCall, nil) + if err != nil { + log.Printf("Failed at repository %s\n", href) + return nil, false + } + + resp, err := client.Do(req) + if err != nil { + log.Printf("Failed at repository %s\n", href) + return nil, false + } + + defer resp.Body.Close() + + var repoResp struct { + Archived bool `json:"archived"` + } + + if err := json.NewDecoder(resp.Body).Decode(&repoResp); err != nil { + return nil, false + } + + var isRepoAdded bool + + var warnings []string + if resp.StatusCode == http.StatusMovedPermanently { + warnings = append(warnings, href+movedPermanently) + log.Printf("%s returned %d", href, resp.StatusCode) + isRepoAdded = true + } + + if resp.StatusCode == http.StatusFound && !isRepoAdded { + warnings = append(warnings, href+status302) + log.Printf("%s returned %d", href, resp.StatusCode) + isRepoAdded = true + } + + if resp.StatusCode >= http.StatusBadRequest && !isRepoAdded { + warnings = append(warnings, href+deadLinkMessage) + log.Printf("%s might not exist!", href) + isRepoAdded = true + } + + if repoResp.Archived && !isRepoAdded { + warnings = append(warnings, href+archived) + log.Printf("%s is archived!", href) + isRepoAdded = true + } + + // FIXME: expression `(len(warnings) > 0) == isRepoAdded` is always true. + return warnings, isRepoAdded +} + +func checkRepoCommitActivity(toRun bool, href string, client *http.Client) ([]string, bool) { + if !toRun { + return nil, false + } + + ownerRepo := strings.ReplaceAll(href, "https://github.com", "") + apiCall := fmt.Sprintf(githubGETCOMMITS, ownerRepo) + req, err := http.NewRequest(http.MethodGet, apiCall, nil) + if err != nil { + log.Printf("Failed at repository %s\n", href) + return nil, false + } + + since := timeNow.Add(-1 * 365 * 24 * numberOfYears * time.Hour) + sinceQuery := since.Format(time.RFC3339) + + q := req.URL.Query() + q.Add("since", sinceQuery) + req.URL.RawQuery = q.Encode() + + resp, err := client.Do(req) + if err != nil { + log.Printf("Failed at repository %s\n", href) + return nil, false + } + + defer resp.Body.Close() + + var respObj []map[string]interface{} + // FIXME: handle error in all that cases + if err := json.NewDecoder(resp.Body).Decode(&respObj); err != nil { + return nil, false + } + + var warnings []string + var isRepoAdded bool + isAged := len(respObj) == 0 + if isAged { + log.Printf("%s has not had a commit in a while", href) + warnings = append(warnings, href) + isRepoAdded = true + } + + // FIXME: expression `(len(warnings) > 0) == isRepoAdded` is always true. + return warnings, isRepoAdded +} + +func TestStaleRepository(t *testing.T) { + doc := goqueryFromReadme(t) + + oauth := os.Getenv("OAUTH_TOKEN") + client := &http.Client{ + Transport: &http.Transport{}, + } + + if oauth == "" { + log.Print("No oauth token found. Using unauthenticated client ...") + } else { + tokenSource := &tokenSource{ + AccessToken: oauth, + } + client = oauth2.NewClient(context.Background(), tokenSource) + } + + // FIXME: return addressedRepositories, no need to pass + addressedRepositories := getAllFlaggedRepositories(t, client) + + var staleRepos []string + doc. + Find("body li > a:first-child"). + EachWithBreak(func(_ int, s *goquery.Selection) bool { + href, ok := s.Attr("href") + if !ok { + log.Println("expected to have href") + return true + } + + if ctr >= LIMIT && LIMIT != -1 { + log.Print("Max number of issues created") + return false + } + + if _, issueExists := addressedRepositories[href]; issueExists { + log.Printf("issue already exists for %s\n", href) + return true + } + + if !reGithubRepo.MatchString(href) { + log.Printf("%s non-github repo not currently handled", href) + } + + // FIXME: this is `or` expres24sion. Probably we need `and`? + warnings, isRepoAdded := checkRepoAvailability(true, href, client) + staleRepos = append(staleRepos, warnings...) + + warnings, isRepoAdded = checkRepoCommitActivity(!isRepoAdded, href, client) + staleRepos = append(staleRepos, warnings...) + + if isRepoAdded { + ctr++ + } + + return true + }) + + createIssue(t, staleRepos, client) +} diff --git a/tmpl/assets/awesome-go.css b/tmpl/assets/awesome-go.css new file mode 100644 index 00000000000..e0e5011b8a7 --- /dev/null +++ b/tmpl/assets/awesome-go.css @@ -0,0 +1,120 @@ +* { + max-width: 100%; + box-sizing: border-box; + font-family: "Fira Sans"; + text-decoration: none; + font-weight: 300; +} +.awesome-logo { + max-width: 500px; + width: 100%; + margin: auto; + display: block; +} + +a { + color: #669; +} +a:visited, h1, h2, h3, h4 { + color: #494368; + font-weight: 400; +} +h1 > a:nth-child(1) { + margin-left: 10px; +} +h1 > a img { + padding-right: 5px; +} + +#content { + width: 100%; + padding: 40px 80px; +} + +@media (max-width: 720px) { + #content { + padding: 20px 40px; + } +} +@media (max-width: 420px) { + #content * { + word-wrap: break-word; + } +} + +/** ADs + * */ +#ads { + max-width: 330px; + width: 100%; + margin: auto; + margin-top: auto; + margin-right: auto; + margin-bottom: auto; + margin-left: auto; + display: block; +} + +#carbonads { + font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, + Cantarell, "Helvetica Neue", Helvetica, Arial, sans-serif; +} + +#carbonads { + display: flex; + max-width: 330px; + background-color: hsl(0, 0%, 98%); + box-shadow: 0 1px 4px 1px hsla(0, 0%, 0%, .1); +} + +#carbonads a { + color: inherit; + text-decoration: none; +} + +#carbonads a:hover { + color: inherit; +} + +#carbonads span { + position: relative; + display: block; + overflow: hidden; +} + +#carbonads .carbon-wrap { + display: flex; +} + +.carbon-img { + display: block; + margin: 0; + line-height: 1; +} + +.carbon-img img { + display: block; +} + +.carbon-text { + font-size: 13px; + padding: 10px; + line-height: 1.5; + text-align: left; +} + +.carbon-poweredby { + display: block; + padding: 8px 10px; + background: repeating-linear-gradient(-45deg, transparent, transparent 5px, hsla(0, 0%, 0%, .025) 5px, hsla(0, 0%, 0%, .025) 10px) hsla(203, 11%, 95%, .4); + text-align: center; + text-transform: uppercase; + letter-spacing: .5px; + font-weight: 600; + font-size: 9px; + line-height: 1; +} + +td { + padding: 6px; +} diff --git a/tmpl/assets/favicon/android-chrome-192x192.png b/tmpl/assets/favicon/android-chrome-192x192.png new file mode 100644 index 00000000000..9596cfcbc6b Binary files /dev/null and b/tmpl/assets/favicon/android-chrome-192x192.png differ diff --git a/tmpl/assets/favicon/android-chrome-512x512.png b/tmpl/assets/favicon/android-chrome-512x512.png new file mode 100644 index 00000000000..84fe314b29a Binary files /dev/null and b/tmpl/assets/favicon/android-chrome-512x512.png differ diff --git a/tmpl/assets/favicon/apple-touch-icon.png b/tmpl/assets/favicon/apple-touch-icon.png new file mode 100644 index 00000000000..18c182f40d5 Binary files /dev/null and b/tmpl/assets/favicon/apple-touch-icon.png differ diff --git a/tmpl/assets/favicon/favicon.ico b/tmpl/assets/favicon/favicon.ico new file mode 100644 index 00000000000..1eba1ab979e Binary files /dev/null and b/tmpl/assets/favicon/favicon.ico differ diff --git a/tmpl/assets/favicon/manifest.json b/tmpl/assets/favicon/manifest.json new file mode 100644 index 00000000000..2d423ac6598 --- /dev/null +++ b/tmpl/assets/favicon/manifest.json @@ -0,0 +1,19 @@ +{ + "name": "Awesome Go", + "short_name": "Awesome-Go", + "icons": [ + { + "src": "./android-chrome-192x192.png", + "sizes": "192x192", + "type": "image/png" + }, + { + "src": "./android-chrome-512x512.png", + "sizes": "512x512", + "type": "image/png" + } + ], + "theme_color": "#ffffff", + "background_color": "#ffffff", + "display": "standalone" +} diff --git a/tmpl/assets/fonts/firasans.css b/tmpl/assets/fonts/firasans.css new file mode 100644 index 00000000000..b52258d7dd3 --- /dev/null +++ b/tmpl/assets/fonts/firasans.css @@ -0,0 +1,140 @@ +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans ExtraLight'), + local('FiraSans-ExtraLight'), + url('/assets/fonts/firasansextralight.woff2') format('woff2'), + url('/assets/fonts/firasansextralight.woff') format('woff'), + url('/assets/fonts/firasansextralight.ttf') format('truetype'); + font-weight: 100; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans ExtraLight Italic'), + local('FiraSans-ExtraLightItalic'), + url('/assets/fonts/firasansextralightitalic.woff2') format('woff2'), + url('/assets/fonts/firasansextralightitalic.woff') format('woff'), + url('/assets/fonts/firasansextralightitalic.ttf') format('truetype'); + font-weight: 100; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Light'), + local('FiraSans-Light'), + url('/assets/fonts/firasanslight.woff2') format('woff2'), + url('/assets/fonts/firasanslight.woff') format('woff'), + url('/assets/fonts/firasanslight.ttf') format('truetype'); + font-weight: 200; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Light Italic'), + local('FiraSans-LightItalic'), + url('/assets/fonts/firasanslightitalic.woff2') format('woff2'), + url('/assets/fonts/firasanslightitalic.woff') format('woff'), + url('/assets/fonts/firasanslightitalic.ttf') format('truetype'); + font-weight: 200; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Book'), + local('FiraSans-Book'), + url('/assets/fonts/firasansbook.woff2') format('woff2'), + url('/assets/fonts/firasansbook.woff') format('woff'), + url('/assets/fonts/firasansbook.ttf') format('truetype'); + font-weight: 300; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Book Italic'), + local('FiraSans-BookItalic'), + url('/assets/fonts/firasansbookitalic.woff2') format('woff2'), + url('/assets/fonts/firasansbookitalic.woff') format('woff'), + url('/assets/fonts/firasansbookitalic.ttf') format('truetype'); + font-weight: 300; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans'), + local('FiraSans-Regular'), + url('/assets/fonts/firasans.woff2') format('woff2'), + url('/assets/fonts/firasans.woff') format('woff'), + url('/assets/fonts/firasans.ttf') format('truetype'); + font-weight: 400; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Italic'), + local('FiraSans-Italic'), + url('/assets/fonts/firasansitalic.woff2') format('woff2'), + url('/assets/fonts/firasansitalic.woff') format('woff'), + url('/assets/fonts/firasansitalic.ttf') format('truetype'); + font-weight: 400; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Medium'), + local('FiraSans-Medium'), + url('/assets/fonts/firasansmedium.woff2') format('woff2'), + url('/assets/fonts/firasansmedium.woff') format('woff'), + url('/assets/fonts/firasansmedium.ttf') format('truetype'); + font-weight: 500; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Medium Italic'), + local('FiraSans-MediumItalic'), + url('/assets/fonts/firasansmediumitalic.woff2') format('woff2'), + url('/assets/fonts/firasansmediumitalic.woff') format('woff'), + url('/assets/fonts/firasansmediumitalic.ttf') format('truetype'); + font-weight: 500; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans SemiBold'), + local('FiraSans-SemiBold'), + url('/assets/fonts/firasanssemibold.woff2') format('woff2'), + url('/assets/fonts/firasanssemibold.woff') format('woff'), + url('/assets/fonts/firasanssemibold.ttf') format('truetype'); + font-weight: 600; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans SemiBold Italic'), + local('FiraSans-SemiBoldItalic'), + url('/assets/fonts/firasanssemibolditalic.woff2') format('woff2'), + url('/assets/fonts/firasanssemibolditalic.woff') format('woff'), + url('/assets/fonts/firasanssemibolditalic.ttf') format('truetype'); + font-weight: 600; + font-style: italic; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Bold'), + local('FiraSans-Bold'), + url('/assets/fonts/firasansbold.woff2') format('woff2'), + url('/assets/fonts/firasansbold.woff') format('woff'), + url('/assets/fonts/firasansbold.ttf') format('truetype'); + font-weight: 700; + font-style: normal; +} +@font-face { + font-family: 'Fira Sans'; + src: local('Fira Sans Bold Italic'), + local('FiraSans-BoldItalic'), + url('/assets/fonts/firasansbolditalic.woff2') format('woff2'), + url('/assets/fonts/firasansbolditalic.woff') format('woff'), + url('/assets/fonts/firasansbolditalic.ttf') format('truetype'); + font-weight: 700; + font-style: italic; +} diff --git a/tmpl/assets/fonts/firasans.ttf b/tmpl/assets/fonts/firasans.ttf new file mode 100644 index 00000000000..5ea949d23c0 Binary files /dev/null and b/tmpl/assets/fonts/firasans.ttf differ diff --git a/tmpl/assets/fonts/firasans.woff b/tmpl/assets/fonts/firasans.woff new file mode 100644 index 00000000000..5259871cc3b Binary files /dev/null and b/tmpl/assets/fonts/firasans.woff differ diff --git a/tmpl/assets/fonts/firasans.woff2 b/tmpl/assets/fonts/firasans.woff2 new file mode 100644 index 00000000000..b28d3362ca2 Binary files /dev/null and b/tmpl/assets/fonts/firasans.woff2 differ diff --git a/tmpl/assets/fonts/firasansbold.ttf b/tmpl/assets/fonts/firasansbold.ttf new file mode 100644 index 00000000000..bcf62411d2b Binary files /dev/null and b/tmpl/assets/fonts/firasansbold.ttf differ diff --git a/tmpl/assets/fonts/firasansbold.woff b/tmpl/assets/fonts/firasansbold.woff new file mode 100644 index 00000000000..dae100fbe0f Binary files /dev/null and b/tmpl/assets/fonts/firasansbold.woff differ diff --git a/tmpl/assets/fonts/firasansbold.woff2 b/tmpl/assets/fonts/firasansbold.woff2 new file mode 100644 index 00000000000..05c5da2f507 Binary files /dev/null and b/tmpl/assets/fonts/firasansbold.woff2 differ diff --git a/tmpl/assets/fonts/firasansbolditalic.ttf b/tmpl/assets/fonts/firasansbolditalic.ttf new file mode 100644 index 00000000000..fab739eb102 Binary files /dev/null and b/tmpl/assets/fonts/firasansbolditalic.ttf differ diff --git a/tmpl/assets/fonts/firasansbolditalic.woff b/tmpl/assets/fonts/firasansbolditalic.woff new file mode 100644 index 00000000000..48ca8dccde9 Binary files /dev/null and b/tmpl/assets/fonts/firasansbolditalic.woff differ diff --git a/tmpl/assets/fonts/firasansbolditalic.woff2 b/tmpl/assets/fonts/firasansbolditalic.woff2 new file mode 100644 index 00000000000..426dda7b106 Binary files /dev/null and b/tmpl/assets/fonts/firasansbolditalic.woff2 differ diff --git a/tmpl/assets/fonts/firasansbook.ttf b/tmpl/assets/fonts/firasansbook.ttf new file mode 100644 index 00000000000..8bfe3037be1 Binary files /dev/null and b/tmpl/assets/fonts/firasansbook.ttf differ diff --git a/tmpl/assets/fonts/firasansbook.woff b/tmpl/assets/fonts/firasansbook.woff new file mode 100644 index 00000000000..239780f979b Binary files /dev/null and b/tmpl/assets/fonts/firasansbook.woff differ diff --git a/tmpl/assets/fonts/firasansbook.woff2 b/tmpl/assets/fonts/firasansbook.woff2 new file mode 100644 index 00000000000..2d880f92754 Binary files /dev/null and b/tmpl/assets/fonts/firasansbook.woff2 differ diff --git a/tmpl/assets/fonts/firasansbookitalic.ttf b/tmpl/assets/fonts/firasansbookitalic.ttf new file mode 100644 index 00000000000..d4b76ed459c Binary files /dev/null and b/tmpl/assets/fonts/firasansbookitalic.ttf differ diff --git a/tmpl/assets/fonts/firasansbookitalic.woff b/tmpl/assets/fonts/firasansbookitalic.woff new file mode 100644 index 00000000000..61674f3491e Binary files /dev/null and b/tmpl/assets/fonts/firasansbookitalic.woff differ diff --git a/tmpl/assets/fonts/firasansbookitalic.woff2 b/tmpl/assets/fonts/firasansbookitalic.woff2 new file mode 100644 index 00000000000..b4ddd45fbbc Binary files /dev/null and b/tmpl/assets/fonts/firasansbookitalic.woff2 differ diff --git a/tmpl/assets/fonts/firasansextralight.ttf b/tmpl/assets/fonts/firasansextralight.ttf new file mode 100644 index 00000000000..92fa7ddbe60 Binary files /dev/null and b/tmpl/assets/fonts/firasansextralight.ttf differ diff --git a/tmpl/assets/fonts/firasansextralight.woff b/tmpl/assets/fonts/firasansextralight.woff new file mode 100644 index 00000000000..02f741226f9 Binary files /dev/null and b/tmpl/assets/fonts/firasansextralight.woff differ diff --git a/tmpl/assets/fonts/firasansextralight.woff2 b/tmpl/assets/fonts/firasansextralight.woff2 new file mode 100644 index 00000000000..0e207ed3094 Binary files /dev/null and b/tmpl/assets/fonts/firasansextralight.woff2 differ diff --git a/tmpl/assets/fonts/firasansextralightitalic.ttf b/tmpl/assets/fonts/firasansextralightitalic.ttf new file mode 100644 index 00000000000..226bd9a5a91 Binary files /dev/null and b/tmpl/assets/fonts/firasansextralightitalic.ttf differ diff --git a/tmpl/assets/fonts/firasansextralightitalic.woff b/tmpl/assets/fonts/firasansextralightitalic.woff new file mode 100644 index 00000000000..fbd889abf9c Binary files /dev/null and b/tmpl/assets/fonts/firasansextralightitalic.woff differ diff --git a/tmpl/assets/fonts/firasansextralightitalic.woff2 b/tmpl/assets/fonts/firasansextralightitalic.woff2 new file mode 100644 index 00000000000..c7340a406bc Binary files /dev/null and b/tmpl/assets/fonts/firasansextralightitalic.woff2 differ diff --git a/tmpl/assets/fonts/firasansitalic.ttf b/tmpl/assets/fonts/firasansitalic.ttf new file mode 100644 index 00000000000..aa45c66c4b6 Binary files /dev/null and b/tmpl/assets/fonts/firasansitalic.ttf differ diff --git a/tmpl/assets/fonts/firasansitalic.woff b/tmpl/assets/fonts/firasansitalic.woff new file mode 100644 index 00000000000..ff5a05aacae Binary files /dev/null and b/tmpl/assets/fonts/firasansitalic.woff differ diff --git a/tmpl/assets/fonts/firasansitalic.woff2 b/tmpl/assets/fonts/firasansitalic.woff2 new file mode 100644 index 00000000000..f86040d3a7f Binary files /dev/null and b/tmpl/assets/fonts/firasansitalic.woff2 differ diff --git a/tmpl/assets/fonts/firasanslight.ttf b/tmpl/assets/fonts/firasanslight.ttf new file mode 100644 index 00000000000..c22cfa36469 Binary files /dev/null and b/tmpl/assets/fonts/firasanslight.ttf differ diff --git a/tmpl/assets/fonts/firasanslight.woff b/tmpl/assets/fonts/firasanslight.woff new file mode 100644 index 00000000000..31ab37deb09 Binary files /dev/null and b/tmpl/assets/fonts/firasanslight.woff differ diff --git a/tmpl/assets/fonts/firasanslight.woff2 b/tmpl/assets/fonts/firasanslight.woff2 new file mode 100644 index 00000000000..65fb70a793e Binary files /dev/null and b/tmpl/assets/fonts/firasanslight.woff2 differ diff --git a/tmpl/assets/fonts/firasanslightitalic.ttf b/tmpl/assets/fonts/firasanslightitalic.ttf new file mode 100644 index 00000000000..b442b2b32b3 Binary files /dev/null and b/tmpl/assets/fonts/firasanslightitalic.ttf differ diff --git a/tmpl/assets/fonts/firasanslightitalic.woff b/tmpl/assets/fonts/firasanslightitalic.woff new file mode 100644 index 00000000000..19a3a199189 Binary files /dev/null and b/tmpl/assets/fonts/firasanslightitalic.woff differ diff --git a/tmpl/assets/fonts/firasanslightitalic.woff2 b/tmpl/assets/fonts/firasanslightitalic.woff2 new file mode 100644 index 00000000000..367e5b1c80b Binary files /dev/null and b/tmpl/assets/fonts/firasanslightitalic.woff2 differ diff --git a/tmpl/assets/fonts/firasansmedium.ttf b/tmpl/assets/fonts/firasansmedium.ttf new file mode 100644 index 00000000000..81f97072f79 Binary files /dev/null and b/tmpl/assets/fonts/firasansmedium.ttf differ diff --git a/tmpl/assets/fonts/firasansmedium.woff b/tmpl/assets/fonts/firasansmedium.woff new file mode 100644 index 00000000000..12b998bb7f8 Binary files /dev/null and b/tmpl/assets/fonts/firasansmedium.woff differ diff --git a/tmpl/assets/fonts/firasansmedium.woff2 b/tmpl/assets/fonts/firasansmedium.woff2 new file mode 100644 index 00000000000..4e23dc487e6 Binary files /dev/null and b/tmpl/assets/fonts/firasansmedium.woff2 differ diff --git a/tmpl/assets/fonts/firasansmediumitalic.ttf b/tmpl/assets/fonts/firasansmediumitalic.ttf new file mode 100644 index 00000000000..1beedda5521 Binary files /dev/null and b/tmpl/assets/fonts/firasansmediumitalic.ttf differ diff --git a/tmpl/assets/fonts/firasansmediumitalic.woff b/tmpl/assets/fonts/firasansmediumitalic.woff new file mode 100644 index 00000000000..e694422596d Binary files /dev/null and b/tmpl/assets/fonts/firasansmediumitalic.woff differ diff --git a/tmpl/assets/fonts/firasansmediumitalic.woff2 b/tmpl/assets/fonts/firasansmediumitalic.woff2 new file mode 100644 index 00000000000..01de8266d8e Binary files /dev/null and b/tmpl/assets/fonts/firasansmediumitalic.woff2 differ diff --git a/tmpl/assets/fonts/firasanssemibold.ttf b/tmpl/assets/fonts/firasanssemibold.ttf new file mode 100644 index 00000000000..69a4be5aa0e Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibold.ttf differ diff --git a/tmpl/assets/fonts/firasanssemibold.woff b/tmpl/assets/fonts/firasanssemibold.woff new file mode 100644 index 00000000000..fe733039f04 Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibold.woff differ diff --git a/tmpl/assets/fonts/firasanssemibold.woff2 b/tmpl/assets/fonts/firasanssemibold.woff2 new file mode 100644 index 00000000000..b828fd27545 Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibold.woff2 differ diff --git a/tmpl/assets/fonts/firasanssemibolditalic.ttf b/tmpl/assets/fonts/firasanssemibolditalic.ttf new file mode 100644 index 00000000000..dd5c7eee85e Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibolditalic.ttf differ diff --git a/tmpl/assets/fonts/firasanssemibolditalic.woff b/tmpl/assets/fonts/firasanssemibolditalic.woff new file mode 100644 index 00000000000..9bbb771b709 Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibolditalic.woff differ diff --git a/tmpl/assets/fonts/firasanssemibolditalic.woff2 b/tmpl/assets/fonts/firasanssemibolditalic.woff2 new file mode 100644 index 00000000000..dc18c3237d4 Binary files /dev/null and b/tmpl/assets/fonts/firasanssemibolditalic.woff2 differ diff --git a/tmpl/assets/logo.png b/tmpl/assets/logo.png new file mode 100644 index 00000000000..982d648913b Binary files /dev/null and b/tmpl/assets/logo.png differ diff --git a/tmpl/assets/normalize.css b/tmpl/assets/normalize.css new file mode 100644 index 00000000000..08f895079ef --- /dev/null +++ b/tmpl/assets/normalize.css @@ -0,0 +1,425 @@ +/*! normalize.css v3.0.1 | MIT License | git.io/normalize */ + +/** + * 1. Set default font family to sans-serif. + * 2. Prevent iOS text size adjust after orientation change, without disabling + * user zoom. + */ + +html { + font-family: sans-serif; /* 1 */ + -ms-text-size-adjust: 100%; /* 2 */ + -webkit-text-size-adjust: 100%; /* 2 */ +} + +/** + * Remove default margin. + */ + +body { + margin: 0; +} + +/* HTML5 display definitions + ========================================================================== */ + +/** + * Correct `block` display not defined for any HTML5 element in IE 8/9. + * Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox. + * Correct `block` display not defined for `main` in IE 11. + */ + +article, +aside, +details, +figcaption, +figure, +footer, +header, +hgroup, +main, +nav, +section, +summary { + display: block; +} + +/** + * 1. Correct `inline-block` display not defined in IE 8/9. + * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. + */ + +audio, +canvas, +progress, +video { + display: inline-block; /* 1 */ + vertical-align: baseline; /* 2 */ +} + +/** + * Prevent modern browsers from displaying `audio` without controls. + * Remove excess height in iOS 5 devices. + */ + +audio:not([controls]) { + display: none; + height: 0; +} + +/** + * Address `[hidden]` styling not present in IE 8/9/10. + * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22. + */ + +[hidden], +template { + display: none; +} + +/* Links + ========================================================================== */ + +/** + * Remove the gray background color from active links in IE 10. + */ + +a { + background: transparent; +} + +/** + * Improve readability when focused and also mouse hovered in all browsers. + */ + +a:active, +a:hover { + outline: 0; +} + +/* Text-level semantics + ========================================================================== */ + +/** + * Address styling not present in IE 8/9/10/11, Safari, and Chrome. + */ + +abbr[title] { + border-bottom: 1px dotted; +} + +/** + * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. + */ + +b, +strong { + font-weight: bold; +} + +/** + * Address styling not present in Safari and Chrome. + */ + +dfn { + font-style: italic; +} + +/** + * Address variable `h1` font-size and margin within `section` and `article` + * contexts in Firefox 4+, Safari, and Chrome. + */ + +h1 { + font-size: 2em; + margin: 0.67em 0; +} + +/** + * Address styling not present in IE 8/9. + */ + +mark { + background: #ff0; + color: #000; +} + +/** + * Address inconsistent and variable font size in all browsers. + */ + +small { + font-size: 80%; +} + +/** + * Prevent `sub` and `sup` affecting `line-height` in all browsers. + */ + +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} + +sup { + top: -0.5em; +} + +sub { + bottom: -0.25em; +} + +/* Embedded content + ========================================================================== */ + +/** + * Remove border when inside `a` element in IE 8/9/10. + */ + +img { + border: 0; +} + +/** + * Correct overflow not hidden in IE 9/10/11. + */ + +svg:not(:root) { + overflow: hidden; +} + +/* Grouping content + ========================================================================== */ + +/** + * Address margin not present in IE 8/9 and Safari. + */ + +figure { + margin: 1em 40px; +} + +/** + * Address differences between Firefox and other browsers. + */ + +hr { + -moz-box-sizing: content-box; + box-sizing: content-box; + height: 0; +} + +/** + * Contain overflow in all browsers. + */ + +pre { + overflow: auto; +} + +/** + * Address odd `em`-unit font size rendering in all browsers. + */ + +code, +kbd, +pre, +samp { + font-family: monospace, monospace; + font-size: 1em; +} + +/* Forms + ========================================================================== */ + +/** + * Known limitation: by default, Chrome and Safari on OS X allow very limited + * styling of `select`, unless a `border` property is set. + */ + +/** + * 1. Correct color not being inherited. + * Known issue: affects color of disabled elements. + * 2. Correct font properties not being inherited. + * 3. Address margins set differently in Firefox 4+, Safari, and Chrome. + */ + +button, +input, +optgroup, +select, +textarea { + color: inherit; /* 1 */ + font: inherit; /* 2 */ + margin: 0; /* 3 */ +} + +/** + * Address `overflow` set to `hidden` in IE 8/9/10/11. + */ + +button { + overflow: visible; +} + +/** + * Address inconsistent `text-transform` inheritance for `button` and `select`. + * All other form control elements do not inherit `text-transform` values. + * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. + * Correct `select` style inheritance in Firefox. + */ + +button, +select { + text-transform: none; +} + +/** + * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` + * and `video` controls. + * 2. Correct inability to style clickable `input` types in iOS. + * 3. Improve usability and consistency of cursor style between image-type + * `input` and others. + */ + +button, +html input[type="button"], /* 1 */ +input[type="reset"], +input[type="submit"] { + -webkit-appearance: button; /* 2 */ + cursor: pointer; /* 3 */ +} + +/** + * Re-set default cursor for disabled elements. + */ + +button[disabled], +html input[disabled] { + cursor: default; +} + +/** + * Remove inner padding and border in Firefox 4+. + */ + +button::-moz-focus-inner, +input::-moz-focus-inner { + border: 0; + padding: 0; +} + +/** + * Address Firefox 4+ setting `line-height` on `input` using `!important` in + * the UA stylesheet. + */ + +input { + line-height: normal; +} + +/** + * It's recommended that you don't attempt to style these elements. + * Firefox's implementation doesn't respect box-sizing, padding, or width. + * + * 1. Address box sizing set to `content-box` in IE 8/9/10. + * 2. Remove excess padding in IE 8/9/10. + */ + +input[type="checkbox"], +input[type="radio"] { + box-sizing: border-box; /* 1 */ + padding: 0; /* 2 */ +} + +/** + * Fix the cursor style for Chrome's increment/decrement buttons. For certain + * `font-size` values of the `input`, it causes the cursor style of the + * decrement button to change from `default` to `text`. + */ + +input[type="number"]::-webkit-inner-spin-button, +input[type="number"]::-webkit-outer-spin-button { + height: auto; +} + +/** + * 1. Address `appearance` set to `searchfield` in Safari and Chrome. + * 2. Address `box-sizing` set to `border-box` in Safari and Chrome + * (include `-moz` to future-proof). + */ + +input[type="search"] { + -webkit-appearance: textfield; /* 1 */ + -moz-box-sizing: content-box; + -webkit-box-sizing: content-box; /* 2 */ + box-sizing: content-box; +} + +/** + * Remove inner padding and search cancel button in Safari and Chrome on OS X. + * Safari (but not Chrome) clips the cancel button when the search input has + * padding (and `textfield` appearance). + */ + +input[type="search"]::-webkit-search-cancel-button, +input[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; +} + +/** + * Define consistent border, margin, and padding. + */ + +fieldset { + border: 1px solid #c0c0c0; + margin: 0 2px; + padding: 0.35em 0.625em 0.75em; +} + +/** + * 1. Correct `color` not being inherited in IE 8/9/10/11. + * 2. Remove padding so people aren't caught out if they zero out fieldsets. + */ + +legend { + border: 0; /* 1 */ + padding: 0; /* 2 */ +} + +/** + * Remove default vertical scrollbar in IE 8/9/10/11. + */ + +textarea { + overflow: auto; +} + +/** + * Don't inherit the `font-weight` (applied by a rule above). + * NOTE: the default cannot safely be changed in Chrome and Safari on OS X. + */ + +optgroup { + font-weight: bold; +} + +/* Tables + ========================================================================== */ + +/** + * Remove most spacing between table cells. + */ + +table { + border-collapse: collapse; + border-spacing: 0; +} + +td, +th { + padding: 0; +} diff --git a/tmpl/assets/sponsors/doppler.png b/tmpl/assets/sponsors/doppler.png new file mode 100644 index 00000000000..a0ada118355 Binary files /dev/null and b/tmpl/assets/sponsors/doppler.png differ diff --git a/tmpl/category-index.tmpl.html b/tmpl/category-index.tmpl.html new file mode 100644 index 00000000000..808f2b60543 --- /dev/null +++ b/tmpl/category-index.tmpl.html @@ -0,0 +1,113 @@ + + + + + + + {{.Title}} - Awesome Go / Golang + + + + + + + + + + + + + + + + + +
+
+

awesome-go {{.Title}} - + Awesome Go

+

{{.Description}}

+

Build Status Awesome Slack Widget Netlify Status +

+

+
🗺️ back to content + menu + Deploys by Netlify +
+ + + + + diff --git a/tmpl/index.tmpl.html b/tmpl/index.tmpl.html new file mode 100644 index 00000000000..3142c956f86 --- /dev/null +++ b/tmpl/index.tmpl.html @@ -0,0 +1,65 @@ + + + + + + + + A curated list of awesome Go frameworks, libraries and software - Awesome Go / Golang + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ +
+ + {{.Body}} + + + Deploys by Netlify + +
+ + + + + + + \ No newline at end of file diff --git a/tmpl/robots.txt b/tmpl/robots.txt new file mode 100644 index 00000000000..f6e6d1d4175 --- /dev/null +++ b/tmpl/robots.txt @@ -0,0 +1,2 @@ +User-Agent: * +Allow: / diff --git a/tmpl/sitemap.tmpl.xml b/tmpl/sitemap.tmpl.xml new file mode 100644 index 00000000000..2ede8fedb81 --- /dev/null +++ b/tmpl/sitemap.tmpl.xml @@ -0,0 +1,18 @@ + + + + + https://www.awesome-go.com/ + 2016-10-10T07:39:03+00:00 + + {{range .}} + + https://www.awesome-go.com/{{.Slug}} + 2016-10-10T07:39:03+00:00 + + {{end}} +