Skip to content

Commit

Permalink
fix: move Authorization Policy to Shared and update policy of services
Browse files Browse the repository at this point in the history
  • Loading branch information
cowienduckie committed Nov 18, 2023
1 parent fc865ef commit ef84473
Show file tree
Hide file tree
Showing 13 changed files with 88 additions and 92 deletions.
9 changes: 9 additions & 0 deletions src/BuildingBlocks/Shared/CustomTypes/AuthorizationPolicy.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
namespace Shared.CustomTypes;

public struct AuthorizationPolicy
{
public const string ADMIN_ACCESS = nameof(ADMIN_ACCESS);
public const string MEMBER_ACCESS = nameof(MEMBER_ACCESS);

public const string ADMIN_MEMBER_ACCESS = nameof(ADMIN_MEMBER_ACCESS);
}
18 changes: 14 additions & 4 deletions src/MasterData/MasterData.Api/Extensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@
using MassTransit;
using MasterData.Api.Options;
using MasterData.Boundaries.Grpc;
using MasterData.Common.Constants;
using MasterData.Data;
using MasterData.IntegrationEvents.Consumers;
using MediatR;
Expand Down Expand Up @@ -74,9 +73,9 @@ public static WebApplication ConfigurePipeline(this WebApplication app)
.UseEndpoints(endpoints =>
{
endpoints.MapGrpcService<MasterDataService>();

endpoints.MapGraphQL();

endpoints
.MapBananaCakePop()
.WithOptions(new GraphQLToolOptions
Expand Down Expand Up @@ -286,12 +285,23 @@ private static IServiceCollection AddAuthentication(this IServiceCollection serv

services.AddAuthorization(o =>
{
o.AddPolicy(AuthorizationPolicy.ADMIN,
o.AddPolicy(AuthorizationPolicy.ADMIN_ACCESS,
policy =>
{
policy.RequireAssertion(c => c.User.IsInRole(Roles.ADMIN_ROLE_NAME)
|| c.User.IsInRole(Roles.SUPER_USER_ROLE_NAME));
});

o.AddPolicy(AuthorizationPolicy.MEMBER_ACCESS,
policy => { policy.RequireAssertion(c => c.User.IsInRole(Roles.MEMBER_ROLE_NAME)); });

o.AddPolicy(AuthorizationPolicy.ADMIN_MEMBER_ACCESS,
policy =>
{
policy.RequireAssertion(c => c.User.IsInRole(Roles.ADMIN_ROLE_NAME)
|| c.User.IsInRole(Roles.SUPER_USER_ROLE_NAME)
|| c.User.IsInRole(Roles.MEMBER_ROLE_NAME));
});
});

services
Expand Down
2 changes: 1 addition & 1 deletion src/MasterData/MasterData.Api/appsettings.json
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
}
},
"Redis": {
"Enabled": false,
"Enabled": true,
"Configuration": "localhost:6379",
"InstanceName": "Promag_",
"SlidingExpirationInSecond": 3600
Expand Down
16 changes: 8 additions & 8 deletions src/MasterData/MasterData/Boundaries/GraphQl/Query.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,14 @@
using MasterData.Boundaries.GraphQl.Dtos;
using MasterData.Boundaries.GraphQl.Filters;
using MasterData.Boundaries.GraphQl.ObjectTypes;
using MasterData.Common.Constants;
using MasterData.UseCases.Queries;
using MediatR;
using Microsoft.Extensions.Caching.Distributed;
using Microsoft.Extensions.Configuration;
using Promag.Protobuf.Commons.V1;
using Shared;
using Shared.Caching;
using Shared.CustomTypes;
using Shared.Serialization;

namespace MasterData.Boundaries.GraphQl;
Expand All @@ -23,14 +23,14 @@ namespace MasterData.Boundaries.GraphQl;
[SuppressMessage("ReSharper", "ClassNeverInstantiated.Global")]
public class Query
{
[GraphQLName("Ping")]
[GraphQLName("MasterDataPing")]
public async Task<PongReply> Ping([Service] ISender mediator)
{
return await mediator.Send(new PingQuery());
}

[GraphQLName("Countries")]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<IList<CountryDto>> GetCountries(
[Service] ISender mediator,
[Service] IDistributedCache distributedCache,
Expand All @@ -46,7 +46,7 @@ public async Task<IList<CountryDto>> GetCountries(
}

[GraphQLName("Languages")]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<IList<LanguageDto>> GetLanguages(
[Service] ISender mediator,
[Service] IDistributedCache distributedCache,
Expand All @@ -62,7 +62,7 @@ public async Task<IList<LanguageDto>> GetLanguages(
}

[GraphQLName("Timezones")]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<IList<TimezoneDto>> GetTimeZones(
[Service] ISender mediator,
[Service] IDistributedCache distributedCache,
Expand All @@ -78,7 +78,7 @@ public async Task<IList<TimezoneDto>> GetTimeZones(
}

[GraphQLName("Currencies")]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<IList<CurrencyDto>> GetCurrencies(
[Service] ISender mediator,
[Service] IDistributedCache distributedCache,
Expand All @@ -96,15 +96,15 @@ public async Task<IList<CurrencyDto>> GetCurrencies(
[GraphQLName("ActivityLogs")]
[UseOffsetPaging(typeof(ActivityLogType))]
[UseFiltering(typeof(ActivityLogFilterInputType))]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<IQueryable<ActivityLogDto>> GetActivityLogs([Service] ISender mediator)
{
return await mediator.Send(new GetActivityLogsQuery());
}

[GraphQLName("ActivityLog")]
[GraphQLType(typeof(ActivityLogType))]
[Authorize(AuthorizationPolicy.ADMIN)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<ActivityLogDto> GetActivityLogById(Guid id, [Service] ISender mediator)
{
return await mediator.Send(new GetActivityLogByIdQuery(id));
Expand Down

This file was deleted.

50 changes: 17 additions & 33 deletions src/PersonalData/PersonalData.Api/Extensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@
using OpenTelemetry.Trace;
using PersonalData.Api.Options;
using PersonalData.Boundaries.Grpc;
using PersonalData.Common.Constants;
using PersonalData.Data;
using PersonalData.Data.Audit;
using PersonalData.Data.Filters;
Expand Down Expand Up @@ -315,38 +314,23 @@ private static IServiceCollection AddAuthentication(this IServiceCollection serv

services.AddAuthorization(o =>
{
o.AddPolicy(AuthorizationPolicy.CAN_VIEW_USER, policy =>
{
policy.RequireAssertion(ctx => ctx.User
.HasClaim(claim =>
claim is { Type: Permissions.PERMISSION_CLAIM_TYPE, Value: Permissions.USER_VIEW or Permissions.USER_FULL }
)
);
});
o.AddPolicy(AuthorizationPolicy.CAN_EDIT_USER, policy =>
{
policy.RequireAssertion(ctx => ctx.User
.HasClaim(claim =>
claim is { Type: Permissions.PERMISSION_CLAIM_TYPE, Value: Permissions.USER_CREATE or Permissions.USER_FULL }
)
);
});
o.AddPolicy(AuthorizationPolicy.CAN_VIEW_ROLE, policy =>
{
policy.RequireAssertion(ctx => ctx.User
.HasClaim(claim =>
claim is { Type: Permissions.PERMISSION_CLAIM_TYPE, Value: Permissions.ROLE_VIEW or Permissions.ROLE_FULL }
)
);
});
o.AddPolicy(AuthorizationPolicy.CAN_EDIT_ROLE, policy =>
{
policy.RequireAssertion(ctx => ctx.User
.HasClaim(claim =>
claim is { Type: Permissions.PERMISSION_CLAIM_TYPE, Value: Permissions.ROLE_CREATE or Permissions.ROLE_FULL }
)
);
});
o.AddPolicy(AuthorizationPolicy.ADMIN_ACCESS,
policy =>
{
policy.RequireAssertion(c => c.User.IsInRole(Roles.ADMIN_ROLE_NAME)
|| c.User.IsInRole(Roles.SUPER_USER_ROLE_NAME));
});

o.AddPolicy(AuthorizationPolicy.MEMBER_ACCESS,
policy => { policy.RequireAssertion(c => c.User.IsInRole(Roles.MEMBER_ROLE_NAME)); });

o.AddPolicy(AuthorizationPolicy.ADMIN_MEMBER_ACCESS,
policy =>
{
policy.RequireAssertion(c => c.User.IsInRole(Roles.ADMIN_ROLE_NAME)
|| c.User.IsInRole(Roles.SUPER_USER_ROLE_NAME)
|| c.User.IsInRole(Roles.MEMBER_ROLE_NAME));
});
});

services
Expand Down
2 changes: 1 addition & 1 deletion src/PersonalData/PersonalData.Api/appsettings.json
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@
}
},
"Redis": {
"Enabled": false,
"Enabled": true,
"Configuration": "localhost:6379",
"InstanceName": "Promag",
"SlidingExpirationInSecond": 3600
Expand Down
12 changes: 6 additions & 6 deletions src/PersonalData/PersonalData/Boundaries/GraphQl/Mutation.cs
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,18 @@
using PersonalData.Boundaries.GraphQl.Dtos;
using PersonalData.Boundaries.GraphQl.InputObjectTypes;
using PersonalData.Boundaries.GraphQl.ObjectTypes;
using PersonalData.Common.Constants;
using PersonalData.UseCases.Commands;
using PersonalData.UseCases.Responses;
using Shared;
using Shared.Caching;
using Shared.CustomTypes;

namespace PersonalData.Boundaries.GraphQl;

public class Mutation
{
[GraphQLType(typeof(PersonType))]
[Authorize(AuthorizationPolicy.CAN_EDIT_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<PersonDto> EditUser(
[GraphQLType(typeof(EditUserInputType))]
EditUserCommand editUserInput,
Expand All @@ -37,7 +37,7 @@ public async Task<PersonDto> EditUser(
}

[GraphQLType(typeof(InviteUserResponseType))]
[Authorize(AuthorizationPolicy.CAN_EDIT_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<InviteUserResponse> InviteUser(
[GraphQLType(typeof(InviteUserInputType))]
InviteUserCommand inviteUserInput,
Expand All @@ -46,7 +46,7 @@ public async Task<InviteUserResponse> InviteUser(
return await mediator.Send(inviteUserInput);
}

[Authorize(AuthorizationPolicy.CAN_EDIT_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<bool> UnlockUser(
[GraphQLType(typeof(UnlockUserInputType))]
UnlockUserCommand unlockUserInput,
Expand All @@ -65,7 +65,7 @@ public async Task<bool> UnlockUser(
return result;
}

[Authorize(AuthorizationPolicy.CAN_EDIT_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<bool> LockUser(
[GraphQLType(typeof(LockUserInputType))]
LockUserCommand lockUserInput,
Expand All @@ -84,7 +84,7 @@ public async Task<bool> LockUser(
return result;
}

[Authorize(AuthorizationPolicy.CAN_EDIT_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_ACCESS)]
public async Task<bool> UpdateRolePermissions(UpdateRolePermissionsCommand updatePermissionsInput, [Service] ISender mediator)
{
return await mediator.Send(updatePermissionsInput);
Expand Down
22 changes: 14 additions & 8 deletions src/PersonalData/PersonalData/Boundaries/GraphQl/Query.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,31 +12,37 @@
using PersonalData.Boundaries.GraphQl.Dtos;
using PersonalData.Boundaries.GraphQl.Filters;
using PersonalData.Boundaries.GraphQl.ObjectTypes;
using PersonalData.Common.Constants;
using PersonalData.Common.Enums;
using PersonalData.Services;
using PersonalData.UseCases.Queries;
using Promag.Protobuf.Commons.V1;
using Promag.Protobuf.Identity.V1;
using Shared;
using Shared.Caching;
using Shared.CustomTypes;
using UserType = PersonalData.Common.Enums.UserType;

namespace PersonalData.Boundaries.GraphQl;

public class Query
{
[GraphQLName("PersonalDataPing")]
public async Task<PongReply> Ping([Service] ISender mediator)
{
return await mediator.Send(new PingQuery());
}

[GraphQLName("Users")]
[UseOffsetPaging(typeof(PersonType))]
[UseFiltering(typeof(PersonFilterType))]
[Authorize(AuthorizationPolicy.CAN_VIEW_USER)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<IQueryable<PersonDto>> GetUsers([Service] IMediator mediator)
{
return await mediator.Send(new GetPeopleQuery(UserType.User));
}

[GraphQLName("Person")]
[GraphQLType(typeof(PersonType))]
[Authorize(AuthorizationPolicy.CAN_VIEW_USER)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<PersonDto?> GetPersonById(
Guid personId,
[Service] ISender mediator,
Expand Down Expand Up @@ -75,7 +81,7 @@ public async Task<IQueryable<PersonDto>> GetUsers([Service] IMediator mediator)

[GraphQLName("Me")]
[GraphQLType(typeof(PersonType))]
[Authorize(AuthorizationPolicy.CAN_VIEW_USER)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<PersonDto?> GetMyProfile(
[Service] IHttpContextAccessor contextAccessor,
[Service] ISender mediator)
Expand All @@ -94,7 +100,7 @@ public async Task<IQueryable<PersonDto>> GetUsers([Service] IMediator mediator)

[GraphQLName("Roles")]
[GraphQLType(typeof(ListType<RoleType>))]
[Authorize(AuthorizationPolicy.CAN_VIEW_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<List<RoleDto>> GetRoles(
[Service] IHttpContextAccessor contextAccessor,
[Service] IIdentityService identityService)
Expand All @@ -119,7 +125,7 @@ superRole is not null &&

[GraphQLName("Role")]
[GraphQLType(typeof(RoleType))]
[Authorize(AuthorizationPolicy.CAN_VIEW_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<RoleDto?> GetRoleById(
Guid roleId,
[Service] IIdentityService identityService)
Expand All @@ -131,7 +137,7 @@ superRole is not null &&

[GraphQLName("Permissions")]
[GraphQLType(typeof(ListType<StringType>))]
[Authorize(AuthorizationPolicy.CAN_VIEW_ROLE)]
[Authorize(AuthorizationPolicy.ADMIN_MEMBER_ACCESS)]
public async Task<List<string>> GetRolePermissions(
Guid roleId,
[Service] ISender mediator)
Expand Down

This file was deleted.

Loading

0 comments on commit ef84473

Please sign in to comment.