A bit late to comment, but .NET RIA Services was announced at MIX09. I recently spent some minutes to see what the fuzz was all about.
.NET RIA Services is a framework proclaimed for Line of Business development which is supposed to make it easy to build N-tier application. The framework makes it easy to expose your domain logic on the server to the client, with validation, authorization, querying and so on. You do this by defining a DomainService like this (taken from the RIA Services Overview):
[EnableClientAccess()] public class CityService : DomainService { private CityData _cityData = new CityData(); public IEnumerable<City> GetCities() { return _cityData.Cities; } }The EnableClientAccess attribute exposes proxies of your entities to the client by code generation. It also generates client access to your operations.
Sounds intriguing? Not really. I wouldn’t have an enterprise application rely so much on magic, but hey, it could maybe be done..
As you can see from the service, an entity called City is exposed to client:
public partial class City { [Key] public string Name { get; set; } [Key] public string State { get; set; } }
Why is the class partial you wonder..? As I said the framwork lets you validate your domain logic both on the server and client. To be able to do this you have to create a metadata class, also known as a buddy class:
[MetadataType(typeof(CityMetadata))] public partial class City { internal sealed class CityMetadata { [Required] public string Name; [Required] [StringLength(2, MinimumLength = 2)] public string State; } }Metadata classes provide a way to attach metadata to an entity without actually modifying the corresponding members on the entity itself. When you generate the client proxy you also get the validation attributes. Sounds intriguing? Not in my wildest dreams. To get validation you actually have to repeat every property of City. This is as DRY as it can possible get. Add the shared code functionality to the soup and you have yourself a maintainability nightmare. .NET RIA Services is for RAD only; prototypes and applications that never reach a satisfactory production quality. I would never ever use this in a production system.