This commit is contained in:
Holger Börchers 2020-09-27 22:16:57 +02:00
parent 1811ea5a1a
commit 5c86727baa
9 changed files with 55 additions and 11 deletions

View File

@ -37,13 +37,20 @@ namespace UserService.DatabaseLayer.Repositories
public virtual async Task<IReadOnlyList<T>> GetAllAsync(Expression<Func<T, bool>>? predicate = null, CancellationToken token = default) public virtual async Task<IReadOnlyList<T>> GetAllAsync(Expression<Func<T, bool>>? predicate = null, CancellationToken token = default)
{ {
await using var db = new UserServiceDbContext(); await using var db = new UserServiceDbContext();
return await Context(db).Include(x => x.Parent).WhereOrDefault(predicate).ToListAsync(token).ConfigureAwait(false); return await Context(db)
.Include(x => x.Parent)
.WhereOrDefault(predicate)
.ToListAsync(token)
.ConfigureAwait(false);
} }
public virtual async Task<T?> GetAsync(Expression<Func<T, bool>> predicate, CancellationToken token = default) public virtual async Task<T?> GetAsync(Expression<Func<T, bool>> predicate, CancellationToken token = default)
{ {
await using var db = new UserServiceDbContext(); await using var db = new UserServiceDbContext();
return await Context(db).Include(x => x.Parent).FirstOrDefaultAsync(predicate, token).ConfigureAwait(false); return await Context(db)
.Include(x => x.Parent)
.FirstOrDefaultAsync(predicate, token)
.ConfigureAwait(false);
} }
public virtual async Task<bool> UpdateAsync(T entity, CancellationToken token = default) public virtual async Task<bool> UpdateAsync(T entity, CancellationToken token = default)
{ {

View File

@ -32,8 +32,10 @@ namespace UserService.DatabaseLayer.Repositories
} }
public interface IMembersRepository : IRepository<Member> public interface IMembersRepository
{ {
} }
} }

View File

@ -24,7 +24,7 @@ namespace UserService.DatabaseLayer.Repositories
var rootOus = await Context(db) var rootOus = await Context(db)
.Include(x => x.Parent) .Include(x => x.Parent)
.WhereOrDefault(predicate) .WhereOrDefault(predicate)
.ToListAsync(cancellationToken: token).ConfigureAwait(false); .ToListAsync(token).ConfigureAwait(false);
IEnumerable<OrganizationUnit> Rec(Node node) IEnumerable<OrganizationUnit> Rec(Node node)
{ {

View File

@ -1,4 +1,6 @@
using Microsoft.EntityFrameworkCore; #nullable enable
using Microsoft.EntityFrameworkCore;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
@ -39,8 +41,11 @@ namespace UserService.DatabaseLayer.Repositories
public override async Task<bool> UpdateAsync(SecurityGroup entity, CancellationToken token = default) public override async Task<bool> UpdateAsync(SecurityGroup entity, CancellationToken token = default)
{ {
if (entity == null) throw new ArgumentNullException(nameof(entity));
await using var db = new UserServiceDbContext(); await using var db = new UserServiceDbContext();
Context(db).Update(entity); Context(db).Update(entity);
db.UserMembers.UpdateRange(entity.Members);
var items = await db.SaveChangesAsync(token).ConfigureAwait(false); var items = await db.SaveChangesAsync(token).ConfigureAwait(false);
return items > 0; return items > 0;
} }

View File

@ -4,8 +4,8 @@ namespace UserService.Infrastructure.DataModels
{ {
public abstract class Member : Node public abstract class Member : Node
{ {
public ICollection<MembersMember> Members { get; set; } = new List<MembersMember>(); public ISet<MembersMember> Members { get; set; } = new HashSet<MembersMember>();
public ICollection<MembersMember> MemberOf { get; set; } = null!; public ISet<MembersMember> MemberOf { get; set; } = null!;
} }
} }

View File

@ -9,5 +9,22 @@ namespace UserService.Infrastructure.DataModels
public Guid AttachedMemberId { get; set; } public Guid AttachedMemberId { get; set; }
public Member? AttachedMember { get; set; } public Member? AttachedMember { get; set; }
public override bool Equals(object obj) => Equals((MembersMember)obj);
public bool Equals(MembersMember other)
{
return MemberId.Equals(other.MemberId) && AttachedMemberId.Equals(other.AttachedMemberId);
}
public override int GetHashCode()
{
unchecked
{
var hashCode = MemberId.GetHashCode();
hashCode = (hashCode * 397) ^ AttachedMemberId.GetHashCode();
return hashCode;
}
}
} }
} }

View File

@ -5,12 +5,12 @@ using System.ComponentModel.DataAnnotations;
namespace UserService.Infrastructure.DataModels namespace UserService.Infrastructure.DataModels
{ {
public abstract class Node : ICloneable public abstract class Node : ICloneable, IComparable<Node>
{ {
public Guid Id { get; set; } public Guid Id { get; set; }
[Required] public string CommonName { get; set; } = null!; [Required] public string CommonName { get; set; } = null!;
public string? Description { get; set; } public string? Description { get; set; }
public ICollection<Node> Children { get; set; } = new List<Node>(); public ISet<Node> Children { get; set; } = new SortedSet<Node>();
public Node? Parent { get; set; } //Parent public Node? Parent { get; set; } //Parent
public Guid? ParentId { get; set; } public Guid? ParentId { get; set; }
@ -20,5 +20,14 @@ namespace UserService.Infrastructure.DataModels
/// <inheritdoc /> /// <inheritdoc />
public virtual object Clone() => MemberwiseClone(); public virtual object Clone() => MemberwiseClone();
public int CompareTo(Node? other)
{
if (ReferenceEquals(this, other)) return 0;
if (ReferenceEquals(null, other)) return 1;
var commonNameComparison = string.Compare(CommonName, other.CommonName, StringComparison.Ordinal);
if (commonNameComparison != 0) return commonNameComparison;
return Id.CompareTo(other.Id);
}
} }
} }

Binary file not shown.

View File

@ -96,13 +96,17 @@ namespace UserService.Pages
{ {
if (SelectedMember is null) return; if (SelectedMember is null) return;
if (SelectedSecurityGroup is null) return; if (SelectedSecurityGroup is null) return;
SelectedSecurityGroup.Members.Add(new MembersMember if (!SelectedSecurityGroup.Members.Add(new MembersMember
{ {
MemberId = SelectedSecurityGroup.Id, MemberId = SelectedSecurityGroup.Id,
Member = SelectedSecurityGroup, Member = SelectedSecurityGroup,
AttachedMemberId = SelectedMember.Id, AttachedMemberId = SelectedMember.Id,
AttachedMember = SelectedMember AttachedMember = SelectedMember
}); }))
{
await JsRuntime.AlertAsync("User already part of the list.").ConfigureAwait(false);
}
SelectedMember = default; SelectedMember = default;
} }