{"id":13454842,"url":"https://github.com/jwma/jump-jump","last_synced_at":"2026-01-16T15:47:24.473Z","repository":{"id":47217340,"uuid":"145663464","full_name":"jwma/jump-jump","owner":"jwma","description":"开箱即用，Golang 开发的一个功能完善的短链接系统。URL shortener service developed with golang.","archived":false,"fork":false,"pushed_at":"2023-11-11T09:31:52.000Z","size":9749,"stargazers_count":238,"open_issues_count":4,"forks_count":71,"subscribers_count":5,"default_branch":"master","last_synced_at":"2025-03-24T07:40:33.183Z","etag":null,"topics":["docker","go","url-shortner","urlshortener"],"latest_commit_sha":null,"homepage":"https://sourl.xyz/dash","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/jwma.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":"2018-08-22T06:03:46.000Z","updated_at":"2025-03-03T06:28:39.000Z","dependencies_parsed_at":"2024-05-28T07:26:44.859Z","dependency_job_id":"f6737331-43c7-4f77-a64e-c62d67399be8","html_url":"https://github.com/jwma/jump-jump","commit_stats":null,"previous_names":[],"tags_count":21,"template":false,"template_full_name":null,"purl":"pkg:github/jwma/jump-jump","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jwma%2Fjump-jump","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jwma%2Fjump-jump/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jwma%2Fjump-jump/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jwma%2Fjump-jump/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/jwma","download_url":"https://codeload.github.com/jwma/jump-jump/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jwma%2Fjump-jump/sbom","scorecard":{"id":545369,"data":{"date":"2025-08-11","repo":{"name":"github.com/jwma/jump-jump","commit":"96e8c35f823a0fb607f5b6ae707afee0c8b34bd0"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":2.5,"checks":[{"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":"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":"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":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/build_and_deploy.yml:1","Warn: no topLevel permission defined: .github/workflows/ci.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":"Code-Review","score":0,"reason":"Found 0/14 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":"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":"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":"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":"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":-1,"reason":"no releases found","details":null,"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/build_and_deploy.yml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/build_and_deploy.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build_and_deploy.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/build_and_deploy.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build_and_deploy.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/build_and_deploy.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build_and_deploy.yml:53: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/build_and_deploy.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build_and_deploy.yml:72: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/build_and_deploy.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/ci.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:23: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/jwma/jump-jump/ci.yml/master?enable=pin","Warn: containerImage not pinned by hash: build/package/Dockerfile:2","Warn: containerImage not pinned by hash: build/package/Dockerfile:19: pin your Docker image by updating alpine to alpine@sha256:4bcff63911fcb4448bd4fdacec207030997caf25e9bea4045fa6c8c44de311d1","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   4 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":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"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 23 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":"26 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GO-2020-0017 / GHSA-w73w-5m7g-f7qc","Warn: Project is vulnerable to: GO-2024-2955 / GHSA-869c-j7wc-8jqv","Warn: Project is vulnerable to: GO-2021-0052 / GHSA-h395-qcrw-5vmq","Warn: Project is vulnerable to: GHSA-3vp4-m3rf-835h","Warn: Project is vulnerable to: GO-2023-1737 / GHSA-2c4m-59x9-fr2g","Warn: Project is vulnerable to: GO-2022-0968 / GHSA-gwc9-m7rh-j2ww","Warn: Project is vulnerable to: GO-2021-0356 / GHSA-8c26-wmh5-6g9v","Warn: Project is vulnerable to: GO-2024-2961","Warn: Project is vulnerable to: GO-2023-2402 / GHSA-45x7-px36-x8w8","Warn: Project is vulnerable to: GO-2024-3321 / GHSA-v778-237x-gjrc","Warn: Project is vulnerable to: GO-2025-3487 / GHSA-hcg3-q754-cr77","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-2022-0493 / GHSA-p782-xgp4-8hr8","Warn: Project is vulnerable to: GO-2024-2611 / GHSA-8r3f-844c-mc37"],"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-20T09:21:49.797Z","repository_id":47217340,"created_at":"2025-08-20T09:21:49.798Z","updated_at":"2025-08-20T09:21:49.798Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28479409,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-16T11:59:17.896Z","status":"ssl_error","status_checked_at":"2026-01-16T11:55:55.838Z","response_time":107,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"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":["docker","go","url-shortner","urlshortener"],"created_at":"2024-07-31T08:00:58.450Z","updated_at":"2026-01-16T15:47:24.439Z","avatar_url":"https://github.com/jwma.png","language":"Go","funding_links":[],"categories":["Go","ShortURL"],"sub_categories":[],"readme":"\u003ch1 align=\"center\"\u003e\n  \u003cbr\u003eJump Jump\u003cbr\u003e\n\u003c/h1\u003e\n\n\u003cp align=\"center\"\u003e\u003cem\u003e开箱即用，Golang 开发的一个功能完善的短链接系统。\u003c/em\u003e\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/jwma/jump-jump/workflows/CI/badge.svg?branch=master\" target=\"_blank\"\u003e\n    \u003cimg src=\"https://github.com/jwma/jump-jump/workflows/CI/badge.svg?branch=master\"\u003e\n  \u003c/a\u003e\n  \u003ca href=\"https://img.shields.io/github/license/mashape/apistatus.svg\" target=\"_blank\"\u003e\n      \u003cimg src=\"https://img.shields.io/github/license/mashape/apistatus.svg\" alt=\"license\"\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n---\n\n* [快速体验](#快速体验)\n* [功能与使用](#功能与使用)\n    * [截图](#截图)\n* [本地启动](#本地启动)\n* [如何访问短链接？](#如何访问短链接)\n    * [设置短链接域名](#设置短链接域名)\n    * [获取完整短链接](#获取完整短链接)\n* [部署到服务器](#部署到服务器)\n* [接口文档](#接口文档)\n* [感谢](#感谢)\n\n---\n\n## 快速体验\n\n[访问这里](http://t.majiawei.com/7pcu75)，来体验一下 Jump Jump 吧！（体验账号/密码：guest/guest）\n\n## 功能与使用\n\n[功能模块](http://t.majiawei.com/c6vn)，后续功能的方向/安排可以持续留意 issues：\n\n\n### 截图\n\n![截图](http://rs.majiawei.com/b/20201016144836.png)\n\n## 本地启动\n\n使用 `docker-compose` 启动，能够快速帮你启动 `redis`, `apiserver`, `landingserver`，使用如下命令：\n\n```shell script\n# 克隆或下载项目源码到本地\ngit clone https://github.com/jwma/jump-jump.git\n\n# 进入项目源码目录\ncd jump-jump/\n\n# 在本地构建容器镜像\nmake dockerimage\n\n# 启动\ndocker-compose -f deployments/docker-compose.yaml -p jumpjump up -d\n\n# 查看服务运行状态\ndocker-compose -f deployments/docker-compose.yaml -p jumpjump ps\n\n# 如果看到 apiserver/landingserver 未启动成功，重启一下就好\ndocker-compose -f deployments/docker-compose.yaml -p jumpjump restart\n\n# 创建用户，在服务正常运行的情况，运行 createuser 可以创建用户，使用如下\ndocker-compose -f deployments/docker-compose.yaml -p jumpjump exec apiserver ./createuser --help\n\nUsage of ./createuser:\n  -password string\n        password.\n  -role int\n        role, 1: normal user, 2: administrator. (default 1)\n  -username string\n        username.\n\n# 创建一个管理员角色的用户\ndocker-compose -f deployments/docker-compose.yaml -p jumpjump exec apiserver ./createuser -username=mj\n -password=12345 -role=2\n```\n\n在服务启动完毕且已经创建好用户之后，可以打开浏览器，访问 `http://localhost:8080` 进入管理后台进行短链接的管理工作。\n\n## 如何访问短链接？\n\n### 设置短链接域名\n\n登入到管理后台之后，你能够看到短链接域名设置（只有管理员有权修改），在这里设置好你部署的**域名/IP:Port**，如：\n`http://127.0.0.1:8000/` 或者 `http://yourdomain.com/`，这里有一点需要注意的是，需要以 `/` 结尾。\n\n### 获取完整短链接\n\n访问短链接列表页面，如果你已经创建了短链接，那么可以在列表的第一个字段，悬停一下，会出现一个带有域名的完整短链接，点击就可以自动拷贝到\n剪切板，你可以到需要使用的地方进行粘贴或者使用浏览器访问。\n\n## Pin\n\n如果你特别关心某个短链接近期的访问情况，不妨试一下在短链接列表中把它 Pin 到 Dashboard 首页，这样你就能方便的观察到它的访问情况啦~\n\n## 部署到服务器\n\n这里提供了使用 docker-compose 的部署方案，[点击查看](http://t.majiawei.com/fk1ta3)。\n\n## 接口文档\n\n使用 Swagger UI 提供了一个可调试文档，具体使用方法查看这个 [PR](https://github.com/jwma/jump-jump/pull/40)，希望这份文档能够帮助\n到大家！\n\n## 感谢\n\n在这里感谢所有为 Jump Jump 提供建议和反馈 bug 的朋友们，有你们 Jump Jump 会变得更好！\n\n![MJ_STUDIO](http://rs.majiawei.com/b/20200714210656.png)","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjwma%2Fjump-jump","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjwma%2Fjump-jump","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjwma%2Fjump-jump/lists"}