{"id":13425008,"url":"https://github.com/grandnode/grandnode","last_synced_at":"2025-09-29T00:32:50.542Z","repository":{"id":47522275,"uuid":"47261966","full_name":"grandnode/grandnode","owner":"grandnode","description":"Open source, headless, multi-tenant eCommerce platform built with .NET Core, MongoDB, AWS DocumentDB, Azure CosmosDB, Vue.js. ","archived":true,"fork":false,"pushed_at":"2021-08-25T14:50:10.000Z","size":388632,"stargazers_count":1889,"open_issues_count":218,"forks_count":762,"subscribers_count":141,"default_branch":"develop","last_synced_at":"2025-01-18T22:38:52.738Z","etag":null,"topics":["asp-net","cart","commerce","core","csharp","docker","dotnet-core","dotnetcore","ecommerce","ecommerce-platform","headless-cms","marketplace","mongodb","nosql","open-source","shop","shopping-cart","storefront"],"latest_commit_sha":null,"homepage":"https://www.grandnode.com","language":"C#","has_issues":false,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/grandnode.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null},"funding":{"open_collective":"grandnode","custom":["https://www.paypal.com/donate/?token=O7n40ic-CbypCH7kizyW3tWuLeAxweuX5fv0gB-DyOSfaaOzJFkmWPfDe0Lg1K2tNmJO10\u0026country.x=PL\u0026locale.x=PL"]}},"created_at":"2015-12-02T13:15:49.000Z","updated_at":"2024-12-23T10:47:18.000Z","dependencies_parsed_at":"2022-07-24T21:02:14.556Z","dependency_job_id":null,"html_url":"https://github.com/grandnode/grandnode","commit_stats":null,"previous_names":[],"tags_count":30,"template":false,"template_full_name":null,"purl":"pkg:github/grandnode/grandnode","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/grandnode%2Fgrandnode","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/grandnode%2Fgrandnode/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/grandnode%2Fgrandnode/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/grandnode%2Fgrandnode/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/grandnode","download_url":"https://codeload.github.com/grandnode/grandnode/tar.gz/refs/heads/develop","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/grandnode%2Fgrandnode/sbom","scorecard":{"id":443494,"data":{"date":"2025-08-11","repo":{"name":"github.com/grandnode/grandnode","commit":"c209758031e88d0279a023a7237b1f68ebd9f4dc"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":2.9,"checks":[{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/aspnetcore.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":"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":"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":"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":"Maintained","score":0,"reason":"project is archived","details":["Warn: Repository is archived."],"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"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":"License","score":9,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Warn: project license file does not contain an FSF or OSI license."],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"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":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"Binary-Artifacts","score":7,"reason":"binaries present in source code","details":["Warn: binary detected: Grand.Web/Rotativa/Linux/wkhtmltopdf:1","Warn: binary detected: Grand.Web/Rotativa/Mac/wkhtmltopdf:1","Warn: binary detected: Grand.Web/Rotativa/Windows/wkhtmltopdf.exe:1"],"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":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact 4.90.1 not signed: https://api.github.com/repos/grandnode/grandnode/releases/46299598","Warn: release artifact 4.90.0 not signed: https://api.github.com/repos/grandnode/grandnode/releases/38097787","Warn: release artifact 4.90.0-beta not signed: https://api.github.com/repos/grandnode/grandnode/releases/36963877","Warn: release artifact 4.80.1 not signed: https://api.github.com/repos/grandnode/grandnode/releases/33158665","Warn: release artifact 4.90.1 does not have provenance: https://api.github.com/repos/grandnode/grandnode/releases/46299598","Warn: release artifact 4.90.0 does not have provenance: https://api.github.com/repos/grandnode/grandnode/releases/38097787","Warn: release artifact 4.90.0-beta does not have provenance: https://api.github.com/repos/grandnode/grandnode/releases/36963877","Warn: release artifact 4.80.1 does not have provenance: https://api.github.com/repos/grandnode/grandnode/releases/33158665"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"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":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'develop'","Warn: branch protection not enabled for branch '4.90.X'","Warn: branch protection not enabled for branch '4.80.X'","Warn: branch protection not enabled for branch 'Release-4.60'","Warn: branch protection not enabled for branch 'Release-4.50'","Warn: branch protection not enabled for branch 'Release-4.40'","Warn: branch protection not enabled for branch 'Release-4.20.01'","Warn: branch protection not enabled for branch 'Release-4.20'","Warn: branch protection not enabled for branch 'Release-4.00'"],"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":"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/aspnetcore.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/grandnode/grandnode/aspnetcore.yml/develop?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/aspnetcore.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/grandnode/grandnode/aspnetcore.yml/develop?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:1","Warn: containerImage not pinned by hash: Dockerfile:47: pin your Docker image by updating mcr.microsoft.com/dotnet/core/aspnet:3.1.0 to mcr.microsoft.com/dotnet/core/aspnet:3.1.0@sha256:9f0aebb2e83a9f455e4ac123db10bc263e729e1faaf733709db04d0d6df2b77c","Warn: containerImage not pinned by hash: Grand.Web/Dockerfile:1","Warn: containerImage not pinned by hash: Grand.Web/Dockerfile:7","Warn: containerImage not pinned by hash: Grand.Web/Dockerfile:20","Warn: containerImage not pinned by hash: Grand.Web/Dockerfile:24","Warn: nugetCommand not pinned by hash: Grand.Web/Dockerfile:15: pin your dependecies by either enabling central package management (https://learn.microsoft.com/nuget/consume-packages/Central-Package-Management) or using a lockfile (https://learn.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies)","Warn: nugetCommand not pinned by hash: .github/workflows/aspnetcore.yml:18: pin your dependecies by either enabling central package management (https://learn.microsoft.com/nuget/consume-packages/Central-Package-Management) or using a lockfile (https://learn.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies)","Info:   0 out of   2 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   6 containerImage dependencies pinned","Info:   0 out of   2 nugetCommand 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"}}]},"last_synced_at":"2025-08-19T06:08:06.702Z","repository_id":47522275,"created_at":"2025-08-19T06:08:06.702Z","updated_at":"2025-08-19T06:08:06.702Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":277450939,"owners_count":25819971,"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-09-28T02:00:08.834Z","response_time":79,"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":["asp-net","cart","commerce","core","csharp","docker","dotnet-core","dotnetcore","ecommerce","ecommerce-platform","headless-cms","marketplace","mongodb","nosql","open-source","shop","shopping-cart","storefront"],"created_at":"2024-07-31T00:01:01.946Z","updated_at":"2025-09-29T00:32:45.532Z","avatar_url":"https://github.com/grandnode.png","language":"C#","funding_links":["https://opencollective.com/grandnode","https://www.paypal.com/donate/?token=O7n40ic-CbypCH7kizyW3tWuLeAxweuX5fv0gB-DyOSfaaOzJFkmWPfDe0Lg1K2tNmJO10\u0026country.x=PL\u0026locale.x=PL"],"categories":["电子商务和支付","Frameworks, Libraries and Tools","E-Commerce and Payments","C# #","框架, 库和工具","C\\#","open-source","Architectural Patterns","Realtime Applications","Applications","csharp"],"sub_categories":["E-Commerce and Payments","电子商务与支付","Domain Driven Design - Domain Centric","Web"],"readme":"This repository contains a legacy version of GrandNode. \n\nUrgent info: We do not currently maintain the legacy version — we provide limited support for bug fixing until the end of 2022 only. All our resources are focused on GrandNode 2.0 development. \n\nGrandNode v2 is our own open-source e-commerce platform based on .NET Core 5.0 and MongoDB. Written from the scratch. \n\nNew updates and improvements will not be available on the legacy version. For updates please look at the GrandNode v2 repository - https://github.com/grandnode/grandnode2.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgrandnode%2Fgrandnode","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgrandnode%2Fgrandnode","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgrandnode%2Fgrandnode/lists"}