Структура единиц работы и репозитория | Официальная команда URF, отслеживаемых объектов и команды Design Factory
URF.Core является полнофункциональным и теперь имеет полную идентичность с URF.NET (устаревшая версия .NET). URF.Core был полностью переписан с акцентом на архитектуру, проектирование и реализацию, а также на реализацию основного запроса для vNext, вы можете взглянуть на наш URF.Core.Sample с веб-API ASP.NET Core, OData, с полными образцами CRUD с пользовательским интерфейсом Angular и Kendo.
Начиная с версии 3.1.1 добавлена поддержка баз данных документов NoSQL с реализацией MongoDb.
Были предоставлены образцы для EF Core 3.x и MongoDb.
Оставаясь верным (наследию) URF.NET, имея небольшой размер. URF.Core URF.Core ( всего 7 классов ) и URF.NET ( всего 12 классов ).
Мы сделали каждую реализацию виртуальной, поэтому ее можно переопределить для любых команд/проектов/разработчиков, а также для крайних случаев.
Как всегда, это религиозные дебаты между командами и сообществом. Как и в случае с (устаревшим) URF.NET, мы предоставили командам возможность выбрать IQueryable или IEnumerable, или даже оба, в зависимости от архитектуры, дизайна, реализации и стиля вашей команды. В качестве URF.NET и для команд, которые считают шаблоны репозитория, которые представляют IQueryable
как дырявую абстракцию, просто используйте URF IQuery
API, который предоставит вам все функции Fluent IQueryable, однако вернет чистый Entity или IEnumerable вместо использования IQueryable, опять же URF. .Core и URF.NET поддерживаются, поэтому команды имеют полную свободу выбора, какой из трех путей/вариантов наиболее целесообразен для их команды/проекта.
public class ProductsController : ODataController
{
private readonly IProductService _productService ;
private readonly IUnitOfWork _unitOfWork ;
public ProductsController (
IProductService productService ,
IUnitOfWork unitOfWork )
{
_productService = productService ;
_unitOfWork = unitOfWork ;
}
// e.g. GET odata/Products?$skip=2&$top=10
[ EnableQuery ]
public IQueryable < Products > Get ( ) => _productService . Queryable ( ) ;
// e.g. GET odata/Products(37)
public async Task < IActionResult > Get ( [ FromODataUri ] int key )
{
if ( ! ModelState . IsValid )
return BadRequest ( ModelState ) ;
var product = await _productService . FindAsync ( key ) ;
if ( product == null )
return NotFound ( ) ;
return Ok ( product ) ;
}
// e.g. PUT odata/Products(37)
public async Task < IActionResult > Put ( [ FromODataUri ] int key , [ FromBody ] Products products )
{
if ( ! ModelState . IsValid )
return BadRequest ( ModelState ) ;
if ( key != products . ProductId )
return BadRequest ( ) ;
_productService . Update ( products ) ;
try
{
await _unitOfWork . SaveChangesAsync ( ) ;
}
catch ( DbUpdateConcurrencyException )
{
if ( ! await _productService . ExistsAsync ( key ) )
return NotFound ( ) ;
throw ;
}
return NoContent ( ) ;
}
// e.g. PUT odata/Products
public async Task < IActionResult > Post ( [ FromBody ] Products products )
{
if ( ! ModelState . IsValid )
return BadRequest ( ModelState ) ;
_productService . Insert ( products ) ;
await _unitOfWork . SaveChangesAsync ( ) ;
return Created ( products ) ;
}
// e.g. PATCH, MERGE odata/Products(37)
[ AcceptVerbs ( " PATCH " , " MERGE " ) ]
public async Task < IActionResult > Patch ( [ FromODataUri ] int key , [ FromBody ] Delta < Products > product )
{
if ( ! ModelState . IsValid )
return BadRequest ( ModelState ) ;
var entity = await _productService . FindAsync ( key ) ;
if ( entity == null )
return NotFound ( ) ;
product . Patch ( entity ) ;
_productService . Update ( entity ) ;
try
{
await _unitOfWork . SaveChangesAsync ( ) ;
}
catch ( DbUpdateConcurrencyException )
{
if ( ! await _productService . ExistsAsync ( key ) )
return NotFound ( ) ;
throw ;
}
return Updated ( entity ) ;
}
// e.g. DELETE odata/Products(37)
public async Task < IActionResult > Delete ( [ FromODataUri ] int key )
{
if ( ! ModelState . IsValid )
return BadRequest ( ModelState ) ;
var result = await _productService . DeleteAsync ( key ) ;
if ( ! result )
return NotFound ( ) ;
await _unitOfWork . SaveChangesAsync ( ) ;
return StatusCode ( ( int ) HttpStatusCode . NoContent ) ;
}
}
URF.Core был полностью переписан, и теперь все полностью task
, async
, await
прямо из коробки. Таким образом, команды автоматически получат лучшее управление потоками за счет улучшения асинхронной производительности.
© 2017 URF.NET. Все права защищены.