Home PostSharp Nedir? Nasıl Kullanılır?
Post
Cancel

PostSharp Nedir? Nasıl Kullanılır?

Merhabalar, sizlere bu makalede benimde projelerimde kullandığım PostSharp Framework içerisindeki Aspect yapısını örneklerle anlatmaya çalışacağım. Bu yapı sayesinde bir metot yada sınıfa attribute ekleyerek işlem aşamalarında yada alınabilecek hata durumlarında farklı aksiyonlar alabiliriz. Ben kendi projemde Logging ve Authorization yapıları için kullanıyorum.

PostSharp Kurulumu

Nuget üzerinden aşağıdaki kod bloğu ile kurulumu yapıyorum.

1
Install-Package PostSharp -Version 6.7.10

Paket kurulumundan sonra Visual Studio eklentisini kurmalıyız. Buradaki adresten eklentiyi indirip kurulumunu yaptığımızda lisans bilgilerini girmem gerekiyor. PostSharp ücretli bir kütüphanedir. Ancak 1000 satırlık kod limiti ile yada öğrenci, öğretmen, freelancer, MVP gibi ayrıcalıklı olarak ücretsiz kullanabilirsiniz.

OnMethodBoundaryAspect

Attribute olarak tanımladığımız bir metodun işlem adımlarını takip edebileceğimiz sınıftır. Aşağıda görüldüğü gibi OnEntry, OnSuccess, OnExit, OnException override metodları ile istediğimiz metodun özelliklerine erişebilmekteyiz.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
[PSerializable]
public class LoggingAspect : OnMethodBoundaryAspect
{
    public override void OnEntry(MethodExecutionArgs args)
    {
        Console.WriteLine("{0} : OnEntry", args.Method.Name);
    }

    public override void OnSuccess(MethodExecutionArgs args)
    {
        Console.WriteLine("{0} OnSuccess", args.Method.Name);
    }

    public override void OnExit(MethodExecutionArgs args)
    {
        Console.WriteLine("{0} OnExit", args.Method.Name);
    }

    public override void OnException(MethodExecutionArgs args)
    {
        Console.WriteLine("{0} OnException", args.Method.Name);
    }

    public override void OnResume(MethodExecutionArgs args)
    {
        Console.WriteLine("{0} OnResume", args.Method.Name);
    }
}

class Program
{
    [LoggingAspect]
    static void Main(string[] args)
    {
        Console.WriteLine("Hello World!");
    }
}

Yukarıdaki OnMethodBoundaryAspect sınıfına ilişkin kendi projelerimde kullanmış olduğum SecuredOperation örneğini inceleyelim. Not: Kullanmış olduğum versiyon : v4.2.17.0

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[Serializable]
public class SecuredOperation : OnMethodBoundaryAspect
{
    public string Roles { get; set; }

    public override void OnEntry(MethodExecutionArgs args)
    {
        string[] roles = Roles.Split(',');
        bool isAuthorized = false;
        for (int i = 0; i < roles.Length; i++)
        {
            if (System.Threading.Thread.CurrentPrincipal.IsInRole(roles[i]))
            {
                isAuthorized = true;
            }
        }

        if (!isAuthorized)
        {
            throw new SecurityException("You aren't authorized!");
        }
    }
}

UserManager sınıında aşağıdaki gibi tanımlamış olduğum sınıflardaki metodlara OnEntry ile girip CurrentPrincipal içerisinde belirli rollerin tanımlı olup olmadığını kontrol ediyorum.

1
2
3
4
5
6
7
8
9
10
11
public class UserManager : IUserService
{
    private readonly IUserDal _userDal;

    [SecuredOperation(Roles = "Admin,User")]
    public List<User> GetAll()
    {
        var users = _mapper.Map<List<User>>(_userDal.GetAll());
        return users;
    }
}

Metod bazında yapıldığı gibi ayrıca sınıfın geneli için de tanımlama yapılabilir.

1
2
3
4
5
6
7
8
9
10
11
[SecuredOperation(Roles = "Admin,User")]
public class UserManager : IUserService
{
    private readonly IUserDal _userDal;

    public List<User> GetAll()
    {
        var users = _mapper.Map<List<User>>(_userDal.GetAll());
        return users;
    }
}

Principal tanımlamasını aşağıdaki şekilde yapabiliriz.

1
2
IPrincipal principal = new GenericPrincipal(new GenericIdentity("Admin"), new string[] { "Admin" }); 
Thread.CurrentPrincipal = principal;

Bir sonraki makalede görüşmek üzere.

This post is licensed under CC BY 4.0 by the author.

ASP.NET Core Web API - Basic Authentication Kullanımı

ASP.NET Core Web API - Swagger Kullanımı