1
0
mirror of https://github.com/bitwarden/server.git synced 2025-01-22 21:51:22 +01:00
The core infrastructure backend (API, database, Docker, etc).
Go to file
Kyle Spearrin 6f04298e17
Data protection for user columns at rest (#2571)
* ServerProtectedData for user entity

* remove using statements

* formatting

* use data protection libs

* no async

* add data protection to ef user repo

* switch to `SetApplicationName` per ASPNET docs

* null checks

* cleanup

* value converter for EF

* new line at eof

* fix using

* remove folder ref

* restore ctor

* fix lint

* use global constant

* UseApplicationServiceProvider for integration tests

* implement constant for DatabaseFieldProtectedPrefix

* Fix EF IntegrationTest

* restore original values after protect and save

* lint fixes

* Use Constants

Co-authored-by: Justin Baur <19896123+justindbaur@users.noreply.github.com>
2023-01-18 13:16:57 -05:00
.config [SM-412] Remove postgres timezone legacy behavior (#2547) 2023-01-09 11:53:47 +01:00
.git-hooks Add git hook for formating (#2224) 2022-09-08 10:27:17 +02:00
.github [SM-394] Secrets Manager (#2164) 2023-01-13 15:02:53 +01:00
.vscode [SG-419] Fix problems with push notifications on self-host (#2338) 2022-11-01 09:58:28 -04:00
bitwarden_license Fix linting errors (#2577) 2023-01-13 17:02:44 +01:00
dev Include SQLite in migrations (#2559) 2023-01-12 07:59:00 -06:00
docker-unified [SM-394] Secrets Manager (#2164) 2023-01-13 15:02:53 +01:00
perf/MicroBenchmarks Migrate to Microsoft.Data.SqlClient (#2548) 2023-01-10 15:58:41 -05:00
scripts Bitwarden Unified Self-Host project (#2410) 2022-11-18 14:39:01 -05:00
src Data protection for user columns at rest (#2571) 2023-01-18 13:16:57 -05:00
test Data protection for user columns at rest (#2571) 2023-01-18 13:16:57 -05:00
util Remove Unused Auto Properties (#2580) 2023-01-13 14:24:58 -05:00
.dockerignore Bitwarden Unified Self-Host project (#2410) 2022-11-18 14:39:01 -05:00
.editorconfig Feature/bit auto data (#2219) 2022-08-31 08:38:35 -05:00
.git-blame-ignore-revs Add instructions (#2232) 2022-08-30 12:17:17 -04:00
.gitattributes
.gitignore
bitwarden-server.sln [SM-394] Secrets Manager (#2164) 2023-01-13 15:02:53 +01:00
CONTRIBUTING.md
Directory.Build.props Bump version to 2023.1.0 (#2562) 2023-01-10 13:11:56 -07:00
LICENSE_AGPL.txt
LICENSE_BITWARDEN.txt
LICENSE_FAQ.md [SM-142] Rename CommCore to Commercial.Core (#2158) 2022-08-02 20:41:18 +02:00
LICENSE.txt
NuGet.Config
README.md [PS-1992] Updating broken link to Server Setup Guide (#2476) 2022-12-06 10:42:25 +01:00
SECURITY.md
TRADEMARK_GUIDELINES.md

Bitwarden

Github Workflow build on master DockerHub gitter chat


The Bitwarden Server project contains the APIs, database, and other core infrastructure items needed for the "backend" of all bitwarden client applications.

The server project is written in C# using .NET Core with ASP.NET Core. The database is written in T-SQL/SQL Server. The codebase can be developed, built, run, and deployed cross-platform on Windows, macOS, and Linux distributions.

Developer Documentation

Please refer to the Server Setup Guide in the Contributing Documentation for build instructions, recommended tooling, code style tips, and lots of other great information to get you started.

Deploy

docker

You can deploy Bitwarden using Docker containers on Windows, macOS, and Linux distributions. Use the provided PowerShell and Bash scripts to get started quickly. Find all of the Bitwarden images on Docker Hub.

Full documentation for deploying Bitwarden with Docker can be found in our help center at: https://help.bitwarden.com/article/install-on-premise/

Requirements

These dependencies are free to use.

Linux & macOS

curl -s -o bitwarden.sh \
    https://raw.githubusercontent.com/bitwarden/server/master/scripts/bitwarden.sh \
    && chmod +x bitwarden.sh
./bitwarden.sh install
./bitwarden.sh start

Windows

Invoke-RestMethod -OutFile bitwarden.ps1 `
    -Uri https://raw.githubusercontent.com/bitwarden/server/master/scripts/bitwarden.ps1
.\bitwarden.ps1 -install
.\bitwarden.ps1 -start

We're Hiring!

Interested in contributing in a big way? Consider joining our team! We're hiring for many positions. Please take a look at our Careers page to see what opportunities are currently open as well as what it's like to work at Bitwarden.

Contribute

Code contributions are welcome! Please commit any pull requests against the master branch. Learn more about how to contribute by reading the Contributing Guidelines. Check out the Contributing Documentation for how to get started with your first contribution.

Security audits and feedback are welcome. Please open an issue or email us privately if the report is sensitive in nature. You can read our security policy in the SECURITY.md file. We also run a program on HackerOne.

No grant of any rights in the trademarks, service marks, or logos of Bitwarden is made (except as may be necessary to comply with the notice requirements as applicable), and use of any Bitwarden trademarks must comply with Bitwarden Trademark Guidelines.

Dotnet-format

Consider installing our git pre-commit hook for automatic formatting.

git config --local core.hooksPath .git-hooks

File Scoped Namespaces

We recently migrated to using file scoped namespaces to save some horizontal space. All previous branches will need to update to avoid large merge conflicts using the following steps:

  1. Check out your local Branch
  2. Run git merge 9b7aef0763ad14e229b337c3b5b27cb411009792
  3. Resolve any merge conflicts, commit.
  4. Run dotnet format
  5. Commit
  6. Run git merge -Xours 7f5f010e1eea400300c47f776604ecf46c4b4f2d
  7. Fix Merge conflicts
  8. Push