mirror of
https://github.com/bitwarden/server
synced 2025-12-06 00:03:34 +00:00
Long lived feature branch for Secrets Manager Co-authored-by: Thomas Avery <43214426+Thomas-Avery@users.noreply.github.com> Co-authored-by: cd-bitwarden <106776772+cd-bitwarden@users.noreply.github.com> Co-authored-by: CarleyDiaz-Bitwarden <103955722+CarleyDiaz-Bitwarden@users.noreply.github.com> Co-authored-by: Thomas Avery <tavery@bitwarden.com> Co-authored-by: Colton Hurst <colton@coltonhurst.com>
74 lines
3.0 KiB
C#
74 lines
3.0 KiB
C#
using System.Linq.Expressions;
|
|
using AutoMapper;
|
|
using Bit.Core.Repositories;
|
|
using Bit.Infrastructure.EntityFramework.Models;
|
|
using Bit.Infrastructure.EntityFramework.Repositories;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
|
|
namespace Bit.Commercial.Infrastructure.EntityFramework.Repositories;
|
|
|
|
public class ProjectRepository : Repository<Core.Entities.Project, Project, Guid>, IProjectRepository
|
|
{
|
|
public ProjectRepository(IServiceScopeFactory serviceScopeFactory, IMapper mapper)
|
|
: base(serviceScopeFactory, mapper, db => db.Project)
|
|
{ }
|
|
|
|
public override async Task<Core.Entities.Project> GetByIdAsync(Guid id)
|
|
{
|
|
using (var scope = ServiceScopeFactory.CreateScope())
|
|
{
|
|
var dbContext = GetDatabaseContext(scope);
|
|
var project = await dbContext.Project
|
|
.Where(c => c.Id == id && c.DeletedDate == null)
|
|
.FirstOrDefaultAsync();
|
|
return Mapper.Map<Core.Entities.Project>(project);
|
|
}
|
|
}
|
|
|
|
public async Task<IEnumerable<Core.Entities.Project>> GetManyByOrganizationIdAsync(Guid organizationId, Guid userId)
|
|
{
|
|
using var scope = ServiceScopeFactory.CreateScope();
|
|
var dbContext = GetDatabaseContext(scope);
|
|
var project = await dbContext.Project
|
|
.Where(p => p.OrganizationId == organizationId && p.DeletedDate == null)
|
|
// TODO: Enable this + Handle Admins
|
|
//.Where(UserHasAccessToProject(userId))
|
|
.OrderBy(p => p.RevisionDate)
|
|
.ToListAsync();
|
|
return Mapper.Map<List<Core.Entities.Project>>(project);
|
|
}
|
|
|
|
private static Expression<Func<Project, bool>> UserHasAccessToProject(Guid userId) => p =>
|
|
p.UserAccessPolicies.Any(ap => ap.OrganizationUser.User.Id == userId && ap.Read) ||
|
|
p.GroupAccessPolicies.Any(ap => ap.Group.GroupUsers.Any(gu => gu.OrganizationUser.User.Id == userId && ap.Read));
|
|
|
|
public async Task DeleteManyByIdAsync(IEnumerable<Guid> ids)
|
|
{
|
|
using (var scope = ServiceScopeFactory.CreateScope())
|
|
{
|
|
var dbContext = GetDatabaseContext(scope);
|
|
var utcNow = DateTime.UtcNow;
|
|
var projects = dbContext.Project.Where(c => ids.Contains(c.Id));
|
|
await projects.ForEachAsync(project =>
|
|
{
|
|
dbContext.Remove(project);
|
|
});
|
|
await dbContext.SaveChangesAsync();
|
|
}
|
|
}
|
|
|
|
public async Task<IEnumerable<Core.Entities.Project>> GetManyByIds(IEnumerable<Guid> ids)
|
|
{
|
|
using (var scope = ServiceScopeFactory.CreateScope())
|
|
{
|
|
var dbContext = GetDatabaseContext(scope);
|
|
var projects = await dbContext.Project
|
|
.Where(c => ids.Contains(c.Id) && c.DeletedDate == null)
|
|
.ToListAsync();
|
|
return Mapper.Map<List<Core.Entities.Project>>(projects);
|
|
}
|
|
|
|
}
|
|
}
|