Skip to content

Commit

Permalink
Merge branch 'develop'
Browse files Browse the repository at this point in the history
  • Loading branch information
furkandeveloper committed Oct 16, 2021
2 parents 1c300c8 + 68b06b1 commit 4d705c7
Show file tree
Hide file tree
Showing 57 changed files with 2,568 additions and 14 deletions.
110 changes: 110 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
# Rules in this file were initially inferred by Visual Studio IntelliCode from the C:\Users\User\source\MyProjects\Public\furkandeveloper\EasyPermissionManagement codebase based on best match to current usage at 12.10.2021
# You can modify the rules from these initially generated values to suit your own policies
# You can learn more about editorconfig here: https://docs.microsoft.com/en-us/visualstudio/ide/editorconfig-code-style-settings-reference
[*.cs]


#Core editorconfig formatting - indentation

#use soft tabs (spaces) for indentation
indent_style = space

#Formatting - new line options

#require members of anonymous types to be on separate lines
csharp_new_line_before_members_in_anonymous_types = true
#require members of object intializers to be on separate lines
csharp_new_line_before_members_in_object_initializers = true
#require braces to be on a new line for methods, control_blocks, types, lambdas, anonymous_types, and object_collection_array_initializers (also known as "Allman" style)
csharp_new_line_before_open_brace = methods, control_blocks, types, lambdas, anonymous_types, object_collection_array_initializers

#Formatting - organize using options

#do not place System.* using directives before other using directives
dotnet_sort_system_directives_first = false

#Formatting - spacing options

#require NO space between a cast and the value
csharp_space_after_cast = false
#require a space before the colon for bases or interfaces in a type declaration
csharp_space_after_colon_in_inheritance_clause = true
#require a space after a keyword in a control flow statement such as a for loop
csharp_space_after_keywords_in_control_flow_statements = true
#require a space before the colon for bases or interfaces in a type declaration
csharp_space_before_colon_in_inheritance_clause = true
#remove space within empty argument list parentheses
csharp_space_between_method_call_empty_parameter_list_parentheses = false
#remove space between method call name and opening parenthesis
csharp_space_between_method_call_name_and_opening_parenthesis = false
#do not place space characters after the opening parenthesis and before the closing parenthesis of a method call
csharp_space_between_method_call_parameter_list_parentheses = false
#remove space within empty parameter list parentheses for a method declaration
csharp_space_between_method_declaration_empty_parameter_list_parentheses = false
#place a space character after the opening parenthesis and before the closing parenthesis of a method declaration parameter list.
csharp_space_between_method_declaration_parameter_list_parentheses = false

#Formatting - wrapping options

#leave code block on single line
csharp_preserve_single_line_blocks = true

#Style - Code block preferences

#prefer curly braces even for one line of code
csharp_prefer_braces = true:suggestion

#Style - expression bodied member options

#prefer block bodies for constructors
csharp_style_expression_bodied_constructors = false:suggestion
#prefer block bodies for methods
csharp_style_expression_bodied_methods = false:suggestion

#Style - expression level options

#prefer the language keyword for member access expressions, instead of the type name, for types that have a keyword to represent them
dotnet_style_predefined_type_for_member_access = true:suggestion

#Style - Expression-level preferences

#prefer objects to be initialized using object initializers when possible
dotnet_style_object_initializer = true:suggestion
#prefer inferred anonymous type member names
dotnet_style_prefer_inferred_anonymous_type_member_names = false:suggestion

#Style - implicit and explicit types

#prefer var over explicit type in all cases, unless overridden by another code style rule
csharp_style_var_elsewhere = true:suggestion
#prefer explicit type over var to declare variables with built-in system types such as int
csharp_style_var_for_built_in_types = false:suggestion
#prefer var when the type is already mentioned on the right-hand side of a declaration expression
csharp_style_var_when_type_is_apparent = true:suggestion

#Style - language keyword and framework type options

#prefer the language keyword for local variables, method parameters, and class members, instead of the type name, for types that have a keyword to represent them
dotnet_style_predefined_type_for_locals_parameters_members = true:suggestion

#Style - modifier options

#prefer accessibility modifiers to be declared except for public interface members. This will currently not differ from always and will act as future proofing for if C# adds default interface methods.
dotnet_style_require_accessibility_modifiers = for_non_interface_members:suggestion

#Style - Modifier preferences

