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
Matt Gibson edf30974dc
Validate cipher updates with revision date (#994)
* Add last updated validation to cipher replacements

* Add AutoFixture scaffolding.

AutoDataAttributes and ICustomizations are meant to automatically
produce valid test input. Examples are the Cipher customizations,
which enforce the model's mutual exclusivity of UserId and
OrganizationId.

FixtureExtensions create a fluent way to generate SUTs. We currently
use parameter injection to fascilitate service testing, which is nicely
handled by AutoNSubstitute. However, in order to gain access to the
substitutions, we need to Freeze them onto the Fixture. The For fluent
method allows specifying a Freeze to a specific type's constructor and
optionally to a parameter name in that constructor.

* Unit tests for single Cipher update version checks

* Fix test runner

Test runner requires Microsoft.NET.Test.Sdk

* Move to provider model for SUT generation

This model differs from previous in that you no longer need to specify
which dependencies you would like access to. Instead, all are
remembered and can be queried through the sutProvider.

* User cipher provided by Put method reads

Every put method already reads all relevant ciphers from database,
there's no need to re-read them.

JSON serialization of datetimes seems to leave truncate at second
precision. Verify last known date time is within one second rather than
exact.

* validate revision date for share many requests

* Update build script to use Github environment path

Co-authored-by: Matt Gibson <mdgibson@Matts-MBP.lan>
2020-11-23 08:48:05 -06:00
.github/workflows docker version bump and update setup-msbuild 2020-11-16 22:44:34 -05:00
bitwarden_license Added OrgIdentifer to SetPasswordAsync // Added jit user two factor provider (#1009) 2020-11-22 08:46:44 -06:00
scripts version bump for patch 1.38.1 (#1007) 2020-11-18 12:42:58 -05:00
src Validate cipher updates with revision date (#994) 2020-11-23 08:48:05 -06:00
test Validate cipher updates with revision date (#994) 2020-11-23 08:48:05 -06:00
util Implement User-based API Keys (#981) 2020-11-10 15:15:29 -05:00
.editorconfig fix prefix fields with _ 2020-01-15 09:19:15 -05:00
.gitattributes Added .gitattributes file to files requiring LF endings are properly checked out on Windows. (#380) 2018-10-18 12:15:41 -04:00
.gitignore ignore lib and css from portal and sso projects 2020-09-04 14:03:54 -04:00
appveyor.yml Update swagger config to use proper URL scheme (#744) 2020-05-21 15:00:03 -04:00
bitwarden-server.sln add all licenses to solution items 2020-09-04 14:09:30 -04:00
build.sh Merge SSO and Portal projects 2020-09-04 13:56:08 -04:00
CONTRIBUTING.md expand contributing guide (#987) 2020-11-12 09:40:18 -05:00
dotnet-tools.json swagger cli tool fixes 2020-01-10 16:06:44 -05:00
ISSUE_TEMPLATE.md Update ISSUE_TEMPLATE.md 2018-03-10 14:35:33 -05:00
LICENSE_AGPL.txt split license file out to support bitwarden licensed code (#912) 2020-09-04 13:36:22 -04:00
LICENSE_BITWARDEN.txt split license file out to support bitwarden licensed code (#912) 2020-09-04 13:36:22 -04:00
LICENSE_FAQ.md Update LICENSE_FAQ.md 2020-09-05 23:39:50 -04:00
LICENSE.txt split license file out to support bitwarden licensed code (#912) 2020-09-04 13:36:22 -04:00
NuGet.Config initial commit of source 2015-12-08 22:57:38 -05:00
README.md Added contributing.md file and link in readme (#950) 2020-09-28 09:48:05 -04:00
SECURITY.md Uppercase Bitwarden 2018-02-27 14:16:19 -05:00

Bitwarden

appveyor build 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.

Build/Run

Requirements

These dependencies are free to use.

These tools are free to use.

API

cd src/Api
dotnet restore
dotnet build
dotnet run

visit http://localhost:5000/alive

Identity

cd src/Identity
dotnet restore
dotnet build
dotnet run

visit http://localhost:33657/.well-known/openid-configuration

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

Contribute

Code contributions are welcome! Visual Studio or VS Code is highly recommended if you are working on this project. Please commit any pull requests against the master branch. Please see CONTRIBUTING.md for more info (and feel free to contribute to that guide as well).

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.