{"id":37046971,"url":"https://github.com/codebeltnet/unitify","last_synced_at":"2026-04-18T00:01:36.117Z","repository":{"id":262154423,"uuid":"873812487","full_name":"codebeltnet/unitify","owner":"codebeltnet","description":"Ported from Cuemon, this library provides a uniform way of working with prefixes and multiples in the context of units of measure.","archived":false,"fork":false,"pushed_at":"2026-04-14T15:41:47.000Z","size":106,"stargazers_count":0,"open_issues_count":1,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-04-14T17:26:29.271Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"C#","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/codebeltnet.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":".github/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":".github/CODE_OF_CONDUCT.md","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,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2024-10-16T19:01:32.000Z","updated_at":"2026-04-14T15:41:50.000Z","dependencies_parsed_at":null,"dependency_job_id":"8ef8eaeb-7f60-4811-b948-cc4c29c27531","html_url":"https://github.com/codebeltnet/unitify","commit_stats":null,"previous_names":["codebeltnet/unitify"],"tags_count":17,"template":false,"template_full_name":"codebeltnet/dotnet-new-classlib","purl":"pkg:github/codebeltnet/unitify","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codebeltnet%2Funitify","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codebeltnet%2Funitify/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codebeltnet%2Funitify/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codebeltnet%2Funitify/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/codebeltnet","download_url":"https://codeload.github.com/codebeltnet/unitify/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codebeltnet%2Funitify/sbom","scorecard":{"id":589475,"data":{"date":"2025-01-21T17:48:50Z","repo":{"name":"github.com/codebeltnet/unitify","commit":"060bdf8bfceab0502cf8e19bd823c0ce26596361"},"scorecard":{"version":"v5.0.0","commit":"ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4"},"score":5.2,"checks":[{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#binary-artifacts"}},{"name":"Branch-Protection","score":3,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'allow deletion' disabled on branch 'main'","Info: 'force pushes' disabled on branch 'main'","Info: 'branch protection settings apply to administrators' is required to merge on branch 'main'","Warn: 'stale review dismissal' is disable on branch 'main'","Warn: branch 'main' does not require approvers","Warn: codeowners review is not required on branch 'main'","Warn: 'last push approval' is disable on branch 'main'","Warn: no status checks found to merge onto branch 'main'","Info: PRs are required in order to make changes on branch 'main'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#branch-protection"}},{"name":"CI-Tests","score":8,"reason":"4 out of 5 merged PRs checked by a CI test -- score normalized to 8","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#ci-tests"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#cii-best-practices"}},{"name":"Code-Review","score":0,"reason":"Found 0/6 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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#code-review"}},{"name":"Contributors","score":6,"reason":"project has 2 contributing companies or organizations -- score normalized to 6","details":["Info: geekle (@geekleio) contributor org/company found, codebeltnet contributor org/company found, "],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#contributors"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#dangerous-workflow"}},{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: detected update tool: Dependabot: .github/dependabot.yml:1"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#dependency-update-tool"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#license"}},{"name":"Maintained","score":4,"reason":"5 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 4","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#maintained"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#packaging"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:159: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:162: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:174: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:177: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:182: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:185: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:188: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:194: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:204: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:37: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:42: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:56: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:59: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:74: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:97: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:100: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:105: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:108: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:120: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:123: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:128: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:131: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:134: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:142: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pipelines.yml:148: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/pipelines.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/scorecard.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/scorecard.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/scorecard.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/scorecard.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/scorecard.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/scorecard.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/scorecard.yml:40: update your workflow using https://app.stepsecurity.io/secureworkflow/codebeltnet/unitify/scorecard.yml/main?enable=pin","Warn: containerImage not pinned by hash: .docfx/Dockerfile.docfx:1","Warn: containerImage not pinned by hash: .docfx/Dockerfile.docfx:4","Warn: containerImage not pinned by hash: .docfx/Dockerfile.docfx:11","Info:   0 out of   3 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  30 third-party GitHubAction dependencies pinned","Info:   0 out of   3 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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":8,"reason":"SAST tool is not run on all commits -- score normalized to 8","details":["Warn: 4 commits out of 5 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#sast"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#security-policy"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#signed-releases"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/pipelines.yml:1","Info: topLevel permissions set to 'read-all': .github/workflows/scorecard.yml:9","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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#token-permissions"}},{"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/ea7e27ed41b76ab879c862fa0ca4cc9c61764ee4/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-20T21:28:17.746Z","repository_id":262154423,"created_at":"2025-08-20T21:28:17.746Z","updated_at":"2025-08-20T21:28:17.746Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31947768,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-17T17:29:20.459Z","status":"ssl_error","status_checked_at":"2026-04-17T17:28:47.801Z","response_time":62,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: 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":[],"created_at":"2026-01-14T05:32:02.051Z","updated_at":"2026-04-18T00:01:36.111Z","avatar_url":"https://github.com/codebeltnet.png","language":"C#","funding_links":[],"categories":[],"sub_categories":[],"readme":"![Unitify by Codebelt](.nuget/icon.png)\n\n# Unitify API by Codebelt\n\n[![Unitify CI/CD Pipeline](https://github.com/codebeltnet/unitify/actions/workflows/ci-pipeline.yml/badge.svg)](https://github.com/codebeltnet/unitify/actions/workflows/ci-pipeline.yml) [![codecov](https://codecov.io/gh/codebeltnet/unitify/graph/badge.svg?token=WAmfmpQyCz)](https://codecov.io/gh/codebeltnet/unitify) [![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=unitify\u0026metric=alert_status)](https://sonarcloud.io/dashboard?id=unitify) [![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=unitify\u0026metric=sqale_rating)](https://sonarcloud.io/dashboard?id=unitify) [![Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=unitify\u0026metric=reliability_rating)](https://sonarcloud.io/dashboard?id=unitify) [![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=unitify\u0026metric=security_rating)](https://sonarcloud.io/dashboard?id=unitify) [![OpenSSF Scorecard](https://api.scorecard.dev/projects/github.com/codebeltnet/unitify/badge)](https://scorecard.dev/viewer/?uri=github.com/codebeltnet/unitify)\n\n### ℹ️ About\n\nAn open-source project (MIT license) that offers types that simplify unit management with comprehensive metric and binary support for prefixes, multiples, and submultiples.\n\nYour versatile \"units of measure\" companion for modern development with `.NET 9` and `.NET 10`.\n\nIt is, by heart, free, flexible and built to extend and boost your agile codebelt.\n\n\u003e [!NOTE]\n\u003e To ensure access to current features, improvements, and security updates, and to keep the codebase clean and easy to maintain, we target only the latest long-term (LTS), short-term (STS) and (where applicable) cross-platform .NET versions.\n\n### 📚 Documentation\n\nFull documentation (generated by [DocFx](https://github.com/dotnet/docfx)) located here: https://unitify.codebelt.net/\n\n## 📦 Standalone Packages\n\nProvides a focused API for working with units of measure including, but not limited to, prefixes, multiples, and submultiples.\n\n|Package|vNext|Stable|Downloads|\n|:--|:-:|:-:|:-:|\n| [Codebelt.Unitify](https://www.nuget.org/packages/Codebelt.Unitify/) | ![vNext](https://img.shields.io/nuget/vpre/Codebelt.Unitify?logo=nuget) | ![Stable](https://img.shields.io/nuget/v/Codebelt.Unitify?logo=nuget) | ![Downloads](https://img.shields.io/nuget/dt/Codebelt.Unitify?color=blueviolet\u0026logo=nuget) |\n\n### Contributing to `Unitify API by Codebelt`\n[Contributions](.github/CONTRIBUTING.md) are welcome and appreciated.\n\nFeel free to submit issues, feature requests, or pull requests to help improve this library.\n\n### License\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE.md) file for details.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodebeltnet%2Funitify","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fcodebeltnet%2Funitify","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodebeltnet%2Funitify/lists"}