Skip to content
This repository was archived by the owner on Dec 19, 2025. It is now read-only.
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions .config/dotnet-tools.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"version": 1,
"isRoot": true,
"tools": {
"csharpier": {
"version": "0.27.3",
"commands": [
"dotnet-csharpier"
]
}
}
}
16 changes: 14 additions & 2 deletions Application/EdFi.Ods.AdminApi/Features/ClaimSets/ClaimSetModel.cs
Original file line number Diff line number Diff line change
Expand Up @@ -44,14 +44,26 @@ public class ClaimSetResourceClaimModel
public List<ClaimSetResourceClaimActionAuthStrategies?> AuthorizationStrategyOverridesForCRUD { get; set; }

[SwaggerSchema(Description = "Children are collection of ResourceClaim")]
public List<ClaimSetResourceClaimModel> Children { get; set; }
public List<ChildrenClaimSetResource> Children { get; set; }
public ClaimSetResourceClaimModel()
{
Children = new List<ClaimSetResourceClaimModel>();
Children = new List<ChildrenClaimSetResource>();
DefaultAuthorizationStrategiesForCRUD = new List<ClaimSetResourceClaimActionAuthStrategies?>();
AuthorizationStrategyOverridesForCRUD = new List<ClaimSetResourceClaimActionAuthStrategies?>();
Actions = new List<ResourceClaimAction>();
}
}


public class ChildrenClaimSetResource: ClaimSetResourceClaimModel
{
[SwaggerSchema(Description = "Children are collection of ResourceClaim")]
public new List<ClaimSetResourceClaimModel> Children { get; set; }

public ChildrenClaimSetResource()
{
Children = new List<ClaimSetResourceClaimModel>();
}
}
[SwaggerSchema(Title = "ResourceClaimModel")]
public class ResourceClaimModel
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,8 @@ public class Validator : AbstractValidator<Request>
public Validator(IGetAllClaimSetsQuery getAllClaimSetsQuery,
IGetResourceClaimsAsFlatListQuery getResourceClaimsAsFlatListQuery,
IGetAllAuthorizationStrategiesQuery getAllAuthorizationStrategiesQuery,
IGetAllActionsQuery getAllActionsQuery)
IGetAllActionsQuery getAllActionsQuery,
IMapper mapper)
{
_getAllClaimSetsQuery = getAllClaimSetsQuery;

Expand Down Expand Up @@ -92,7 +93,7 @@ public Validator(IGetAllClaimSetsQuery getAllClaimSetsQuery,
foreach (var resourceClaim in claimSet.ResourceClaims)
{
resourceClaimValidator.Validate(resourceClaims, actions, authStrategyNames,
resourceClaim, claimSet.ResourceClaims, context, claimSet.Name);
resourceClaim, mapper.Map<List<ChildrenClaimSetResource>>(claimSet.ResourceClaims), context, claimSet.Name);
}
}
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ public ResourceClaimValidator()
}

public void Validate<T>(Lookup<string, ResourceClaim> dbResourceClaims, List<string> dbActions,
List<string?> dbAuthStrategies, ClaimSetResourceClaimModel resourceClaim, List<ClaimSetResourceClaimModel> existingResourceClaims,
List<string?> dbAuthStrategies, ClaimSetResourceClaimModel resourceClaim, List<ChildrenClaimSetResource> existingResourceClaims,
ValidationContext<T> context, string? claimSetName)
{
context.MessageFormatter.AppendArgument("ClaimSetName", claimSetName);
Expand Down Expand Up @@ -55,7 +55,7 @@ private static void ValidateIfExist<T>(ValidationContext<T> context, string prop
}
}

private static void ValidateDuplicateResourceClaim<T>(ClaimSetResourceClaimModel resourceClaim, List<ClaimSetResourceClaimModel> existingResourceClaims, ValidationContext<T> context, string propertyName)
private static void ValidateDuplicateResourceClaim<T>(ClaimSetResourceClaimModel resourceClaim, List<ChildrenClaimSetResource> existingResourceClaims, ValidationContext<T> context, string propertyName)
{
if (existingResourceClaims.Count(x => x.Name == resourceClaim.Name) > 1)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,13 @@ public AdminApiMappingProfile()
.ForMember(dst => dst.DefaultAuthorizationStrategiesForCRUD, opt => opt.MapFrom(src => src.DefaultAuthStrategiesForCRUD))
.ForMember(dst => dst.Children, opt => opt.MapFrom(src => src.Children));

CreateMap<ClaimSetResourceClaimModel, ChildrenClaimSetResource>()
.ForMember(dst => dst.Name, opt => opt.MapFrom(src => src.Name))
.ForMember(dst => dst.Actions, opt => opt.MapFrom(src => src.Actions))
.ForMember(dst => dst.AuthorizationStrategyOverridesForCRUD, opt => opt.MapFrom(src => src.AuthorizationStrategyOverridesForCRUD))
.ForMember(dst => dst.DefaultAuthorizationStrategiesForCRUD, opt => opt.MapFrom(src => src.DefaultAuthorizationStrategiesForCRUD))
.ForMember(dst => dst.Children, opt => opt.MapFrom(src => src.Children));

CreateMap<IResourceClaimOnClaimSetRequest, EditResourceOnClaimSetModel>()
.ForMember(dst => dst.ClaimSetId, opt => opt.MapFrom(src => src.ClaimSetId))
.ForMember(dst => dst.ResourceClaim, opt => opt.MapFrom<ResourceClaimResolver>());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ public static IServiceCollection AddHealthCheck(this IServiceCollection services
else
{
connectionStrings = new() {
{ "SingleTenant", configuration.GetConnectionString(dbName) }};
{ "SingleTenant", configuration.GetConnectionString(dbName) ?? string.Empty }};
}

if (!string.IsNullOrEmpty(databaseEngine))
Expand Down