#when this rule is set to a list of modifiers, prefer the specified ordering.
csharp_preferred_modifier_order = public,protected,private,static,virtual,override,async,readonly,abstract:suggestion

#Style - Pattern matching

#prefer pattern matching instead of is expression with type casts
csharp_style_pattern_matching_over_as_with_null_check = true:suggestion

#Style - qualification options

#prefer fields not to be prefaced with this. or Me. in Visual Basic
dotnet_style_qualification_for_field = false:suggestion
#prefer properties not to be prefaced with this. or Me. in Visual Basic
dotnet_style_qualification_for_property = false:suggestion
4 changes: 3 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -360,4 +360,6 @@ MigrationBackup/
.ionide/

# Fody - auto-generated XML schema
FodyWeavers.xsd
FodyWeavers.xsd

appsettings.*.json
18 changes: 18 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
<p align="center">
<img src="https://user-images.githubusercontent.com/47147484/136712257-bf88799b-f3e8-4102-bf77-91bdf6a9f5b6.png" style="max-width:100%;" height="140" />
</p>


## Changelog for EasyPermissionManagement

This document includes changelog for EasyPermissionManagement.

For Every version must be store changelog.

- ### ✨ v1.0.0 [10.10.2021]

> ⛏ Implement infrastructure layer<br/>
> ⛏ Implement AspNetCore module<br/>
> ⛏ Implement EF Core module<br/>
> ⛏ Implement PostgreSql module<br/>
> ⛏ Implement Core module
71 changes: 70 additions & 1 deletion EasyPermissionManagement.sln
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,24 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{62CB44B7-4F0
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "sample", "sample", "{F8D0F299-BAF9-4C19-B3BA-BBFA582EF663}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "EasyPermissionManagement.Core", "src\EasyPermissionManagement.Core\EasyPermissionManagement.Core.csproj", "{FFFE218C-C1FB-48AF-A94D-599853495DCD}"
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EasyPermissionManagement.Core", "src\EasyPermissionManagement.Core\EasyPermissionManagement.Core.csproj", "{FFFE218C-C1FB-48AF-A94D-599853495DCD}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EasyPermissionManagement.Web", "sample\EasyPermissionManagement.Web\EasyPermissionManagement.Web.csproj", "{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EasyPermissionManagement.EntityFrameworkCore", "src\EasyPermissionManagement.EntityFrameworkCore\EasyPermissionManagement.EntityFrameworkCore.csproj", "{45587D32-10C0-408A-A68F-854AC2362BE8}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EasyPermissionManagement.PostgreSql", "src\EasyPermissionManagement.PostgreSql\EasyPermissionManagement.PostgreSql.csproj", "{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "EasyPermissionManagement.AspNetCore", "src\EasyPermissionManagement.AspNetCore\EasyPermissionManagement.AspNetCore.csproj", "{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{CBB2864A-7715-4443-9F83-B21F8F21EEA5}"
ProjectSection(SolutionItems) = preProject
.editorconfig = .editorconfig
.gitignore = .gitignore
CHANGELOG.md = CHANGELOG.md
common.props = common.props
README.md = README.md
EndProjectSection
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Expand All @@ -31,12 +48,64 @@ Global
{FFFE218C-C1FB-48AF-A94D-599853495DCD}.Release|x64.Build.0 = Release|Any CPU
{FFFE218C-C1FB-48AF-A94D-599853495DCD}.Release|x86.ActiveCfg = Release|Any CPU
{FFFE218C-C1FB-48AF-A94D-599853495DCD}.Release|x86.Build.0 = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|Any CPU.Build.0 = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|x64.ActiveCfg = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|x64.Build.0 = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|x86.ActiveCfg = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Debug|x86.Build.0 = Debug|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|Any CPU.ActiveCfg = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|Any CPU.Build.0 = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|x64.ActiveCfg = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|x64.Build.0 = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|x86.ActiveCfg = Release|Any CPU
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9}.Release|x86.Build.0 = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|Any CPU.Build.0 = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|x64.ActiveCfg = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|x64.Build.0 = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|x86.ActiveCfg = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Debug|x86.Build.0 = Debug|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|Any CPU.ActiveCfg = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|Any CPU.Build.0 = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|x64.ActiveCfg = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|x64.Build.0 = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|x86.ActiveCfg = Release|Any CPU
{45587D32-10C0-408A-A68F-854AC2362BE8}.Release|x86.Build.0 = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|Any CPU.Build.0 = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|x64.ActiveCfg = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|x64.Build.0 = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|x86.ActiveCfg = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Debug|x86.Build.0 = Debug|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|Any CPU.ActiveCfg = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|Any CPU.Build.0 = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|x64.ActiveCfg = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|x64.Build.0 = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|x86.ActiveCfg = Release|Any CPU
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395}.Release|x86.Build.0 = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|Any CPU.Build.0 = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|x64.ActiveCfg = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|x64.Build.0 = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|x86.ActiveCfg = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Debug|x86.Build.0 = Debug|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|Any CPU.ActiveCfg = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|Any CPU.Build.0 = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|x64.ActiveCfg = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|x64.Build.0 = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|x86.ActiveCfg = Release|Any CPU
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(NestedProjects) = preSolution
{FFFE218C-C1FB-48AF-A94D-599853495DCD} = {62CB44B7-4F0A-4B35-A407-C80A580698FE}
{6EAE7DBF-DAEB-41BE-9C17-50AACD056EA9} = {F8D0F299-BAF9-4C19-B3BA-BBFA582EF663}
{45587D32-10C0-408A-A68F-854AC2362BE8} = {62CB44B7-4F0A-4B35-A407-C80A580698FE}
{4DF4757E-F6E8-4DBE-853B-2DAD3CA96395} = {62CB44B7-4F0A-4B35-A407-C80A580698FE}
{4BE3AE6B-8935-41CB-B18E-3E598A5353EE} = {62CB44B7-4F0A-4B35-A407-C80A580698FE}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {84FFA3BA-F139-429A-9FED-C84A21FE0E2A}
Expand Down
52 changes: 52 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
<p align="center">
<img src="https://user-images.githubusercontent.com/47147484/136712257-bf88799b-f3e8-4102-bf77-91bdf6a9f5b6.png" style="max-width:100%;" height="140" />
</p>

<p align="center">
<a href="https://gitmoji.carloscuesta.me">
<img src="https://img.shields.io/badge/gitmoji-%20😜%20😍-FFDD67.svg?style=flat-square" alt="Gitmoji">
</a>
</p>

***

## Give a Star 🌟
If you liked the project or if **EasyPermissionManagement** helped you, please give a star.

***

### Purpose
**Easy Permission Management** provides easily permission management on your aspnetcore project.

***

### Supported Databases
- PostgreSQL


### Planned Databases
- [ ] Sql Server
- [ ] MariaDb
- [ ] MySql
- [ ] Mongo
- [ ] SqLite
- [ ] Firebird
- [ ] Oracle

***


## Permission-based Authorization

Typically, applications require more than just authenticated users. We would like to have users with different sets of permissions. The easiest way to achieve this is with the role-based authorization where we allow users to perform certain actions depending on their membership in a role.

For small applications, it might be perfectly fine to use role-based authorization, but this has some drawbacks. For instance, it would be difficult to add or remove roles, because we would have to check every `AuthorizeAttribute` with role specified in our code whenever we changed roles.

More flexible authorization could be implemented using claims. Instead of checking role membership, we check if a user has a permission to perform a certain action. Permission in this case is represented as a claim.

***

### Documentation
Visit [Wiki](https://github.com/furkandeveloper/EasyPermissionManagement/wiki) page for documentation. Lets learn. 👨‍🎓🧐


21 changes: 21 additions & 0 deletions common.props
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
<Project>
<PropertyGroup>
<TargetFrameworks>net5.0</TargetFrameworks>
<Version>1.0.1</Version>
<GenerateDocumentationFile>true</GenerateDocumentationFile>
<LangVersion>latest</LangVersion>
<PackageRequireLicenseAcceptance>false</PackageRequireLicenseAcceptance>
<RepositoryUrl>https://github.com/furkandeveloper/EasyPermissionManagement</RepositoryUrl>
<Authors>furkandeveloper</Authors>
<Description>This repo provides easily permission management on your aspnetcore project</Description>
<PackageTags>permissions, permission-manager, permission, permissionmanagement</PackageTags>
<PackageReleaseNotes>
⛏ Implement infrastructure layer
⛏ Implement AspNetCore module
⛏ Implement EF Core module
⛏ Implement PostgreSql module
⛏ Implement Core module
</PackageReleaseNotes>
<PackageLicenseExpression>MIT</PackageLicenseExpression>
</PropertyGroup>
</Project>

0 comments on commit 4d705c7

Please sign in to comment.