Files
server/src/Infrastructure.Dapper/Repositories/PolicyRepository.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

60 lines
2.0 KiB
C#
Raw Normal View History

using System.Data;
using Bit.Core.Entities;
2020-01-20 08:53:09 -05:00
using Bit.Core.Enums;
using Bit.Core.Repositories;
using Bit.Core.Settings;
2021-12-16 15:35:09 +01:00
using Dapper;
using Microsoft.Data.SqlClient;
2020-01-06 14:27:16 -05:00
namespace Bit.Infrastructure.Dapper.Repositories;
2022-08-29 16:06:55 -04:00
public class PolicyRepository : Repository<Policy, Guid>, IPolicyRepository
2020-01-06 14:27:16 -05:00
{
public PolicyRepository(GlobalSettings globalSettings)
: this(globalSettings.SqlServer.ConnectionString, globalSettings.SqlServer.ReadOnlyConnectionString)
{ }
public PolicyRepository(string connectionString, string readOnlyConnectionString)
: base(connectionString, readOnlyConnectionString)
{ }
2020-01-20 08:53:09 -05:00
public async Task<Policy> GetByOrganizationIdTypeAsync(Guid organizationId, PolicyType type)
2022-08-29 16:06:55 -04:00
{
using (var connection = new SqlConnection(ConnectionString))
2020-01-20 08:53:09 -05:00
{
var results = await connection.QueryAsync<Policy>(
$"[{Schema}].[{Table}_ReadByOrganizationIdType]",
new { OrganizationId = organizationId, Type = (byte)type },
commandType: CommandType.StoredProcedure);
return results.SingleOrDefault();
}
2022-08-29 16:06:55 -04:00
}
2020-01-06 14:27:16 -05:00
public async Task<ICollection<Policy>> GetManyByOrganizationIdAsync(Guid organizationId)
2022-08-29 16:06:55 -04:00
{
using (var connection = new SqlConnection(ConnectionString))
2020-01-06 14:27:16 -05:00
{
var results = await connection.QueryAsync<Policy>(
$"[{Schema}].[{Table}_ReadByOrganizationId]",
new { OrganizationId = organizationId },
commandType: CommandType.StoredProcedure);
return results.ToList();
}
2022-08-29 16:06:55 -04:00
}
2020-01-28 15:33:32 -05:00
public async Task<ICollection<Policy>> GetManyByUserIdAsync(Guid userId)
2022-08-29 16:06:55 -04:00
{
using (var connection = new SqlConnection(ConnectionString))
2020-01-28 15:33:32 -05:00
{
var results = await connection.QueryAsync<Policy>(
$"[{Schema}].[{Table}_ReadByUserId]",
new { UserId = userId },
commandType: CommandType.StoredProcedure);
return results.ToList();
}
2022-08-29 16:06:55 -04:00
}
2020-01-06 14:27:16 -05:00
}