- Server is now asynronous which allows it to handles burst in load much better and generally better performance (latency/CPU/memory) under load.
- Client networking API the DomainClient is now based on Task instead of using the APM pattern with Begin/End methods
- Supported TargetFrameworks has changed
- Code generation now works against netstandard 2.0 and netcore 2.1+ clients
- AspNetMembership authentication (AuthenticationBase and related classes) are moved to a new namespace and nuget package
- Add a reference to OpenRIAServices.Server.Authenication.AspNetMembership if you use it
- Update both all client anor/or server nuget packages to the new version, dont't mix with v4 in the same project.
- If you have been using AuthenticationBase or other classes in the
OpenRiaServices.DomainServices.Server.ApplicationServices
namespace in your server project- Add the OpenRiaServices.Server.Authentication.AspNetMembership nuget package to it
- Replace OpenRiaServices.DomainServices.Server.ApplicationServices with OpenRiaServices.DomainServices.Server.Authentication
- Add
using OpenRiaServices.DomainServices.Server.Authentication.AspNetMembership;
in file which uses AuthenicationBase, UserBase or related classes.
- If you have compilation problems in your DomainServices because it overrides methods which do not exist then try to overridde the method with the same name but with "Async" as postfix, method signatures will be different. Eg. replace override of Invoke with override of InvokeAsync.
- Fix any additional compilation errors, use changes below for guidance about replacements.
- If you are using
OpenRiaServices.EntityFramework
the framework will now only call theSaveChangesAsync
and notSaveChanges
so if you are overridingSaveChanges
make sure you do the same forSaveChangesAsync
For better scalability (can be done afterwards):
- Update your Query and Invoke methods so that they use async/await where relevant. E.g if you are using EF6, other ORM frameworks or do network or file access.
A "new" samples repository is availible at https://github.com/OpenRIAServices/Samples
It is currently quite empty but already demonstrates some of the following scenarios:
- A simple WFP app on .Net framework
- Includes a number of queries/invokes for manually testing Task returning methods, GET/POST and exception handling
- A WFP app on .Net Core
- .net core and netstandard support
- Using Asp.Net Identity for authentication
- Writing your own custom Authentication logic
- Running OpenRiaServices in same project as Asp.Net MVC
- Complete Load/Invoke/Submit and Authentication operations on the ´SynchronizationContext` of the caller instead of saving the SynchronizationContext (#211, #209 for submit, #216, #212)
- This is a behavioral change which might break applications. This means that operations should be started on the UI thread if any data of the DomainContext or returned Operaitons are bound to the UI before completion.
- Base SubmitChanges on SubmitChangesAsync (#209)
- Submit operation will now cancel only if the web request is cancelled (and then after cancellation) Update cancellation behavior to be the same as for Load and Invoke (Follow up on #203 and #162)
- Changed extension point for SubmitChangesAsync to a new method called by both SubmitChanges and SubmitChangesAsync
protected virtual Task<SubmitResult> SubmitChangesAsync(EntityChangeSet changeSet, CancellationToken cancellationToken)
- Changed extension point for InvokeOperationAsync to a new protected method.
- Base DomainContext.Invoke on DomainContext.InvokeAsync (#203)
- Invoke operation will now cancel only if the web request is cancelled (and then after cancellation)
- Ensure Completed event is always called when Load/Invoke/SubmitOperation finishes (#206)
- AuthenticationService is rewritten to use TPM (
Task
based methods) instead ofAPM
for the methods implementing the actual authentication operations (#212, #214, #216) - Pass in endpoint name in WcfDomainClientFactory to make it easier to derive from it (#218)
- Hosting - new "PubInternal" types
- behaviors for easy creation endpoints based on standard wcf (non REST) transports
Bugfix
- Handle early cancellation (Cancellation before actual request has been sent) in WebDomainClient (#210)
- In earlier previews an exception was thrown instead of the operation beeing Cancelled
- Hosting - Endpoint changes (#218)
- Reuse the same
ContractDescription
for multiple endpoints (endpoint name is not longer added) - Dont add SilverlightFaultBehaviour by default to DomainServices
- new "PubInternal" types
- behaviors for easy creation endpoints based on standard wcf (non REST) transports
- Reuse the same
- Trigger cancellation on client disconnect (#222)
- EntityFramework: Target IDbSet instead of DbSet with AttachAsModified extension methods (#215)
- Improved test execution times by reducing waiting delays (parts in #212. 213)
This is mostly a performance and feature update. It does not contain any new breaking changes since preiew 1
- Cache ChannelFactories for large performance improvements (#184)
- Code generation now works for netstandard and netcoreapp (#199, #201)
- Fix error messages about incompatible Target frameworks when TargetFramework differs between client and server. (#188)
- Significant performance and memory usage improvemens for serialization (#189)
- Improve Perf for Query and Invoke where validation is not required (#186)
- Reduce per request allocations (#197)
- Small improvements in Task To APM wrapper for async completing operations
- Fix potential race condition when configuring endpoint authentication. (#196)
- Readme updates
Most of the changes are Brekaing changes, even if many of them will only require changes in a small percentage of applications.
1 Change DomainClient contract to Task based async methods (#153) * Performing multiple loads and waiting for the result is now faster * Any custom DomainClient or code which interact with DomainClient will no longer compile. 2. Remove old target frameworks
- Remove netstandard13 (#160)
- Remove portable class library TargetFramework (#164)
- Remove Silverlight (#174, #175 and more commits)
- .Net Framework 4.5 requirement is replaced by 4.6 (will be 4.6.1+)
- Move EntityList and QueryBuilder from OpenRiaServices...Data namespace to OpenRiaServices...Client namespace (#182)
- Dont allocate PropertyChangedEventArgs if not needed (#155)
- remove sevaral OnPropertyChanged methods and only keep RaisePropertyChanged
- If your code does not compile override RaisePropertyChanged instead
- Memory usage during Load etc is much lighter
- remove sevaral OnPropertyChanged methods and only keep RaisePropertyChanged
- Make DomainClientResult internal so it can be removed in the future
- Have
EntityContainer.LoadEntities
returnIEnumerable<Entity>
instead ofIEnumerable
- Make WebDomainClient non sealed (#166) non breaking Make CallServiceOperation virtual so that the invoke behaviour can be modified in derived classes. This should simplify adding bearer based authentication
- Cache WCF ChannelFactories per DomainContext type for improved perf (#184)
- This significantly improves the performance for the first network operation per DominContext insteance. The cost is only paid on the first access per DomainService type (not per instance). Performance of overhead for E2E benchmark of loading some simple entity from a simple DomainService went from 200% to <10% (so the speedup for creating a new instance of this specific DomainContext is above 20 times) and will improve with more complex services.
- Change from IEnumerable to IReadOnlyCollection in a few places (#183)
- Mostly ValidationErrors properties and for IEntityCollection
Behaviour changes
- Base DomainContext.Load on DomainContext.LoadAsync instead of other way around
- The generic
Load<TEntity>
can be overridden but it will only be called when any of the "Load" methods are called
DomainContext.IsLoading
is no longer set to false directly on cancellation. Instead a load is only considered done until after it has been cancelled (or completed)
- DomainServices are now async #159 and many methods have been renamed with Async suffic
- Move aspnet authentication to separate namespace, assembly and nuget package (#173) Move Authenication related code from ..Server.ApplicationServices to
- ..Server.Authentication
- and ..Server.Authentication.AspNetMembership (AuthenticationBase, UserBase ..)
-
- If you are using
OpenRiaServices.EntityFramework
the framework will now only call theSaveChangesAsync
and notSaveChanges
so if you are overridingSaveChanges
make sure you do the same forSaveChangesAsync
- If you are using
- Fixed a number of flaky tests (#161, #172, .. and more commits)
- use VS2019 for azure pipelines (#148)
- Have client test start webserver if not already running (#169)
- Changed folder structure by placing code in src folder (#176)
- net45 dependency replaced with net46 dependency
- With slightly better less allocations as a result
- Removed code market as obsolete (#170)
- Some modernisation of codebase via refactoring via code analyzers
- Add transport (OpenRiaServices.DomainServices.Client.Web) to netstandard 2.0 nuget. This provides the SoapDomainClientFactory for netstandard / netcoreapp assemblies.
- Add new interface IEntityCollection (#156) This is a combination of ICollection<>, INotifyPropertyChanged, INotifyCollectionChanged as well as typed events for Add/Remove of entitites. It helps treating collections of entities EntityCollection and EntitySet in a more uniform way. It should help OpenRiaServices.M2M integrate better with the core pacakges.
- LoadOperation performance improvements (Issue #154)
- Raise Reset action instead of multiple Add notfications for significantly imroved IU responsiveness when binding to the
Entitites or AllEntities properties before the load operation is completed.
- The UI now only updates once instead of potentially once per item
- Don't allocate multiple NotifyCollectionChangedEventArgs and PropertyChangedEventArgs for each entity loaded.
- Don't allocate event args if no one is listening
- EntityCollection performance improvements (Issue #154)
- Don't allocate NotifyCollectionChangedEventArgs on each change if no one is listening
- Add netstandard 2.0 target
- Support query translation for builtin VB operators in projects compiled using VS 2017
- Support using "soap" endpoint from client (Cross Platform)
- native support for all platforms supporting netstandard 2
- Run this code before creating first DomainContext,
DomainContext.DomainClientFactory = new OpenRiaServices.DomainServices.Client.Web.SoapDomainClientFactory()
{
ServerBaseUri = "https://my.site.com/",
};
- Limitations / differences from binary endpoint:
- Standard query size limitations apply (no workaround as for binary endpoint)
- invoke operations will use POST even when for operations with HasSideEffect=false
- soap endpoint must be manually enabled on server
- Fix namespace for ObjectContextExtensions for OpenRiaServices.EntityFramework (breaking change)
- Use VS 2017 for compilation
- Replaced multiple projects with using built in multitargeting with SDK style projects
- All assemblies are strong named ("signed") (#145)
- The "signed" version of all nuget packages will be depreciated since it is only to replace them with the "normal" nuget packages
- This will significantly make maintainance easier as well as make it easier to "get started" since there are less variations
- Add VS Extension projects to main solution
- Fix tests for VS Extension project
- Remove "Interfaces" assembly to reduce complextity and fix some problems
- New Visual Studio extension https://marketplace.visualstudio.com/items?itemName=OpenRiaServices.OpenRiaServicesTooling release in preview
- Updates "manage openriaservices link" dialog with more settings
- Update add new item for domainservice item tempate so it generates EF6 compatible code
- Add VS2017 + VS2019 support
- Bugfix when invoking tooling with unloaded projects
See: https://github.com/OpenRIAServices/OpenRiaServices/releases for release notes