{"id":34124129,"url":"https://github.com/gotway/gotway","last_synced_at":"2025-12-14T22:59:22.995Z","repository":{"id":48074286,"uuid":"261401804","full_name":"gotway/gotway","owner":"gotway","description":"☸️ Cloud native API Gateway powered with in-redis cache","archived":false,"fork":false,"pushed_at":"2023-03-16T17:13:36.000Z","size":552,"stargazers_count":77,"open_issues_count":8,"forks_count":7,"subscribers_count":6,"default_branch":"master","last_synced_at":"2024-11-15T01:21:19.760Z","etag":null,"topics":["api","api-gateway","cloud-native","go","golang","gotway","helm","http","ingress","kubernetes","kubernetes-controller","microservices","redis","rest-api"],"latest_commit_sha":null,"homepage":"https://github.com/gotway","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/gotway.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-05-05T08:34:19.000Z","updated_at":"2024-03-21T18:44:43.000Z","dependencies_parsed_at":"2024-06-18T18:26:34.412Z","dependency_job_id":"aed7e162-e10f-476e-b824-bcbd485b5217","html_url":"https://github.com/gotway/gotway","commit_stats":null,"previous_names":["gosmo-devs/microgateway"],"tags_count":15,"template":false,"template_full_name":null,"purl":"pkg:github/gotway/gotway","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gotway%2Fgotway","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gotway%2Fgotway/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gotway%2Fgotway/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gotway%2Fgotway/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/gotway","download_url":"https://codeload.github.com/gotway/gotway/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gotway%2Fgotway/sbom","scorecard":{"id":442250,"data":{"date":"2025-08-11","repo":{"name":"github.com/gotway/gotway","commit":"b13d0e19839914b64dcccc93e59db682a74c765e"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":2.5,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/30 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/ci.yml:1","Warn: no topLevel permission defined: .github/workflows/helm.yml:1","Warn: no topLevel permission defined: .github/workflows/release.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v0.0.13 not signed: https://api.github.com/repos/gotway/gotway/releases/95738563","Warn: release artifact helm-chart-0.8.0 not signed: https://api.github.com/repos/gotway/gotway/releases/95766907","Warn: release artifact helm-chart-0.7.0 not signed: https://api.github.com/repos/gotway/gotway/releases/93350180","Warn: release artifact helm-chart-0.6.0 not signed: https://api.github.com/repos/gotway/gotway/releases/93339007","Warn: release artifact v0.0.12 not signed: https://api.github.com/repos/gotway/gotway/releases/68670371","Warn: release artifact v0.0.13 does not have provenance: https://api.github.com/repos/gotway/gotway/releases/95738563","Warn: release artifact helm-chart-0.8.0 does not have provenance: https://api.github.com/repos/gotway/gotway/releases/95766907","Warn: release artifact helm-chart-0.7.0 does not have provenance: https://api.github.com/repos/gotway/gotway/releases/93350180","Warn: release artifact helm-chart-0.6.0 does not have provenance: https://api.github.com/repos/gotway/gotway/releases/93339007","Warn: release artifact v0.0.12 does not have provenance: https://api.github.com/repos/gotway/gotway/releases/68670371"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:25: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:39: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:54: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:60: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/helm.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/helm.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/helm.yml:30: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/helm.yml:35: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/helm.yml:55: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/helm.yml:65: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/helm.yml:68: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/helm.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:45: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:65: update your workflow using https://app.stepsecurity.io/secureworkflow/gotway/gotway/release.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:1","Warn: containerImage not pinned by hash: Dockerfile:13: pin your Docker image by updating alpine:3.16.0 to alpine:3.16.0@sha256:686d8c9dfa6f3ccfc8230bc3178d23f84eeaf7e457f36f271ab1acc53015037c","Info:   0 out of  11 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  10 third-party GitHubAction dependencies pinned","Info:   0 out of   2 containerImage dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 2 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":0,"reason":"21 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GO-2022-0619 / GHSA-r48q-9g5r-8q2h","Warn: Project is vulnerable to: GO-2022-0322 / GHSA-cg3q-j54f-5p7p","Warn: Project is vulnerable to: GO-2022-0236 / GHSA-h86h-8ppg-mxmh","Warn: Project is vulnerable to: GO-2021-0238 / GHSA-83g2-8m93-v3w7","Warn: Project is vulnerable to: GO-2022-0288","Warn: Project is vulnerable to: GO-2022-0969 / GHSA-69cg-p879-7622","Warn: Project is vulnerable to: GO-2022-1144 / GHSA-xrjj-mj9h-534m","Warn: Project is vulnerable to: GO-2023-1571 / GHSA-vvpx-j8f3-3w6h","Warn: Project is vulnerable to: GO-2023-1988 / GHSA-2wrh-6pvc-2jm9","Warn: Project is vulnerable to: GO-2023-2102 / GHSA-4374-p667-p6c8","Warn: Project is vulnerable to: GHSA-qppj-fm5r-hxr3","Warn: Project is vulnerable to: GO-2024-2687 / GHSA-4v7x-pqxf-cx7m","Warn: Project is vulnerable to: GO-2024-3333","Warn: Project is vulnerable to: GO-2025-3503 / GHSA-qxp5-gwg8-xv66","Warn: Project is vulnerable to: GO-2025-3595 / GHSA-vvgc-356p-c3xw","Warn: Project is vulnerable to: GO-2025-3488 / GHSA-6v2p-p543-phr9","Warn: Project is vulnerable to: GO-2022-0493 / GHSA-p782-xgp4-8hr8","Warn: Project is vulnerable to: GO-2021-0113 / GHSA-ppp9-7jff-5vj2","Warn: Project is vulnerable to: GO-2022-1059 / GHSA-69ch-w2m2-3vjp","Warn: Project is vulnerable to: GO-2024-2611 / GHSA-8r3f-844c-mc37","Warn: Project is vulnerable to: GO-2022-0603 / GHSA-hp87-p4gw-j4gq"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-19T05:50:03.671Z","repository_id":48074286,"created_at":"2025-08-19T05:50:03.671Z","updated_at":"2025-08-19T05:50:03.671Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":27738602,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-12-14T02:00:11.348Z","response_time":56,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api","api-gateway","cloud-native","go","golang","gotway","helm","http","ingress","kubernetes","kubernetes-controller","microservices","redis","rest-api"],"created_at":"2025-12-14T22:59:22.348Z","updated_at":"2025-12-14T22:59:22.988Z","avatar_url":"https://github.com/gotway.png","language":"Go","readme":"\u003cp align=\"center\"\u003e\n\u003cimg src=\"https://gotway.github.io/gotway/assets/gotway.png\" alt=\"mariadb\" width=\"250\"/\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n\u003ca href=\"https://github.com/gotway/gotway/actions/workflows/ci.yml\"\u003e\u003cimg src=\"https://github.com/gotway/gotway/actions/workflows/ci.yml/badge.svg\" alt=\"CI\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/gotway/gotway/actions/workflows/helm.yml\"\u003e\u003cimg src=\"https://github.com/gotway/gotway/actions/workflows/helm.yml/badge.svg\" alt=\"Helm\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/gotway/gotway/actions/workflows/release.yml\"\u003e\u003cimg src=\"https://github.com/gotway/gotway/actions/workflows/release.yml/badge.svg\" alt=\"Release\"\u003e\u003c/a\u003e\n\u003ca href=\"https://goreportcard.com/report/github.com/gotway/gotway\"\u003e\u003cimg src=\"https://goreportcard.com/badge/github.com/gotway/gotway\" alt=\"Go Report Card\"\u003e\u003c/a\u003e\n\u003ca href=\"https://pkg.go.dev/github.com/gotway/gotway\"\u003e\u003cimg src=\"https://pkg.go.dev/badge/github.com/gotway/gotway.svg\" alt=\"Go Reference\"\u003e\u003c/a\u003e\n\u003ca href=\"https://artifacthub.io/packages/helm/gotway/gotway\"\u003e\u003cimg src=\"https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/gotway\" alt=\"Artifact Hub\"\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n# ☸️ gotway \n\nCloud native API Gateway powered with in-redis cache.\n\n- API composition: expose your services to the internet using a single endpoint\n- Cloud native: configure routing and cache using [Kubernetes CRDs](./manifests/examples/catalog.yml)\n- In-memory cache using redis \n- Cache invalidation using tags\n- Health checking\n- Management [REST API](#management-rest-api)\n- ~6MB [Docker image](https://github.com/gotway/gotway/pkgs/container/gotway) available for multiple architectures\n- [Helm chart](https://artifacthub.io/packages/helm/gotway/gotway)\n\n### Installation\n\n```bash\nhelm repo add mmontes https://mmontes11.github.io/charts\nhelm repo add gotway https://gotway.github.io/gotway\nhelm install redis mmontes/redis\nhelm install gotway gotway/gotway\n```\n\n### Quickstart\n\nWe will need microservices to route to in order to test Gotway, you can deploy some by running:\n\n```bash\nhelm upgrade --install gotway gotway/gotway --set examples.enabled=true\n```\n\nLet's register the [catalog](https://github.com/gotway/service-examples/tree/main/cmd/catalog) service into Gotway by creating an `IngressHTTP` CRD:\n\n```bash\nkubectl apply -f ./manifests/examples/catalog.yml \n``` \n```yaml\napiVersion: gotway.io/v1alpha1\nkind: IngressHTTP\nmetadata:\n  name: catalog\nspec:\n  match:\n    host: catalog.gotway.duckdns.org:9111\n  service:\n    name: catalog\n    url: http://gotway-catalog\n    healthPath: /health\n  cache:\n    ttl: 30\n    statuses:\n      - 200\n      - 404\n    tags:\n      - \"catalog\"\n      - \"products\"\n\n```\n\nWe are now able to route requests through Gotway:\n\n```bash\ncurl -k --request GET 'https://catalog.gotway.duckdns.org:9111/products' | jq\n```\n```json\n{\n    \"products\": [\n        {\n            \"id\": 911902081,\n            \"name\": \"sneakers\",\n            \"price\": 69000,\n            \"color\": \"white\",\n            \"size\": \"42\"\n        }\n    ],\n    \"totalCount\": 1\n}\n``` \n\nThis response has a TTL of 30 seconds, let's invalidate the cache for the catalog service by providing one of its tags:\n\n```bash\ncurl -k --request DELETE 'https://gotway.duckdns.org:9111/api/cache' \\\n--header 'Content-Type: application/json' \\\n--data-raw '{\n    \"tags\": [\"catalog\"]\n}'\n``` \n### Management REST API \n\n[![Run in Postman](https://run.pstmn.io/button.svg)](https://app.getpostman.com/run-collection/9776-3e976745-8b33-46c1-bfe6-d7211722d809?action=collection%2Ffork\u0026collection-url=entityId%3D9776-3e976745-8b33-46c1-bfe6-d7211722d809%26entityType%3Dcollection%26workspaceId%3D10c73242-ad78-405e-b364-b37e56fbb5d3#?env%5BGotway%5D=W3sia2V5IjoidXJsIiwidmFsdWUiOiJodHRwczovL2dvdHdheS5kdWNrZG5zLm9yZzo5MTExIiwiZW5hYmxlZCI6dHJ1ZSwic2Vzc2lvblZhbHVlIjoiaHR0cHM6Ly9nb3R3YXkuZHVja2Rucy5vcmc6OTExMSIsInNlc3Npb25JbmRleCI6MH0seyJrZXkiOiJ1cmxDYXRhbG9nIiwidmFsdWUiOiJodHRwczovL2NhdGFsb2cuZ290d2F5LmR1Y2tkbnMub3JnOjkxMTEiLCJlbmFibGVkIjp0cnVlLCJzZXNzaW9uVmFsdWUiOiJodHRwczovL2NhdGFsb2cuZ290d2F5LmR1Y2tkbnMub3JnOjkxMTEiLCJzZXNzaW9uSW5kZXgiOjF9LHsia2V5IjoidXJsU3RvY2siLCJ2YWx1ZSI6Imh0dHBzOi8vc3RvY2suZ290d2F5LmR1Y2tkbnMub3JnOjQ0MzMiLCJlbmFibGVkIjp0cnVlLCJzZXNzaW9uVmFsdWUiOiJodHRwczovL3N0b2NrLmdvdHdheS5kdWNrZG5zLm9yZzo5MTExIiwic2Vzc2lvbkluZGV4IjoyfSx7ImtleSI6InByb2R1Y3RJZCIsInZhbHVlIjoiMTIzNCIsImVuYWJsZWQiOnRydWUsInNlc3Npb25WYWx1ZSI6IjEyMzQiLCJzZXNzaW9uSW5kZXgiOjN9LHsia2V5IjoicHJvZHVjdElkMiIsInZhbHVlIjoiNDU2IiwiZW5hYmxlZCI6dHJ1ZSwic2Vzc2lvblZhbHVlIjoiNDU2Iiwic2Vzc2lvbkluZGV4Ijo0fSx7ImtleSI6InByb2R1Y3RJZDMiLCJ2YWx1ZSI6Ijc4OSIsImVuYWJsZWQiOnRydWUsInNlc3Npb25WYWx1ZSI6Ijc4OSIsInNlc3Npb25JbmRleCI6NX1d)\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgotway%2Fgotway","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgotway%2Fgotway","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgotway%2Fgotway/lists"}