1
0
mirror of https://github.com/bitwarden/server.git synced 2025-04-05 21:18:13 -05:00

5619 Commits

Author SHA1 Message Date
Jonas Hendrickx
a010c090a9
Remove design patterns 2025-03-26 16:30:45 +01:00
Jonas Hendrickx
6c797567f5
Merge remote-tracking branch 'origin/PM-17830' into PM-17830 2025-03-26 15:17:40 +01:00
Jonas Hendrickx
b24c25ff14
Wrong business logic checking for invalid permissions. 2025-03-26 15:16:28 +01:00
Jonas Hendrickx
990df5ef6a
Wrong business logic checking for invalid permissions. 2025-03-26 15:01:32 +01:00
Jonas Hendrickx
f6143b12d6
Encrypt the notes field 2025-03-26 12:35:39 +01:00
Jonas Hendrickx
052c2dd043
Fix CreateSponsorshipCommandTests 2025-03-26 12:27:01 +01:00
Jonas Hendrickx
5b858a0dd6
CreateAdminInitiatedSponsorshipHandler unit tests 2025-03-26 12:17:17 +01:00
Jonas Hendrickx
6c3ee36485
Forgot to add Notes column to OrganizationSponsorships table in the migration script 2025-03-26 11:56:42 +01:00
Jonas Hendrickx
ba7b9073ac
More tests for CreateSponsorshipHandler 2025-03-26 11:50:15 +01:00
Jonas Hendrickx
43f790a1af
Unit tests for CreateSponsorshipHandler 2025-03-26 11:25:15 +01:00
Jonas Hendrickx
f6ec513443
Add feature flag to CreateAdminInitiatedSponsorshipHandler 2025-03-26 10:49:54 +01:00
Jonas Hendrickx
bbb109cba8
Add Notes column to OrganizationSponsorships table 2025-03-26 10:29:53 +01:00
Jonas Hendrickx
c457b0bb9c WIP 2025-03-14 16:27:39 +01:00
Jonas Hendrickx
ac0691ff26 WIP 2025-03-14 16:27:20 +01:00
Jonas Hendrickx
2d5711240b WIP 2025-03-14 16:25:52 +01:00
Jonas Hendrickx
daefc148e1 WIP 2025-03-14 16:21:45 +01:00
Jonas Hendrickx
73a25337a8 WIP 2025-03-14 16:18:48 +01:00
Jonas Hendrickx
b3ede1d95d WIP 2025-03-14 16:17:22 +01:00
Jonas Hendrickx
56167aae4a WIP 2025-03-14 16:16:52 +01:00
Jonas Hendrickx
7fd4f4c77f WIP 2025-03-14 16:11:05 +01:00
Jonas Hendrickx
b06cff0b1b WIP 2025-03-14 16:04:15 +01:00
Jonas Hendrickx
7f8fa6663b WIP 2025-03-14 16:00:00 +01:00
Jonas Hendrickx
e923af2675 WIP 2025-03-14 15:59:06 +01:00
Jonas Hendrickx
8cc1969c90 WIP 2025-03-14 15:54:47 +01:00
Jonas Hendrickx
841ce9429f WIP 2025-03-14 15:37:16 +01:00
Jonas Hendrickx
f752050d2b WIP 2025-03-14 13:27:46 +01:00
Jonas Hendrickx
ef207e5ec6 WIP 2025-03-14 11:46:09 +01:00
Jonas Hendrickx
5b895865ca WIP 2025-03-12 09:47:16 +01:00
Jonas Hendrickx
effd0b7d33 WIP 2025-03-11 15:55:06 +01:00
Jonas Hendrickx
c03190d672 WIP 2025-03-11 15:07:41 +01:00
Jonas Hendrickx
989f64d449 WIP 2025-03-11 13:03:32 +01:00
Jonas Hendrickx
08924e10d2 WIP 2025-03-11 12:51:42 +01:00
Thomas Rittson
224ef1272e
[PM-18876] Refine PolicyRequirements API (#5445)
* make the PolicyRequirements API more granular, e.g.
  replace factory methods with a factory interface
* update Send to use the new API
2025-03-11 10:46:09 +10:00
Matt Andreko
29dc69a77b
Remove extra && (#5484) 2025-03-10 16:13:35 -04:00
Matt Andreko
8287d0a968
Replace secret checking logic with branch detection logic (#5454) 2025-03-10 15:57:56 -04:00
Jonas Hendrickx
ac25ec4519
[PM-19002] Extract billing code from AccountsController (#5477) 2025-03-10 18:14:22 +01:00
Ike
913da4a629
[PM-15015] Add Country Name to auth request from request headers (#5471)
* feat(pm-15015) : 
  * Add `CountryName` column to AuthRequest Table in Database, and refreshing AuthRequestView
  * Modify database stored procedures and Entity Framework migrations for AuthRequest Repositories
  * Add property to `ICurrentContext` and response models.
2025-03-10 12:16:43 -04:00
Daniel James Smith
031e188e82
Remove extension-refresh feature flag (#5410)
Co-authored-by: Daniel James Smith <djsmith85@users.noreply.github.com>
2025-03-10 11:53:07 -04:00
Rui Tomé
6e7c5b172c
[PM-18087] Add cipher permissions to response models (#5418)
* Add Manage permission to UserCipherDetails and CipherDetails_ReadByIdUserId

* Add Manage property to CipherDetails and UserCipherDetailsQuery

* Add integration test for CipherRepository Manage permission rules

* Update CipherDetails_ReadWithoutOrganizationsByUserId to include Manage permission

* Refactor UserCipherDetailsQuery to include detailed permission and organization properties

* Refactor CipherRepositoryTests to improve test organization and readability

- Split large test method into smaller, focused methods
- Added helper methods for creating test data and performing assertions
- Improved test coverage for cipher permissions in different scenarios
- Maintained existing test logic while enhancing code structure

* Refactor CipherRepositoryTests to consolidate cipher permission tests

- Removed redundant helper methods for permission assertions
- Simplified test methods for GetCipherPermissionsForOrganizationAsync, GetManyByUserIdAsync, and GetByIdAsync
- Maintained existing test coverage for cipher manage permissions
- Improved code readability and reduced code duplication

* Add integration test for CipherRepository group collection manage permissions

- Added new test method GetCipherPermissionsForOrganizationAsync_ManageProperty_RespectsCollectionGroupRules
- Implemented helper method CreateCipherInOrganizationCollectionWithGroup to support group-based collection permission testing
- Verified manage permissions are correctly applied based on group collection access settings

* Add @Manage parameter to Cipher stored procedures

- Updated CipherDetails_Create, CipherDetails_CreateWithCollections, and CipherDetails_Update stored procedures
- Added @Manage parameter with comment "-- not used"
- Included new stored procedure implementations in migration script
- Consistent with previous work on adding Manage property to cipher details

* Update UserCipherDetails functions to reorder Manage and ViewPassword columns

* [PM-18086] Add CanRestore and CanDelete authorization methods.

* [PM-18086] Address code review feedback.

* [PM-18086] Add missing part.

* [PM-18087] Add CipherPermissionsResponseModel for cipher permissions

* Add GetManyOrganizationAbilityAsync method to application cache service

* Add organization ability context to cipher response models

This change introduces organization ability context to various cipher response models across multiple controllers. The modifications include:

- Updating CipherResponseModel to include permissions based on user and organization ability
- Modifying CiphersController methods to fetch and pass organization abilities
- Updating SyncController to include organization abilities in sync response
- Adding organization ability context to EmergencyAccessController response generation

* Remove organization ability context from EmergencyAccessController

This change simplifies the EmergencyAccessController by removing unnecessary organization ability fetching and passing. Since emergency access only retrieves personal ciphers, the organization ability context is no longer needed in the response generation.

* Remove unused IApplicationCacheService from EmergencyAccessController

* Refactor EmergencyAccessViewResponseModel constructor

Remove unnecessary JsonConstructor attribute and simplify constructor initialization for EmergencyAccessViewResponseModel

* Refactor organization ability retrieval in CiphersController

Extract methods to simplify organization ability fetching for ciphers, reducing code duplication and improving readability. Added two private helper methods:
- GetOrganizationAbilityAsync: Retrieves organization ability for a single cipher
- GetManyOrganizationAbilitiesAsync: Retrieves organization abilities for multiple ciphers

* Update CiphersControllerTests to use GetUserByPrincipalAsync

Modify test methods to:
- Replace GetProperUserId with GetUserByPrincipalAsync
- Use User object instead of separate userId
- Update mocking to return User object
- Ensure user ID is correctly set in test scenarios

* Refactor CipherPermissionsResponseModel to use constructor-based initialization

* Refactor CipherPermissionsResponseModel to use record type and init-only properties

* [PM-18086] Undo files

* [PM-18086] Undo files

* Refactor organization abilities retrieval in cipher-related controllers and models

- Update CiphersController to use GetOrganizationAbilitiesAsync instead of individual methods
- Modify CipherResponseModel and CipherDetailsResponseModel to accept organization abilities dictionary
- Update CipherPermissionsResponseModel to handle organization abilities lookup
- Remove deprecated organization ability retrieval methods
- Simplify sync and emergency access response model handling of organization abilities

* Remove GetManyOrganizationAbilityAsync method

- Delete unused method from IApplicationCacheService interface
- Remove corresponding implementation in InMemoryApplicationCacheService
- Continues cleanup of organization ability retrieval methods

* Update CiphersControllerTests to include organization abilities retrieval

- Add organization abilities retrieval in test setup for PutCollections_vNext method
- Ensure consistent mocking of IApplicationCacheService in test scenarios

* Update error message for missing organization ability

---------

Co-authored-by: Jimmy Vo <huynhmaivo82@gmail.com>
2025-03-10 15:27:30 +00:00
cyprain-okeke
88e91734f1
[PM-17594]Remove feature flag self-host license refactor (#5372)
* Remove the feature flag

Signed-off-by: Cy Okeke <cokeke@bitwarden.com>

* Resolve the failing test

Signed-off-by: Cy Okeke <cokeke@bitwarden.com>

---------

Signed-off-by: Cy Okeke <cokeke@bitwarden.com>
Co-authored-by: Conner Turnbull <133619638+cturnbull-bitwarden@users.noreply.github.com>
2025-03-10 11:46:44 +01:00
Github Actions
f26f14165c Bumped version to 2025.3.0 2025-03-10 10:28:50 +00:00
Justin Baur
bd7a0a8ed8
Codespaces improvements (#4969)
* Skip one_time_setup in GH Codespaces

* Make .env File Optional

* Wrap Path in Single Quotes

* Comment out .env File

* Add Modify Database Task

* Work on modify_database.ps1

* Add space

* Remove compose version

* Do changes in community as well

* Do required: false

* Reverse check

* Remove printenv

* Skip DB changes

* Remove docker outside of docker feature

* Remove newlines
2025-03-09 16:56:04 -04:00
Daniel James Smith
34358acf61
Fix user context on importing into individual vaults (#5465)
Pass in the current userId instead of trying to infer it from the folders or ciphers passed into the ImportCiphersCommand

Kudos go to @MJebran who pointed this out on https://github.com/bitwarden/server/pull/4896

Co-authored-by: Daniel James Smith <djsmith85@users.noreply.github.com>
2025-03-07 15:09:54 +01:00
Jonas Hendrickx
c589f9a330
[BEEEP] [PM-18518] Cleanup StripePaymentService (#5435) 2025-03-07 09:52:04 +01:00
Jared McCannon
6cb97d9bf9
[PM-18972] - Fix query for Org By User Domain (#5474)
* Changed query to avoid table scan. Added index to speed up query as well.
2025-03-07 12:32:21 +10:00
Github Actions
bea0d0d76f Bumped version to 2025.2.4 2025-03-06 21:51:25 +00:00
Maciej Zieniuk
8628206fa9
ArgumentNullException: Value cannot be null in POST /push/register (#5472) 2025-03-06 22:13:02 +01:00
Alex Morask
cb1c12794f
Derive item add on status from price metadata (#5389) 2025-03-06 13:44:10 -05:00
Jimmy Vo
c82908f40b
[PM-15621] Add functionality to map command results to HTTP responses. (#5467) 2025-03-06 11:16:58 -05:00
Jonas Hendrickx
7281dd9b58
[PM-18163] Remove feature flag 'AC-1795_updated-subscription-status-section' (#5411) 2025-03-06 13:19:18 +01:00