OLT.DataAdapters
9.0.0
Prefix Reserved
dotnet add package OLT.DataAdapters --version 9.0.0
NuGet\Install-Package OLT.DataAdapters -Version 9.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="OLT.DataAdapters" Version="9.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="OLT.DataAdapters" Version="9.0.0" />
<PackageReference Include="OLT.DataAdapters" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add OLT.DataAdapters --version 9.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: OLT.DataAdapters, 9.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#addin nuget:?package=OLT.DataAdapters&version=9.0.0
#tool nuget:?package=OLT.DataAdapters&version=9.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
OLT Adapter Resolver and adapters for IQueryable and paged results
// Inject IOltAdapterResolver
// Checks to see if can project IQueryable
adapterResolver.CanProjectTo<PersonEntity, PersonModel>();
//Simple Map
var person = adapterResolver.Map<PersonEntity, PersonModel>(entity, new PersonModel());
var queryable = Context.People.GetAll();
var records = adapterResolver.ProjectTo<PersonEntity, PersonModel>(queryable);
DI Configuration
Using https://www.nuget.org/packages/OLT.Utility.AssemblyScanner
var assemblies = new OltAssemblyScanBuilder()
.IncludeFilter("OLT.", "MyApp.")
.DeepScan()
.ExcludeMicrosoft()
.ExcludeNewtonsoft()
.ExcludeAutomapper()
.Build();
services.AddOltAdapters(opt => opt.AddAdapters(assemblies));
services.AddOltAutoMapper(opt =>
{
opt.AddMaps(assemblies);
});
Simple Adapater
public class PersonEntityToPersonModelAdapter : OltAdapter<PersonEntity, PersonModel>
{
public override void Map(PersonEntity source, PersonModel destination)
{
destination.Name = new PersonName
{
First = source.FirstName,
Last = source.LastName,
};
}
public override void Map(PersonModel source, PersonEntity destination)
{
destination.FirstName = source.Name.First;
destination.LastName = source.Name.Last;
}
}
Projection Adapter using IQueryable
public class PersonEntityToPersonModelQueryableAdapter : OltAdapter<PersonEntity, PersonModel>, IOltAdapterQueryable<PersonEntity, PersonModel>
{
public PersonEntityToPersonModelQueryableAdapter()
{
this.WithOrderBy(p => p.OrderBy(o => o.FirstName).ThenBy(o => o.LastName));
}
public override void Map(PersonEntity source, PersonModel destination)
{
destination.Name = new PersonName
{
First = source.FirstName,
Last = source.LastName,
};
}
public override void Map(PersonModel source, PersonEntity destination)
{
destination.FirstName = source.Name.First;
destination.LastName = source.Name.Last;
}
public IQueryable<PersonModel> Map(IQueryable<PersonEntity> queryable)
{
return queryable.Select(entity => new PersonModel
{
Name = new PersonName
{
First = entity.FirstName,
Last = entity.LastName,
}
});
}
}
Projection Adapter using IQueryable for Paging (requires Default Order By)
public class PersonEntityToPersonModelPagedAdapter : OltAdapterPaged<PersonEntity, PersonModel>
{
public override void Map(PersonEntity source, PersonModel destination)
{
destination.Name = new PersonName
{
First = source.FirstName,
Last = source.LastName,
};
}
public override void Map(PersonModel source, PersonEntity destination)
{
destination.FirstName = source.Name?.First;
destination.LastName = source.Name?.Last;
}
public override IQueryable<PersonModel> Map(IQueryable<PersonEntity> queryable)
{
return queryable.Select(entity => new PersonModel
{
Name = new PersonName
{
First = entity.FirstName,
Last = entity.LastName,
}
});
}
public override IOrderedQueryable<PersonEntity> DefaultOrderBy(IQueryable<PersonEntity> queryable)
{
return queryable.OrderBy(p => p.LastName).ThenBy(p => p.FirstName);
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- OLT.DataAdapters.Abstractions (>= 9.0.0)
- Scrutor (>= 5.0.2)
-
net9.0
- OLT.DataAdapters.Abstractions (>= 9.0.0)
- Scrutor (>= 5.0.2)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on OLT.DataAdapters:
Package | Downloads |
---|---|
OLT.DataAdapters.AutoMapper
DataAdapters AutoMapper Library |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
9.0.0 | 143 | 1/29/2025 |
9.0.0-beta-0015 | 145 | 12/2/2024 |
9.0.0-beta-0010 | 156 | 11/25/2024 |
9.0.0-beta-0005 | 78 | 11/24/2024 |
8.4.0-beta-0010 | 99 | 11/7/2024 |
8.4.0-beta-0005 | 84 | 10/9/2024 |
8.3.1 | 1,121 | 8/26/2024 |
8.3.1-beta-0005 | 130 | 8/21/2024 |
8.3.0 | 158 | 8/9/2024 |
8.3.0-beta-0015 | 109 | 6/3/2024 |
8.3.0-beta-0010 | 129 | 5/13/2024 |
8.3.0-beta-0005 | 102 | 5/10/2024 |
8.2.1 | 689 | 4/22/2024 |
8.2.0 | 369 | 4/8/2024 |
8.1.0 | 221 | 3/10/2024 |
8.0.0 | 1,577 | 2/21/2024 |
8.0.0-beta-0030 | 546 | 2/19/2024 |
8.0.0-beta-0025 | 587 | 1/15/2024 |
8.0.0-beta-0020 | 166 | 1/15/2024 |
8.0.0-beta-0015 | 225 | 12/29/2023 |
8.0.0-beta-0010 | 261 | 12/20/2023 |
8.0.0-beta-0005 | 238 | 12/9/2023 |
7.2.0 | 412 | 12/8/2023 |
7.2.0-beta-0007 | 195 | 12/8/2023 |
7.2.0-beta-0005 | 194 | 12/8/2023 |
7.1.0 | 369 | 10/23/2023 |
7.1.0-beta-0015 | 221 | 7/28/2023 |
7.1.0-beta-0013 | 231 | 6/28/2023 |
7.1.0-beta-0011 | 187 | 6/25/2023 |
7.1.0-beta-0006 | 217 | 6/24/2023 |
7.1.0-beta-0003 | 201 | 6/24/2023 |
7.1.0-beta-0002 | 221 | 6/24/2023 |
7.1.0-beta-0001 | 239 | 5/31/2023 |
7.0.3 | 398 | 9/25/2023 |
7.0.2 | 312 | 7/27/2023 |
7.0.1 | 337 | 7/26/2023 |
7.0.0 | 744 | 4/20/2023 |
7.0.0-beta-0010 | 241 | 4/5/2023 |
7.0.0-beta-0008 | 212 | 2/26/2023 |
7.0.0-beta-0005 | 276 | 2/12/2023 |
7.0.0-beta-0003 | 263 | 1/29/2023 |
7.0.0-beta-0001 | 234 | 1/29/2023 |
6.8.0 | 1,020 | 2/11/2023 |
6.8.0-beta-0003 | 203 | 2/11/2023 |
6.8.0-beta-0001 | 254 | 1/29/2023 |
6.7.2 | 665 | 1/29/2023 |
6.7.1 | 1,440 | 12/20/2022 |
6.7.0 | 733 | 12/17/2022 |
6.6.0 | 924 | 12/2/2022 |
6.5.4 | 950 | 11/23/2022 |
6.5.3 | 860 | 11/23/2022 |
6.5.2 | 930 | 11/14/2022 |
6.5.1 | 1,247 | 10/19/2022 |
6.5.0 | 1,157 | 10/3/2022 |
6.4.3 | 1,129 | 9/28/2022 |
6.4.2 | 1,152 | 9/26/2022 |
6.4.1 | 1,201 | 9/18/2022 |
6.4.0 | 1,192 | 8/31/2022 |
6.3.5 | 1,154 | 8/12/2022 |
6.3.4 | 1,398 | 7/25/2022 |
6.3.3 | 1,272 | 7/22/2022 |
6.3.2 | 1,222 | 7/11/2022 |
6.3.1 | 1,308 | 7/2/2022 |
6.3.0 | 1,189 | 7/1/2022 |
6.2.1 | 1,436 | 6/15/2022 |
6.2.0 | 1,210 | 6/2/2022 |
6.1.1 | 1,333 | 5/12/2022 |
6.1.0 | 1,376 | 5/1/2022 |
6.0.6 | 1,257 | 4/6/2022 |
6.0.5 | 1,152 | 4/4/2022 |
6.0.4 | 1,131 | 4/2/2022 |
6.0.3 | 1,112 | 4/1/2022 |
6.0.2 | 1,108 | 3/31/2022 |
6.0.1 | 1,101 | 3/25/2022 |
6.0.0 | 1,158 | 3/24/2022 |
6.0.0-beta-0035 | 335 | 3/17/2022 |
6.0.0-beta-0030 | 354 | 3/15/2022 |
6.0.0-beta-0025 | 349 | 3/14/2022 |
6.0.0-beta-0006 | 290 | 3/6/2022 |
6.0.0-beta-0005 | 356 | 2/28/2022 |
6.0.0-beta-0004 | 284 | 2/28/2022 |
6.0.0-beta-0003 | 275 | 2/27/2022 |
6.0.0-beta-0001 | 321 | 2/25/2022 |
5.8.0 | 1,287 | 2/15/2022 |
5.7.0 | 1,293 | 1/26/2022 |
5.6.0 | 735 | 12/7/2021 |
5.5.0 | 1,024 | 12/4/2021 |
5.4.2 | 6,265 | 11/24/2021 |
5.4.1 | 813 | 11/17/2021 |
5.4.0 | 759 | 11/15/2021 |
5.3.3 | 814 | 11/9/2021 |
5.3.2 | 862 | 11/5/2021 |
5.3.1 | 909 | 10/28/2021 |
5.3.0 | 889 | 9/22/2021 |
5.2.6 | 846 | 9/16/2021 |
5.2.5 | 892 | 9/13/2021 |
5.2.4 | 834 | 9/3/2021 |
5.2.3 | 847 | 8/31/2021 |
5.2.2 | 875 | 8/27/2021 |
5.2.1 | 842 | 8/25/2021 |
5.2.0 | 894 | 8/15/2021 |