mirror of
https://github.com/bitwarden/server.git
synced 2025-04-24 22:32:22 -05:00

* [PM-17562] Slack Event Investigation * Refactored Slack and Webhook integrations to pull configurations dynamically from a new Repository * Added new TemplateProcessor and added/updated unit tests * SlackService improvements, testing, integration configurations * Refactor SlackService to use a dedicated model to parse responses * Refactored SlackOAuthController to use SlackService as an injected dependency; added tests for SlackService * Remove unnecessary methods from the IOrganizationIntegrationConfigurationRepository * Moved Slack OAuth to take into account the Organization it's being stored for. Added methods to store the top level integration for Slack * Organization integrations and configuration database schemas * Format EF files * Initial buildout of basic repositories * [PM-17562] Add Dapper Repositories For Organization Integrations and Configurations * Update Slack and Webhook handlers to use new Repositories * Update SlackOAuth tests to new signatures * Added EF Repositories * Update handlers to use latest repositories * [PM-17562] Add Dapper and EF Repositories For Ogranization Integrations and Configurations * Updated with changes from PR comments * Adjusted Handlers to new repository method names; updated tests to naming convention * Adjust URL structure; add delete for Slack, add tests * Added Webhook Integration Controller * Add tests for WebhookIntegrationController * Added Create/Delete for OrganizationIntegrationConfigurations * Prepend ConnectionTypes into IntegrationType so we don't run into issues later * Added Update to OrganizationIntegrationConfigurtionController * Moved Webhook-specific integration code to being a generic controller for everything but Slack * Removed delete from SlackController - Deletes should happen through the normal Integration controller * Fixed SlackController, reworked OIC Controller to use ids from URL and update the returned object * Added parse/type checking for integration and integration configuration JSONs, Cleaned up GlobalSettings to remove old values * Cleanup and fixes for Azure Service Bus support * Clean up naming on TemplateProcessorTests * Address SonarQube warnings/suggestions * Expanded test coverage; Cleaned up tests * Respond to PR Feedback * Rename TemplateProcessor to IntegrationTemplateProcessor --------- Co-authored-by: Matt Bishop <mbishop@bitwarden.com>
121 lines
3.4 KiB
C#
121 lines
3.4 KiB
C#
using System.Text.Json;
|
|
using Bit.Api.AdminConsole.Models.Request.Organizations;
|
|
using Bit.Core.Enums;
|
|
using Bit.Core.Models.Data.Integrations;
|
|
using Xunit;
|
|
|
|
namespace Bit.Api.Test.AdminConsole.Models.Request.Organizations;
|
|
|
|
public class OrganizationIntegrationConfigurationRequestModelTests
|
|
{
|
|
[Fact]
|
|
public void IsValidForType_CloudBillingSyncIntegration_ReturnsFalse()
|
|
{
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = "{}",
|
|
Template = "template"
|
|
};
|
|
|
|
Assert.False(model.IsValidForType(IntegrationType.CloudBillingSync));
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(null)]
|
|
[InlineData("")]
|
|
[InlineData(" ")]
|
|
public void IsValidForType_EmptyConfiguration_ReturnsFalse(string? config)
|
|
{
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = config,
|
|
Template = "template"
|
|
};
|
|
|
|
var result = model.IsValidForType(IntegrationType.Slack);
|
|
|
|
Assert.False(result);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(null)]
|
|
[InlineData("")]
|
|
[InlineData(" ")]
|
|
public void IsValidForType_EmptyTemplate_ReturnsFalse(string? template)
|
|
{
|
|
var config = JsonSerializer.Serialize(new WebhookIntegrationConfiguration("https://example.com"));
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = config,
|
|
Template = template
|
|
};
|
|
|
|
Assert.False(model.IsValidForType(IntegrationType.Webhook));
|
|
}
|
|
|
|
[Fact]
|
|
public void IsValidForType_InvalidJsonConfiguration_ReturnsFalse()
|
|
{
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = "{not valid json}",
|
|
Template = "template"
|
|
};
|
|
|
|
Assert.False(model.IsValidForType(IntegrationType.Webhook));
|
|
}
|
|
|
|
[Fact]
|
|
public void IsValidForType_ScimIntegration_ReturnsFalse()
|
|
{
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = "{}",
|
|
Template = "template"
|
|
};
|
|
|
|
Assert.False(model.IsValidForType(IntegrationType.Scim));
|
|
}
|
|
|
|
[Fact]
|
|
public void IsValidForType_ValidSlackConfiguration_ReturnsTrue()
|
|
{
|
|
var config = JsonSerializer.Serialize(new SlackIntegrationConfiguration("C12345"));
|
|
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = config,
|
|
Template = "template"
|
|
};
|
|
|
|
Assert.True(model.IsValidForType(IntegrationType.Slack));
|
|
}
|
|
|
|
[Fact]
|
|
public void IsValidForType_ValidWebhookConfiguration_ReturnsTrue()
|
|
{
|
|
var config = JsonSerializer.Serialize(new WebhookIntegrationConfiguration("https://example.com"));
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = config,
|
|
Template = "template"
|
|
};
|
|
|
|
Assert.True(model.IsValidForType(IntegrationType.Webhook));
|
|
}
|
|
|
|
[Fact]
|
|
public void IsValidForType_UnknownIntegrationType_ReturnsFalse()
|
|
{
|
|
var model = new OrganizationIntegrationConfigurationRequestModel
|
|
{
|
|
Configuration = "{}",
|
|
Template = "template"
|
|
};
|
|
|
|
var unknownType = (IntegrationType)999;
|
|
|
|
Assert.False(model.IsValidForType(unknownType));
|
|
}
|
|
}
|