Test_Store.Common => Pagination.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Common
این خط، نامفضا (namespace) Test_Store.Common را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس Pagination
csharp
public static class Pagination
{
public static IEnumerable<TSource> ToPaged<TSource>(this IEnumerable<TSource> source , int page , int pagSize ,out int rowsCont)
{
rowsCont = source.Count();
return source.Skip((page -1) * pagSize).Take(rowsCont);
}
}
public static class Pagination:
این خط یک کلاس استاتیک به نام Pagination تعریف میکند. کلاسهای استاتیک نمیتوانند نمونهسازی شوند و تمام اعضای آنها نیز باید استاتیک باشند.
متد ToPaged<TSource>
این متد برای صفحهبندی لیستی از آیتمها استفاده میشود. صفحهبندی به معنای تقسیم لیست بلند از آیتمها به صفحات کوچکتر است که به کاربران نمایش داده میشود.
تعریف متد
csharp
public static IEnumerable<TSource> ToPaged<TSource>(this IEnumerable<TSource> source, int page, int pagSize, out int rowsCont)
public static IEnumerable<TSource> ToPaged<TSource>(this IEnumerable<TSource> source, int page, int pagSize, out int rowsCont):
این متد استاتیک و جنریک است و یک IEnumerable<TSource> را برمیگرداند. این متد از یک IEnumerable<TSource> ورودی (source) برای صفحهبندی استفاده میکند.
this IEnumerable<TSource> source:
این قسمت به متد اجازه میدهد که به عنوان یک متد افزونه (extension method) برای انواع IEnumerable<TSource> استفاده شود.
int page:
شماره صفحهای که قرار است بازیابی شود.
int pagSize:
تعداد آیتمهایی که قرار است در هر صفحه نمایش داده شود.
out int rowsCont:
تعداد کل آیتمها در لیست اصلی را برمیگرداند. از out برای برگرداندن این مقدار استفاده میشود.
محتوای متد
csharp
rowsCont = source.Count();
return source.Skip((page - 1) * pagSize).Take(pagSize);
rowsCont = source.Count();:
این خط تعداد کل آیتمهای موجود در لیست اصلی را محاسبه کرده و در متغیر rowsCont ذخیره میکند.
return source.Skip((page - 1) * pagSize).Take(pagSize);:
این خط آیتمهای مورد نظر برای صفحهبندی را انتخاب میکند. ابتدا تعداد آیتمهای صفحههای قبلی را رد میکند (Skip) و سپس تعداد آیتمهای مورد نیاز برای صفحه جاری را برمیدارد (Take).
نتیجهگیری
این کد یک متد افزونه (extension method) به نام ToPaged را تعریف میکند که به هر IEnumerable<TSource> اجازه میدهد تا بهطور کارآمد به صفحات کوچکتر تقسیم شود. این متد صفحهای از آیتمها را بر اساس شماره صفحه و اندازه صفحه بازمیگرداند و تعداد کل آیتمها را نیز برمیگرداند.
Test_Store.Application => Services => Users => Commands => RegisterUser => IRegisterUserService.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Commands.RegisterUser
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Commands.RegisterUser را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
تعریف اینترفیس IRegisterUserService
csharp
public interface IRegisterUserService
{
ResultDto<ResultRegisterUser> Execute(RequestRegisterUserDto request);
}
public interface IRegisterUserService:
این خط یک اینترفیس به نام IRegisterUserService تعریف میکند. این اینترفیس شامل متدی به نام Execute است که ورودی آن یک RequestRegisterUserDto و خروجی آن یک ResultDto<ResultRegisterUser> است. این متد برای ثبتنام کاربر استفاده میشود.
کلاس RegisterUserService
این کلاس پیادهسازی اینترفیس IRegisterUserService است و شامل منطق اصلی ثبتنام کاربر است.
تعریف کلاس و سازنده
csharp
public class RegisterUserService : IRegisterUserService
{
private readonly IDataBaseContext _context;
public RegisterUserService(IDataBaseContext context)
{
_context = context;
}
private readonly IDataBaseContext _context;:
این خط یک متغیر خصوصی و فقط خواندنی به نام _context از نوع IDataBaseContext تعریف میکند که برای دسترسی به پایگاه داده استفاده میشود.
public RegisterUserService(IDataBaseContext context):
این سازنده کلاس است که یک نمونه از IDataBaseContext را به عنوان ورودی میپذیرد و آن را به متغیر _context اختصاص میدهد.
متد Execute
csharp
public ResultDto<ResultRegisterUser> Execute(RequestRegisterUserDto request)
{
User user = new User()
{
Email = request.Email,
FullName = request.FullName,
};
List<UserInRole> userInRoles = new List<UserInRole>();
foreach (var item in request.roles)
{
var roles = _context.Roles.Find(item.Id);
userInRoles.Add(new UserInRole
{
Role=roles,
RoleId=roles.Id,
User=user,
UserId=user.Id,
});
}
user.UserInRoles = userInRoles;
_context.Users.Add(user);
_context.SaveChanges();
return new ResultDto<ResultRegisterUser>()
{
Data = new ResultRegisterUser()
{
UserId = user.Id,
},
IsSuccess = true,
Massage = "ثبت نام کاربر انجام شد",
};
}
User user = new User():
این خط یک نمونه جدید از کلاس User ایجاد میکند و ویژگیهای آن را از RequestRegisterUserDto تنظیم میکند.
List<UserInRole> userInRoles = new List<UserInRole>();:
این خط یک لیست جدید از UserInRole ایجاد میکند تا نقشهای کاربر را نگهداری کند.
حلقه foreach: این حلقه برای هر نقش در درخواست کاربر، نقش مربوطه را از پایگاه داده پیدا میکند و آن را به لیست userInRoles اضافه میکند.
user.UserInRoles = userInRoles;:
این خط نقشهای کاربر را به ویژگی UserInRoles اختصاص میدهد.
_context.Users.Add(user);:
این خط کاربر جدید را به دیتابیس اضافه میکند.
_context.SaveChanges();:
این خط تغییرات را در پایگاه داده ذخیره میکند.
بازگشت ResultDto<ResultRegisterUser>: این بخش یک نمونه جدید از ResultDto<ResultRegisterUser> را بازمیگرداند که شامل شناسه کاربر، وضعیت موفقیت و پیام موفقیت است.
کلاسهای DTO
RequestRegisterUserDto
csharp
public class RequestRegisterUserDto
{
public string FullName { get; set; }
public string Email { get; set; }
public List<RolesInRegisterUserDto> roles { get; set; }
}
public string FullName { get; set; }:
نام کامل کاربر.
public string Email { get; set; }: ایمیل کاربر.
public List<RolesInRegisterUserDto> roles { get; set; }:
لیستی از نقشهای کاربر.
RolesInRegisterUserDto
csharp
public class RolesInRegisterUserDto
{
public long Id { get; set; }
}
public long Id { get; set; }:
شناسه نقش.
ResultRegisterUser
csharp
public class ResultRegisterUser
{
public long UserId { get; set; }
}
public long UserId { get; set; }:
شناسه کاربر که بهتازگی ثبتنام شده است.
نتیجهگیری
این کد یک سرویس ثبتنام کاربر را پیادهسازی میکند که شامل کلاسهای DTO برای درخواست و پاسخ و همچنین منطق اصلی ثبتنام کاربر است. این سرویس کاربر جدید را ایجاد کرده و نقشهای او را به پایگاه داده اضافه میکند.
Test_Store.Application => Services => Users => Queries => GetRoles => GetRolesService.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetRoles
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetRoles را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس GetRolesService
این کلاس پیادهسازی اینترفیس IGetRolesService است و شامل منطق اصلی برای دریافت نقشها از پایگاه داده است.
تعریف کلاس و سازنده
csharp
public class GetRolesService : IGetRolesService
{
private readonly IDataBaseContext _context;
public GetRolesService(IDataBaseContext context)
{
_context = context;
}
private readonly IDataBaseContext _context;:
این خط یک متغیر خصوصی و فقط خواندنی به نام _context از نوع IDataBaseContext تعریف میکند که برای دسترسی به پایگاه داده استفاده میشود.
public GetRolesService(IDataBaseContext context):
این سازنده کلاس است که یک نمونه از IDataBaseContext را به عنوان ورودی میپذیرد و آن را به متغیر _context اختصاص میدهد.
متد Execute
csharp
public ResultDto<List<RolesDto>> Execute()
{
var roles = _context.Roles.ToList().Select(p => new RolesDto
{
Id = p.Id,
Name = p.Name
}).ToList();
return new ResultDto<List<RolesDto>>()
{
Data = roles,
IsSuccess = true,
Massage = "",
};
}
var roles = _context.Roles.ToList().Select(p => new RolesDto { Id = p.Id, Name = p.Name }).ToList();:
این خط، تمام نقشها را از پایگاه داده دریافت کرده و هر نقش را به یک شیء RolesDto تبدیل میکند. در نهایت، این لیست از نقشها را در متغیر roles ذخیره میکند.
_context.Roles.ToList():
تمام نقشها را به صورت لیستی از پایگاه داده دریافت میکند.
.Select(p => new RolesDto { Id = p.Id, Name = p.Name }):
هر عنصر لیست را به یک شیء RolesDto تبدیل میکند.
.ToList():
نتیجه نهایی را به یک لیست تبدیل میکند.
return new ResultDto<List<RolesDto>>() { Data = roles, IsSuccess = true, Massage = "" };:
این خط یک شیء ResultDto<List<RolesDto>> جدید ایجاد کرده و آن را بازمیگرداند. این شیء شامل دادههای نقشها (roles)، وضعیت موفقیت (IsSuccess = true) و پیام (Massage = "") است.
نتیجهگیری
این کد یک سرویس برای دریافت نقشها از پایگاه داده پیادهسازی میکند. این سرویس نقشها را دریافت کرده و به فرمتی که میتواند به کلاینت یا لایههای دیگر ارسال شود، برمیگرداند. این کلاس از اینترفیس IGetRolesService استفاده میکند و نتیجه را به صورت یک شیء ResultDto<List<RolesDto>> بازمیگرداند که شامل دادهها، وضعیت موفقیت و پیام است.
Test_Store.Application => Services => Users => Queries => GetRoles => IGetRolesService.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetRoles
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetRoles را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس GetRolesService
این کلاس پیادهسازی اینترفیس IGetRolesService است و شامل منطق اصلی برای دریافت نقشها از پایگاه داده است.
تعریف کلاس و سازنده
csharp
public class GetRolesService : IGetRolesService
{
private readonly IDataBaseContext _context;
public GetRolesService(IDataBaseContext context)
{
_context = context;
}
private readonly IDataBaseContext _context;:
این خط یک متغیر خصوصی و فقط خواندنی به نام _context از نوع IDataBaseContext تعریف میکند که برای دسترسی به پایگاه داده استفاده میشود.
public GetRolesService(IDataBaseContext context):
این سازنده کلاس است که یک نمونه از IDataBaseContext را به عنوان ورودی میپذیرد و آن را به متغیر _context اختصاص میدهد.
متد Execute
csharp
public ResultDto<List<RolesDto>> Execute()
{
var roles = _context.Roles.ToList().Select(p => new RolesDto
{
Id = p.Id,
Name = p.Name
}).ToList();
return new ResultDto<List<RolesDto>>()
{
Data = roles,
IsSuccess = true,
Massage = "",
};
}
var roles = _context.Roles.ToList().Select(p => new RolesDto { Id = p.Id, Name = p.Name }).ToList();:
این خط، تمام نقشها را از پایگاه داده دریافت کرده و هر نقش را به یک شیء RolesDto تبدیل میکند. در نهایت، این لیست از نقشها را در متغیر roles ذخیره میکند.
_context.Roles.ToList():
تمام نقشها را به صورت لیستی از پایگاه داده دریافت میکند.
.Select(p => new RolesDto { Id = p.Id, Name = p.Name }):
هر عنصر لیست را به یک شیء RolesDto تبدیل میکند.
.ToList(): نتیجه نهایی را به یک لیست تبدیل میکند.
return new ResultDto<List<RolesDto>>() { Data = roles, IsSuccess = true, Massage = "" };:
این خط یک شیء ResultDto<List<RolesDto>> جدید ایجاد کرده و آن را بازمیگرداند. این شیء شامل دادههای نقشها (roles)، وضعیت موفقیت (IsSuccess = true) و پیام (Massage = "") است.
نتیجهگیری
این کد یک سرویس برای دریافت نقشها از پایگاه داده پیادهسازی میکند. این سرویس نقشها را دریافت کرده و به فرمتی که میتواند به کلاینت یا لایههای دیگر ارسال شود، برمیگرداند. این کلاس از اینترفیس IGetRolesService استفاده میکند و نتیجه را به صورت یک شیء ResultDto<List<RolesDto>> بازمیگرداند که شامل دادهها، وضعیت موفقیت و پیام است.
Test_Store.Application => Services => Users => Queries => GetRoles => RolesDto.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetRoles
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetRoles را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس RolesDto
csharp
public class RolesDto
{
public long Id { get; set; }
public string Name { get; set; }
}
public class RolesDto:
این خط کلاس RolesDto را تعریف میکند. Dto مخفف "Data Transfer Object" است که برای انتقال دادهها بین لایههای مختلف یک برنامه استفاده میشود.
public long Id { get; set; }:
این پراپرتی شناسهی منحصربهفرد (ID) برای نقش را نشان میدهد. این شناسه از نوع long است.
public string Name { get; set; }:
این پراپرتی نام نقش را ذخیره میکند. این نام از نوع string است.
نتیجهگیری
کلاس RolesDto یک Data Transfer Object (DTO) ساده است که برای انتقال اطلاعات مربوط به نقشها بین لایههای مختلف برنامه استفاده میشود. این کلاس شامل دو پراپرتی Id و Name است که به ترتیب شناسه و نام نقش را نگهداری میکنند.
Test_Store.Application => Services => Users => Queries => GetUsers => ReslutGetUserDto.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetUsers
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetUsers را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس ResultGetUserDto
csharp
public class ResultGetUserDto
{
public List<GetUsersDto> Users { get; set; }
public int Rows { get; set; }
}
public class ResultGetUserDto:
این خط یک کلاس به نام ResultGetUserDto تعریف میکند.
public List<GetUsersDto> Users { get; set; }:
این پراپرتی یک لیست از نوع GetUsersDto را ذخیره میکند. این لیست شامل کاربران دریافت شده است.
public int Rows { get; set; }:
این پراپرتی تعداد کل ردیفها (کاربران) را ذخیره میکند.
نتیجهگیری
کلاس ResultGetUserDto یک Data Transfer Object (DTO) است که برای انتقال دادههای مربوط به کاربران بین لایههای مختلف برنامه استفاده میشود. این کلاس شامل دو پراپرتی Users (لیست کاربران) و Rows (تعداد کل کاربران) است.
Test_Store.Application => Services => Users => Queries => GetUsers => IGetUsersService.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetUsers
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetUsers را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
اینترفیس IGetUsersService
csharp
public interface IGetUsersService
{
ResultGetUserDto Execute(RequestGetUserDto request);
}
public interface IGetUsersService:
این خط یک اینترفیس به نام IGetUsersService تعریف میکند.
ResultGetUserDto Execute(RequestGetUserDto request);:
این متد در اینترفیس تعریف شده است که یک RequestGetUserDto را به عنوان ورودی میپذیرد و یک ResultGetUserDto را به عنوان خروجی برمیگرداند. این متد برای دریافت کاربران بر اساس درخواست استفاده میشود.
نتیجهگیری
این اینترفیس IGetUsersService برای تعریف یک سرویس است که کاربران را بر اساس یک درخواست دریافت میکند. متد Execute شامل ورودی RequestGetUserDto و خروجی ResultGetUserDto است که به شما امکان میدهد درخواستهای کاربر را پردازش کرده و نتایج مربوطه را بازگردانید.
Test_Store.Application => Services => Users => Queries => GetUsers => GetUsersService.cs
استفاده از نامفضاها (Namespaces)
csharp
using Test_Store.Application.Interfaces.Contexs;
using Test_Store.Common;
using Test_Store.Application.Interfaces.Contexs;:
این دستور به شما امکان میدهد تا از اینترفیسها و کلاسهای موجود در این نامفضا استفاده کنید.
using Test_Store.Common;:
این دستور به شما امکان میدهد تا از کلاسها و امکانات موجود در نامفضای Test_Store.Common استفاده کنید.
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetUsers
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetUsers را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس GetUsersService
این کلاس پیادهسازی اینترفیس IGetUsersService است و شامل منطق اصلی برای دریافت کاربران از پایگاه داده است.
تعریف کلاس و سازنده
csharp
public class GetUsersService : IGetUsersService
{
private readonly IDataBaseContext _context;
public GetUsersService(IDataBaseContext context)
{
_context = context;
}
private readonly IDataBaseContext _context;:
این خط یک متغیر خصوصی و فقط خواندنی به نام _context از نوع IDataBaseContext تعریف میکند که برای دسترسی به پایگاه داده استفاده میشود.
public GetUsersService(IDataBaseContext context):
این سازنده کلاس است که یک نمونه از IDataBaseContext را به عنوان ورودی میپذیرد و آن را به متغیر _context اختصاص میدهد.
متد Execute
csharp
public ResultGetUserDto Execute(RequestGetUserDto request)
{
var users = _context.Users.AsQueryable();
if (!string.IsNullOrWhiteSpace(request.SearchKey))
{
users = users.Where(p => p.FullName.Contains(request.SearchKey) && p.Email.Contains(request.SearchKey));
}
int rowsCount = 0;
var userList = users.ToPaged(request.Page, 20, out rowsCount).Select(p => new GetUsersDto
{
Email = p.Email,
FullName = p.FullName,
Id = p.Id,
}).ToList();
return new ResultGetUserDto
{
Rows = rowsCount,
Users = userList,
};
}
var users = _context.Users.AsQueryable();:
این خط تمام کاربران را به صورت یک کوئری قابل پرسش (IQueryable) از پایگاه داده دریافت میکند.
if (!string.IsNullOrWhiteSpace(request.SearchKey)):
این شرط بررسی میکند که آیا کلید جستجو (SearchKey) خالی یا فضای خالی نیست.
users = users.Where(p => p.FullName.Contains(request.SearchKey) && p.Email.Contains(request.SearchKey));:
این خط کاربران را فیلتر میکند تا فقط کاربرانی را که کلید جستجو را در نام کامل و ایمیل خود دارند، نمایش دهد.
int rowsCount = 0;:
این خط یک متغیر برای نگهداری تعداد کل کاربران تنظیم میکند.
var userList = users.ToPaged(request.Page, 20, out rowsCount).Select(p => new GetUsersDto { Email = p.Email, FullName = p.FullName, Id = p.Id }).ToList();:
این خط کاربران را به صفحات کوچکتر تقسیم میکند و هر کاربر را به یک شیء GetUsersDto تبدیل میکند.
users.ToPaged(request.Page, 20, out rowsCount):
کاربران را به صفحات تقسیم میکند. request.Page شماره صفحه و 20 تعداد آیتمها در هر صفحه است. rowsCount تعداد کل کاربران را ذخیره میکند.
.Select(p => new GetUsersDto { Email = p.Email, FullName = p.FullName, Id = p.Id }):
هر کاربر را به یک شیء GetUsersDto تبدیل میکند.
.ToList():
نتیجه نهایی را به یک لیست تبدیل میکند.
return new ResultGetUserDto { Rows = rowsCount, Users = userList };:
این خط یک شیء ResultGetUserDto جدید ایجاد کرده و آن را بازمیگرداند. این شیء شامل تعداد کل کاربران (rowsCount) و لیست کاربران (userList) است.
نتیجهگیری
این کد یک سرویس برای دریافت کاربران از پایگاه داده پیادهسازی میکند. این سرویس کاربران را بر اساس کلید جستجو فیلتر کرده، آنها را به صفحات تقسیم کرده و به فرمتی که میتواند به کلاینت یا لایههای دیگر ارسال شود، برمیگرداند. این کلاس از اینترفیس IGetUsersService استفاده میکند و نتیجه را به صورت یک شیء ResultGetUserDto بازمیگرداند که شامل دادهها، تعداد کل کاربران و لیست کاربران است.
Test_Store.Application => Services => Users => Queries => GetUsers => GetUsersDto.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetUsers
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetUsers را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس GetUsersDto
csharp
public class GetUsersDto
{
public long Id { get; set; }
public string FullName { get; set; }
public string Email { get; set; }
}
public class GetUsersDto:
این خط کلاس GetUsersDto را تعریف میکند. Dto مخفف "Data Transfer Object" است که برای انتقال دادهها بین لایههای مختلف یک برنامه استفاده میشود.
public long Id { get; set; }:
این پراپرتی شناسهی منحصربهفرد (ID) برای کاربر را نشان میدهد. این شناسه از نوع long است.
public string FullName { get; set; }:
این پراپرتی نام کامل کاربر را ذخیره میکند. این نام از نوع string است.
public string Email { get; set; }:
این پراپرتی ایمیل کاربر را ذخیره میکند. این ایمیل از نوع string است.
نتیجهگیری
کلاس GetUsersDto یک Data Transfer Object (DTO) ساده است که برای انتقال اطلاعات مربوط به کاربران بین لایههای مختلف برنامه استفاده میشود. این کلاس شامل سه پراپرتی Id، FullName و Email است که به ترتیب شناسه، نام کامل و ایمیل کاربر را نگهداری میکنند.
Test_Store.Application => Services => Users => Queries => GetUsers => RequestGetUserDto.cs
نامفضا (Namespace)
csharp
namespace Test_Store.Application.Services.Users.Queries.GetUsers
این خط، نامفضا (namespace) Test_Store.Application.Services.Users.Queries.GetUsers را تعریف میکند. نامفضاها برای سازماندهی و دستهبندی کدها استفاده میشوند.
کلاس RequestGetUserDto
csharp
public class RequestGetUserDto
{
public string SearchKey { get; set; }
public int Page { get; set; }
}
public class RequestGetUserDto:
این خط یک کلاس به نام RequestGetUserDto تعریف میکند.
public string SearchKey { get; set; }:
این پراپرتی یک کلید جستجو (SearchKey) از نوع string را ذخیره میکند. این کلید جستجو برای فیلتر کردن کاربران بر اساس نام یا ایمیل استفاده میشود.
public int Page { get; set; }:
این پراپرتی شماره صفحهای (Page) را ذخیره میکند که کاربران باید در آن نمایش داده شوند. این ویژگی برای صفحهبندی کاربران استفاده میشود.
نتیجهگیری
کلاس RequestGetUserDto یک Data Transfer Object (DTO) است که برای انتقال دادههای مربوط به درخواست دریافت کاربران بین لایههای مختلف برنامه استفاده میشود. این کلاس شامل دو پراپرتی SearchKey (کلید جستجو) و Page (شماره صفحه) است که به ترتیب برای فیلتر کردن و صفحهبندی کاربران استفاده میشوند.
اضافه کردن ایترفیس و کلاس ارث بری در program
افزودن سرویسها به کانتینر DI (Dependency Injection)
csharp
builder.Services.AddScoped<IDataBaseContext, DataBaseContext>();
builder.Services.AddScoped<IGetUsersService, GetUsersService>();
builder.Services.AddScoped<IGetRolesService, GetRolesService>();
AddScoped<IDataBaseContext, DataBaseContext>();
تعریف: این خط به DI Container میگوید که هر بار که نیاز به IDataBaseContext وجود دارد، یک نمونه از DataBaseContext ایجاد کند.
و Scope: Scoped به این معنی است که یک نمونه جدید برای هر درخواست HTTP ساخته میشود و تا پایان آن درخواست استفاده میشود.
AddScoped<IGetUsersService, GetUsersService>();
تعریف: این خط به DI Container میگوید که هر بار که نیاز به IGetUsersService وجود دارد، یک نمونه از GetUsersService ایجاد کند.
و Scope: همانند IDataBaseContext، Scoped به این معنی است که یک نمونه جدید برای هر درخواست HTTP ساخته میشود.
AddScoped<IGetRolesService, GetRolesService>();
تعریف: این خط به DI Container میگوید که هر بار که نیاز به IGetRolesService وجود دارد، یک نمونه از GetRolesService ایجاد کند.
و Scope: باز هم، Scoped به این معنی است که یک نمونه جدید برای هر درخواست HTTP ساخته میشود.
نتیجهگیری
این خطوط کد سه سرویس مختلف را به DI Container اضافه میکنند و به برنامه شما اجازه میدهند تا وابستگیها را به طور خودکار تزریق کند. هر سرویس با استفاده از الگوی Scoped ایجاد میشود، به این معنی که یک نمونه جدید برای هر درخواست HTTP ایجاد میشود.