{"id":34335136,"url":"https://github.com/seibert-media/teamvault","last_synced_at":"2026-02-18T12:02:44.118Z","repository":{"id":18582563,"uuid":"21785942","full_name":"seibert-media/teamvault","owner":"seibert-media","description":"Keep your company's passwords behind the firewall","archived":false,"fork":false,"pushed_at":"2026-01-07T14:06:46.000Z","size":7122,"stargazers_count":46,"open_issues_count":32,"forks_count":13,"subscribers_count":13,"default_branch":"main","last_synced_at":"2026-01-13T21:48:38.539Z","etag":null,"topics":["enterprise","password-manager","python","security"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"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/seibert-media.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","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,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2014-07-13T08:19:54.000Z","updated_at":"2025-12-17T07:57:22.000Z","dependencies_parsed_at":"2024-01-05T10:30:46.232Z","dependency_job_id":"286c2737-cb22-4d33-a113-8b97c59f6c1e","html_url":"https://github.com/seibert-media/teamvault","commit_stats":{"total_commits":683,"total_committers":14,"mean_commits":"48.785714285714285","dds":"0.37188872620790625","last_synced_commit":"9dc078564be63c43b2af70901e9fd8f41fa2fc6c"},"previous_names":["trehn/teamvault"],"tags_count":37,"template":false,"template_full_name":null,"purl":"pkg:github/seibert-media/teamvault","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seibert-media%2Fteamvault","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seibert-media%2Fteamvault/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seibert-media%2Fteamvault/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seibert-media%2Fteamvault/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/seibert-media","download_url":"https://codeload.github.com/seibert-media/teamvault/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seibert-media%2Fteamvault/sbom","scorecard":{"id":810084,"data":{"date":"2025-08-11","repo":{"name":"github.com/seibert-media/teamvault","commit":"c4b4687331a74636529463d003eeac7cde0acefe"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":4.5,"checks":[{"name":"Maintained","score":10,"reason":"30 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":2,"reason":"Found 4/14 approved changesets -- score normalized to 2","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":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: topLevel 'contents' permission set to 'write': .github/workflows/create-build-on-release.yml:8","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":"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/create-build-on-release.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:23: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:47: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:60: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:62: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:67: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/create-build-on-release.yml:78: update your workflow using https://app.stepsecurity.io/secureworkflow/seibert-media/teamvault/create-build-on-release.yml/main?enable=pin","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   4 third-party GitHubAction 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":"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":"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":"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":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact 0.10.1 not signed: https://api.github.com/repos/seibert-media/teamvault/releases/238452941","Warn: release artifact 0.10.0 not signed: https://api.github.com/repos/seibert-media/teamvault/releases/238449026","Warn: release artifact 0.10.1 does not have provenance: https://api.github.com/repos/seibert-media/teamvault/releases/238452941","Warn: release artifact 0.10.0 does not have provenance: https://api.github.com/repos/seibert-media/teamvault/releases/238449026"],"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":-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 20 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-23T12:53:10.384Z","repository_id":18582563,"created_at":"2025-08-23T12:53:10.384Z","updated_at":"2025-08-23T12:53:10.384Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28572887,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-19T14:39:55.009Z","status":"ssl_error","status_checked_at":"2026-01-19T14:39:01.217Z","response_time":67,"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":["enterprise","password-manager","python","security"],"created_at":"2025-12-17T20:03:16.377Z","updated_at":"2026-01-19T15:07:53.603Z","avatar_url":"https://github.com/seibert-media.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# TeamVault\n\nTeamVault is an open-source web-based shared password manager for behind-the-firewall installation. It requires Python 3.10+ and PostgreSQL (with the unaccent extension).\n\n## Installation\n\n\tapt-get install libffi-dev libldap2-dev libpq-dev libsasl2-dev python3.X-dev postgresql-contrib\n\tpip install teamvault\n\tteamvault setup\n\tvim /etc/teamvault.conf\n\t# note that the teamvault database user will need SUPERUSER privileges\n\t# during this step in order to activate the unaccent extension\n\tteamvault upgrade\n\tteamvault plumbing createsuperuser\n\tteamvault run\n\n## Update\n\n\tpip install --upgrade teamvault\n\tteamvault upgrade\n\n## Development\n### Start a PostgreSQL database\nCreate a database and superuser for TeamVault to use, for example by starting a Docker container:\n\n\tdocker run --rm --detach --publish=5432:5432 --name teamvault-postgres -e POSTGRES_USER=teamvault -e POSTGRES_PASSWORD=teamvault postgres:latest\n\n\n### Run Webpack to serve static files\nTo compile all JS \u0026 SCSS files, you'll need to install all required packages via bun (or yarn/npm) with node \u003e= v18.\n\nUse ```bun/yarn/npm run serve``` to start a dev server.\n\n**Note**:\nSome MacOS users have reported errors when running the dev server via bun. In this case feel free to switch to NPM.\n\n\n### Configure your Virtualenv via uv\n\tuv sync\n\n### Setup TeamVault\n\texport TEAMVAULT_CONFIG_FILE=teamvault.cfg\n\tteamvault setup\n\tvim teamvault.cfg  # base_url = http://localhost:8000\n\t                   # session_cookie_secure = False\n\t                   # database config as needed\n\tteamvault upgrade\n\tteamvault plumbing createsuperuser\n\n### Start the development server\n\tteamvault run\n\nNow open http://localhost:8000\n\n## Scheduled background jobs\n\nWe use [huey](https://huey.readthedocs.io/en/latest/) to run background jobs. This requires you to run a second process, in parallel to TeamVault itself. You can launch it via `manage.py`:\n\n    teamvault run_huey\n\n## Release process\n1. Bump the version in ```teamvault/__version__.py``` and ```pyproject.toml```\n2. Update CHANGELOG.md with the new version and current date\n3. Make a release commit with the changes made above\n4. Push the commit\n5. Run ```./build.sh``` to create a new package\n6. Sign and push the artifacts to PyPI via ```uv publish```\n7. Test that the package can be installed: ```uv run --isolated --no-cache --prerelease allow --with teamvault --no-project -- teamvault --version```\n8. Add a new GitHub release\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fseibert-media%2Fteamvault","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fseibert-media%2Fteamvault","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fseibert-media%2Fteamvault/lists"}