{"id":2930733,"name":"sqlvalidator","ecosystem":"pypi","description":"SQL queries formatting, syntactic and semantic validation","homepage":"https://github.com/David-Wobrock/sqlvalidator","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/David-Wobrock/sqlvalidator","keywords_array":["python","sql","format","formatter","formatting","validation","validator","validate","automation"],"namespace":null,"versions_count":20,"first_release_published_at":"2019-05-26T17:51:41.000Z","latest_release_published_at":"2022-12-25T15:30:12.000Z","latest_release_number":"0.0.20","last_synced_at":"2026-05-26T16:30:58.371Z","created_at":"2022-04-10T12:42:18.356Z","updated_at":"2026-05-26T16:31:29.019Z","registry_url":"https://pypi.org/project/sqlvalidator/","install_command":"pip install sqlvalidator --index-url https://pypi.org/simple","documentation_url":"https://sqlvalidator.readthedocs.io/","metadata":{"funding":null,"documentation":null,"classifiers":["Development Status :: 3 - Alpha","Intended Audience :: Developers","Programming Language :: Python","Programming Language :: Python :: 3","Programming Language :: Python :: 3.10","Programming Language :: Python :: 3.11","Programming Language :: Python :: 3.7","Programming Language :: Python :: 3.8","Programming Language :: Python :: 3.9"],"normalized_name":"sqlvalidator","project_status":null},"repo_metadata":{"id":39863416,"uuid":"188714154","full_name":"David-Wobrock/sqlvalidator","owner":"David-Wobrock","description":"SQL queries formatting, syntactic and semantic validation","archived":false,"fork":false,"pushed_at":"2024-03-14T17:10:22.000Z","size":205,"stargazers_count":74,"open_issues_count":14,"forks_count":17,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-08-21T01:41:13.859Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"https://pypi.org/project/sqlvalidator/","language":"Python","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/David-Wobrock.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":"2019-05-26T17:46:56.000Z","updated_at":"2025-08-11T02:15:38.000Z","dependencies_parsed_at":"2024-06-18T21:25:28.436Z","dependency_job_id":"c2fd1c06-f089-4dd8-8f04-bfa5f127bc9d","html_url":"https://github.com/David-Wobrock/sqlvalidator","commit_stats":{"total_commits":198,"total_committers":4,"mean_commits":49.5,"dds":"0.025252525252525304","last_synced_commit":"9e5bb468ba8f4364715e2da7b1804caf5eaaf83c"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/David-Wobrock/sqlvalidator","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/David-Wobrock","download_url":"https://codeload.github.com/David-Wobrock/sqlvalidator/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator/sbom","scorecard":{"id":38168,"data":{"date":"2025-08-11","repo":{"name":"github.com/David-Wobrock/sqlvalidator","commit":"9e5bb468ba8f4364715e2da7b1804caf5eaaf83c"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.4,"checks":[{"name":"Code-Review","score":0,"reason":"Found 2/23 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":"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":"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":"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-build.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":"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-build.yml:41: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-build.yml:43: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-build.yml:56: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-build.yml:58: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci-build.yml:68: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-build.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-build.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/David-Wobrock/sqlvalidator/ci-build.yml/main?enable=pin","Warn: pipCommand not pinned by hash: .github/workflows/ci-build.yml:48","Warn: pipCommand not pinned by hash: .github/workflows/ci-build.yml:63","Warn: pipCommand not pinned by hash: .github/workflows/ci-build.yml:64","Info:   0 out of   6 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   1 third-party GitHubAction dependencies pinned","Info:   0 out of   3 pipCommand 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":"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":"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":"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":-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":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for 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/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 14 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"}}]},"last_synced_at":"2025-08-14T20:46:26.151Z","repository_id":39863416,"created_at":"2025-08-14T20:46:26.151Z","updated_at":"2025-08-14T20:46:26.151Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":277578062,"owners_count":25842007,"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-29T02:00:09.175Z","response_time":84,"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"},"owner_record":{"login":"David-Wobrock","name":"David Wobrock","uuid":"8582749","kind":"user","description":"Senior Software Engineer @BackMarket","email":"","website":null,"location":"Berlin, Germany","twitter":null,"company":"@BackMarket","icon_url":"https://avatars.githubusercontent.com/u/8582749?u=ea34f214f140183f050b01d11f35f689be1ddef9\u0026v=4","repositories_count":37,"last_synced_at":"2024-04-18T06:15:18.521Z","metadata":{"has_sponsors_listing":false},"html_url":"https://github.com/David-Wobrock","funding_links":[],"total_stars":78,"followers":70,"following":43,"created_at":"2022-11-09T20:35:34.557Z","updated_at":"2024-04-18T06:15:23.880Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/David-Wobrock","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/David-Wobrock/repositories"},"tags":[]},"repo_metadata_updated_at":"2026-05-26T16:31:28.998Z","dependent_packages_count":9,"downloads":136531,"downloads_period":"last-month","dependent_repos_count":6,"rankings":{"downloads":0.8329243818467549,"dependent_repos_count":6.014601104917513,"dependent_packages_count":1.2450113616834386,"stargazers_count":8.879234617881831,"forks_count":9.57024051636065,"docker_downloads_count":null,"average":5.308402396538037},"purl":"pkg:pypi/sqlvalidator","advisories":[],"docker_usage_url":"https://docker.ecosyste.ms/usage/pypi/sqlvalidator","docker_dependents_count":1,"docker_downloads_count":17,"usage_url":"https://repos.ecosyste.ms/usage/pypi/sqlvalidator","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/pypi/sqlvalidator/dependencies","status":null,"funding_links":[],"critical":null,"issue_metadata":{"last_synced_at":"2025-08-21T01:39:15.055Z","issues_count":35,"pull_requests_count":18,"avg_time_to_close_issue":2047891.5833333333,"avg_time_to_close_pull_request":3129850.8,"issues_closed_count":24,"pull_requests_closed_count":15,"pull_request_authors_count":9,"issue_authors_count":19,"avg_comments_per_issue":0.7714285714285715,"avg_comments_per_pull_request":1.222222222222222,"merged_pull_requests_count":11,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":1,"past_year_pull_requests_count":0,"past_year_avg_time_to_close_issue":null,"past_year_avg_time_to_close_pull_request":null,"past_year_issues_closed_count":0,"past_year_pull_requests_closed_count":0,"past_year_pull_request_authors_count":0,"past_year_issue_authors_count":1,"past_year_avg_comments_per_issue":0.0,"past_year_avg_comments_per_pull_request":null,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0,"issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/David-Wobrock%2Fsqlvalidator/issues","maintainers":[{"login":"David-Wobrock","count":24,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/David-Wobrock"}],"active_maintainers":[]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/version_numbers","latest_version_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/latest_version","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/related_packages","codemeta_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/sqlvalidator/codemeta","maintainers":[{"uuid":"David-Wobrock","login":"David-Wobrock","name":null,"email":null,"url":null,"packages_count":3,"html_url":"https://pypi.org/user/David-Wobrock/","role":null,"created_at":"2023-02-25T13:15:14.294Z","updated_at":"2023-02-25T13:15:14.294Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/maintainers/David-Wobrock/packages"}]}