Data Driven WPF and Silverlight Applications


Published on

Published in: Technology
  • Be the first to like this

No Downloads
Total views
On SlideShare
From Embeds
Number of Embeds
Embeds 0
No embeds

No notes for slide
  • Things have got much better in terms of user interaction in other walks of life since the GUI was brought to us on Windows and the MAC, but although things have improved since Windows 3.0, in some ways nothing has changed since 1980sUser experience is more than “looks”. User experience represents the overall interaction process of the user with an object. This interaction provides the user with an added value benefit. In this case the benefit that both tools offer is “opening a can”. However it is evident that the can opener will provide the user with a better overall user experience on obtaining the benefit. It is more secure, easier to use and can achieve the benefit faster than the knife.Let’s take this example even further. What is the difference between 2 cars - a 10K car and a 40K BMW? Both take you from point A to point B. There’s a world of difference. For one, the BMW has a much superior user experience (styling, handling, performance, etc.) In addition, notice that a BMW offers its owners an emotional connection, a “pride of ownership.” This gives BMW a unique brand in the eyes of its owners, and to the millions of potential owners who dream of buying this car some day! This shows us that user experience has tremendous business value – ability to differentiate products, create brand awareness, and customer satisfaction.
  • Stands for EXtensiveApplication Markup LanguageEasily toolable, declarative markupBuild applications in simple declarative statementsCan be used for any CLR object hierarchyCode and content are separateStreamline collaboration between designers and developersDevelopers add business logic, while designers design Can be rendered in the browser (as part of a web page) or as a standalone application
  • Family Show Library
  • XAML DemosSilverlight anatomyHTMLobject tagASP.NET FileXAP file
  • Silverlight Background projectSilverlight LocalInteraction project
  • Talking Points: When we talk about the Entity Framework, we’re actually talking about two things: The Entity Data Model (EDM) The Entity Framework It’s important to delineate the two as separate, but complementing technologies The Entity Framework is a set of services that allow you to consume an EDM from within your applications. Object services is a set of classes that allow you to query an EDM and retrieve your results in the form of strongly-typed CLR objects. Entity Client allows you to query an EDM using a traditional ADO.NET paradigm (EntityConnection, EntityDataReader, etc.) Provides a smooth migration path for developers that are new to the Entity Framework Offers performances benefits due to the lack of object materialization Entity SQL is a SQL-like language that let’s you query your EDM with full control. Unlike SQL, Entity SQL queries the conceptual model, so your queries can be expressed in terms of the way your application sees your model, not how your database is actually shaped. LINQ To Entities sits on top of Object Services and allows you to retrieve strongly-typed objects from your EDM, expressed through familiar LINQ query syntax.The Entity Framework is RDMS agnostic, and numerous database vendors are currently developing providers: Oracle, DB2, MySQL, PostgreSQL, VistaDB, SQLite, Sybase, Informix, etc.
  • Estimated Time: 6 minutesTalking Points: When we talk about the Entity Framework, we’re actually talking about two things: The Entity Data Model (EDM) The Entity Framework It’s important to delineate the two as separate, but complementing technologies The EDM is a set of layers that make up your application’s model, as well as it’s mapping to an underlying data store. Made up of three files: CSDL (Conceptual Schema Definition Language) MSL (Mapping Specification Language) SSDL (Storage Schema Definition Language) This separation of concerns allows great flexibility: Model your application the way you want regardless of the state/structure of its underlying data store Normalize your database as much as you need without worrying about affecting the interface of the application’s object model The EDM represents a re-useable application model that can be leveraged from within many applications/environments and persisted across numerous databases. The Entity Data Model is RDMS agnostic, and numerous database vendors are currently developing providers: Oracle, DB2, MySQL, PostgreSQL, VistaDB, SQLite, Sybase, Informix, etc. The Entity Data Model primarily of three main concepts: Entities, which represent your domain objects. Associations, which represent a relationship between two entities. Functions, which represent stored procedures or UDFs in your database that can be mapped to model-level functionality. Because there will be plenty of situations where you’ll need to use stored procedures, the Entity Data Model allows you to map functions in your model to a store procedure in your database. This is useful because you can leverage a stored procedure without having to write ADO.NET code to call it, you can simply call a function on your model. EDM functions are represented as methods on your ObjectContext class.
  • EFConsoleDemoTO DO:Add EDM for Adventure Works Product and SalesOrderDetailLook inside EDM to show: CSDL (Conceptual Schema Definition Language) MSL (Mapping Specification Language) SSDL (Storage Schema Definition Language)
  • Estimated Time: 1 minuteTalking Points: Now that we’ve seen the Entity Data Model, let’s see how to work with it using the Entity Framework. The Entity Framework is a set of services that allow you to consume an EDM from within your applications:Entity Client Entity SQL Object Services Entity SQL LINQ To Entities We’ll take a look at the 3 different flavors on consumption in detail, and discuss why and when you would use each one.
  • Estimated Time: 3 minutesTalking Points: This diagram helps to illustrate how each of the Entity Framework’s query options relate to each other. At the core of it all is the database-specific provider. This layer is what translates the query into the SQL flavor required for the underlying data source. Above that is the Entity Client API, which takes the Entity Framework query and passes in down to the database specific provider. If you want to use the Entity Client API directly, you see that you’re only query option is Entity SQL, and because it sits below Object Services, you don’t get any of its benefits. If you want to materialize your queries as objects, and get things like change tracking, identity mapping, relationship loading, etc. then you would use object services, that delegates its queries down to the Entity Client layer. When using Object Services you can leverage both Entity SQL and LINQ to make your queries.
  • Estimated Time: 4 minutesTalking Points: The Entity Client is an Entity Framework “port” of the familiar object model of classes used in traditional ADO.NET programming, including:EntityCommandEntityConnectionEntityConnectionStringBuilderEntityDataReaderEntityParameterEntityTransaction Because of this fact it makes it a prime choice for developers migrating to the Entity Framework from ADO.NET. Just like traditional ADO.NET, your queries are returned as sequential text-based data that can iterated over using an EntityDataReader. This is great for performance, but lacks the rich object model that was created as part of your EDM. Entity Client gives you read-only access to your EDM. If data modification is required, you’ll have to use Object Services, which we’ll talk about in a bit. When using Entity Client, your queries are written using Entity SQL, which we’ll talk about in the next slide.
  • Estimated Time: 4 minutesTalking Points: Entity SQL is a query language that is syntactically very similar to SQL, but serves the sole-purpose of querying an EDM. Because it is meant for querying your EDM, this means your queries are written against your conceptual model, not your underlying data store. This higher-level abstraction allows you to write a textual query that is database agnostic. The translation from Entity SQL to T-SQL or PL/SQL (or whatever flavor your underlying data uses), is done by the selected ADO.NET Provider. Here we see a simple example that shows the same query written in T-SQL as well as Entity SQL. Notice that in Entity SQL we don’t have to do any joins, because the notion of relationships are first-class in our conceptual model. As a result, our query is half the size as the T-SQL version. Notice the use of the “Length” function in our Entity SQL example. This is called a “Canonical Function”, which is a high-level abstraction of a database function that will be translated into it’s respective database-specific flavor by your underlying provider
  • Estimated Time: 5 minutesTalking Points: While the Entity Client API is great and performant, it lacks the use of our created object model, as well as the ability to update data in our model. The Object Services API sits on top of Entity Client, and provides object materialization on top of our queries. This means that instead of getting text-based results, we get back a collection of CLR objects that we can easily work with. The two mains components of the Object Services taxonomy are: ObjectContext, and ObjectQuery<T>ObjectContext is equivalent to an EntityConnection, and is what manages our connection to the EDM as well as provides crucial services for working with our data.ObjectQuery is equivalent to an EntityCommand and represents a single query executed against our EDM, that is manifested back as strongly-typed objects. Object Services allows you to write queries using two flavors: Entity SQL LINQ To Entities The same Entity SQL queries you would write using Entity Client can be leveraged with Object Services, but with the added benefits you get with the higher abstraction level (i.e. object materialization). While Entity SQL is great for scenarios that require a dynamic query, or greater control over your query’s shape, you’re still working with a string that is error-prone. In addition to Entity SQL, Object Services allows you to write your queries against it in LINQ which provides you with strong-typing, error-checking, and a higher level of abstraction from Entity SQL. If you are already familiar with LINQ, then you don’t have to master Entity SQL in order to query an EDM, because LINQ To Entities will make the translation for you. In addition to object materialization, object services provides you with other benefits/services: Unit of work Your Object Context represents your unit of work, which aggregates all changes made to all entities attached/contained in it, so that when you want to push those changes back to the server, you can do so in a single batch. Identity tracking The ObjectContext keeps track of the entities you’ve queried for by key, so that if you later request the same entity (by key), using the same ObjectContext instance, it will return you the instance it already has instead of re-hitting the database. Eager/explicit loading The Entity Framework doesn’t pre-load any relationship properties for you. If you want to query an entity as well as some of it’s related entities, you’ll need to explicitly request that by performing a “span” using the Include method of the ObjectQuery<T> class. Alternatively you can call the Load method on your entity’s relationship property.
  • Table per type – classic inheritance where separate table contains additional propertiesTable per hierarchy – many types contained in one table and used an indicator flag to indicate the type, table may contain null columns when they have no relevance to type. Situation may occur when table had been de-normalized. Can create many sub-types based on table.Table per concrete type – all information for sub-type in a separate table, e.g. discontinued product information used for reference
  • EFConsoleDemoTO DO:Create 1 to Many Association between Product and SalesOrderDetail on ProductIDDemo code inside EFConsoleDemo
  • Estimated Time: 4 minutesTalking Points: Let’s briefly take a look at some common scenarios that services apply. If you develop an AJAX application, the client requests a page and the server returns HTML and JavaScript. At that point all communication happens between the client (JavaScript) and the server. This situation will typically call for a set of services on the server that the client can call using AJAX. In this scenario, the service required for client-server communication is largely data centric, and could look similar to the example we saw in the previous slide [Advance Animation] In a Silverlight application, the server returns the compiled Silverlight app, which then runs on the client’s machine. At that point any client-server communication is done with services. A lot of the services required by the client might be data-centric, at which point we’re in the same situation as we saw in the previous slide [Advance Animation] If you’re creating an online service that is meant to provide data over the cloud, then you’re creating nothing but data access logic, so we’re looking at the same scenario as before [Advance Animation] Finally if you’re creating a mashup, your server returns the UI of the mashup itself, which in turn contains logic for communicating with the data feeds that you’re mashing up. There are many other scenarios that require the use of services, but these exemplify enough the need for services that are largely data-centric. Keep in mind, that there are plenty of scenarios where service functionality that is operational in nature and not data-centric, is also typically required. But in many cases in these scenarios, the common need is data.
  • Estimated Time: 4 minutesTalking Points: Today is we wanted to make a web service using the .NET stack, we could use ASMX or WCF. Both options are great and provide there own level of flexibility and ease-of-use, based on your own familiarity. Imagine we create a service, and initially our service’s purpose is to return a specific customer from a data store [Advance Animation] We simply create a GetCustomer method on our service, and we’re good to go. We later realize that we need to be able to retrieve a list of all customers as well [Advance Animation] We add a GetCustomers method that retrieves all customers, easy enough. We realize that we’ll also have a need to retrieve customers, sorted by a specific field [Advance Animation] We add an overloaded version of GetCustomers that takes an order column. While our service’s functionality is increasing, so is its size. Now we realize that we need to be able to specify the sort direction of the ordered customers we retrieve [Advance Animation] Yet another overloaded version of our GetCustomers method is created. While being able to retrieve all customers is great, the amount of data being transported is too much, so we need to implement a paging mechanism [Advance Animation] Great, now we have paging, and another GetCustomers overloaded. Then we realize we need to be able to apply an arbitrary filter criteria to the method, so we add yet another overload [Advance Animation] So now we have created six methods on our service just to retrieve customer data with ordering, paging, and filtering. What if we later needed address data, and orders made by customers, etc. The amount of code needed to write data access code grows exponentially. Even further, we have only discussed the read operations. What if we later need to have insert, update, and delete methods for customers on our service? Yet more methods added, and more boilerplate code written.
  • Representational State Transfer (REST) is an architectural pattern used in the design of services. REST is about the way in which you expose and make available to callers the contract of the service. REST, therefore, is opposed to SOAP. WCF Data Services’ RESTful interface uses a common URL syntax that clients can learn and leverage across all data services This makes it easy to consume new data services once you’re familiar with the syntax
  • It’s important to note that the “Data” in “Data Services” isn’t referring to a database. A data service is meant to expose data, of any kind over the web, in a standard, and easily consumable fashion. A data service is capable of exposing any object model that contains public properties of type IQueryable<T>. This criteria matches LINQ To SQL, and the Entity Framework, but can just as easily fit a custom object model. Data services implements the Atom Publishing Protocol (AtomPub or APP): Maps HTTP verbs to CRUD operations: GET = Read POST = Create PUT = UpdateDELETE = Delete Exposes the data in the form of Atom feeds and entries
  • http://localhost/WCFDataServices/Service.svc/$metadatahttp://localhost/WCFDataServices/Service.svc/Productshttp://localhost/WCFDataServices/Service.svc/Product(324)http://localhost/WCFDataServices/Service.svc/Product(324)/Namehttp://localhost/WCFDataServices/Service.svc/Product(324)/Name/$valuehttp://localhost/WCFDataServices/Service.svc/ProductSubcategories(2)/Productshttp://localhost/WCFDataServices/Service.svc/ProductSubcategories(2)/Products(789)/Namehttp://localhost/WCFDataServices/Service.svc/Products?$orderby=Namehttp://localhost/WCFDataServices/Service.svc/Products?$filter=Color%20eq%20'Black’http://localhost/WCFDataServices/Service.svc/Products?$top=2http://localhost/WCFDataServices/Service.svc/Products?$top=2&$skip=2http://localhost/WCFDataServices/Service.svc/ProductSubcategories?$expand=Products
  • Estimated Time: 2 minutesTalking Points: While working with a data service in a browser is great, that doesn’t exactly help accent a client application very much. Because data services have a RESTful interface, you could program against use them using any HTTP stack, such as the HttpWebRequest class in .NET.HttpWebRequest doesn’t offer the rich data platform client functionality that developers might expect, which is why ADO.NET Data Services provides a set of client APIs for working with data services in a more intuitive way: There is a client API for .NET applications as well as Silverlight applications. These allow you to consume a data service from within managed code. There is a new data source control that allows the consumption of a data service using the familiar data source paradigm with an ASP.NET application, that can be easily connected to a GridView, ListView, FormView, or DetailsView. Finally there is a client-side API that allows data service consumption using the ASP.NET AJAX library. With these four client options, you are able to consume a data service from within any .NET application, regardless of the environment.
  • Estimated Time: 3 minutesTalking Points: When using the .NET client API, the DataServiceContext class represents your connection to the data service. The DataServiceContext class provides a lot of functionality around consuming a data service. The arguable two most notable features it provides are: An abstraction layer over the HTTP requests made to the service Object materialization Writing the code required to communicate with a data service using the HttpWebRequest class wouldn’t be that hard, but it would quickly get pretty verbose and time-consuming. Being able to use the DataServiceContext class saves you the effort of working at the HTTP-level completely (there are hooks that let you peer into it if you need to) and allows you to simply request the data you want and let the API handle the plumbing for you. As we saw in our previous examples, the data service returns data in AtomPub format by default, which is great, but would be a pain to have to manually parse in our client application. Fortunately the DataServiceContext class provides full object materialization which translates the returned AtomPub content into CLR objects that we can easily use. The best part about the DataServiceContext’s object materialization is that is doesn’t require the client-side model to match the service-side model at all. As the diagram illustrates, the two-models are completely independent and can to a large degree evolve independently.
  • Data Driven WPF and Silverlight Applications

    1. 1. Data Driven WPF and Silverlight Applications<br />Dave Allen<br />ISV Application Architect<br />Developer and Platform Group<br />Microsoft UK<br />
    2. 2. Agenda<br />Windows Presentation Foundation<br />Silverlight<br />Entity Framework<br />WCF Data Services<br />Silverlight & WCF Data Services<br />Silverlight & WCF RIA Services<br />
    3. 3. The Windows Client Platform<br />Silverlight Mobile<br />Mobile<br />.NET<br />XAML<br />Desktop<br />Web<br />WPF<br />Silverlight<br />
    4. 4. Windows Presentation Foundation<br />Now in it’s forth release: 3.0, 3.5, 3.5 SP1, 4.0<br />Highly stable platform for rich client applications<br />Many bug fixes and supplemental features<br />Performance optimizations – especially cold start-up<br />Some mixed messages on it’s initial release<br />WinForms is dead, no further development – not true!<br />Backtrack – WPF isn’t really suitable for LOB – was true!<br />Tooling not good enough for RAD of LOB apps – was true!<br />WPF is moving into mainstream LOB<br />WPF 4.0 primary goal is LOB applications<br />WPF Toolkit still available for supplemental features<br />
    5. 5. Silverlight (subset of WPF)<br />Now in it’s forth release: 1.0, 2.0, 3.0, 4.0<br />Platform for Rich Internet Applications (RIAs)<br />Was originally a browser plug-in – still it’s primary use<br />Cross-browser, cross-platforms, cross-device<br />Includes .NET Runtime for C# and VB.NET<br />Some key features<br />From SL3 will now run out-of-browser<br />Primary development platform for Windows Phone 7<br />Includes rich networking stack<br />Integrates with HTML DOM<br />Supports Isolated Storage<br />Supports Safe File Open Dialog<br />
    6. 6. The user experience<br />
    7. 7. Primary features of WPF/Silverlight<br />Vector based graphics, resolution-independent DPI <br />Composition engine – allows nesting of all controls<br />Unified programming model for 2D, 3D, and Media<br />Declarative programming model with XAML<br />High degree of control over styling<br />Powerful text engine and rendering <br />Support different types of layout<br />Advanced animation techniques<br />Built-in support for data binding<br />Interop with COM components<br />
    8. 8. WPF/Silverlight programming model<br />XAML<br />C#<br />VB.NET<br /><Button Width="100"> OK<br /> <Button.Background><br /> LightBlue<br /> </Button.Background><br /></Button><br />Button b1 = new Button();<br />b1.Content = "OK";<br />b1.Background = new SolidColorBrush(Colors.LightBlue);<br />b1.Width = 100;<br />Dim b1 As New Button<br />b1.Content = "OK"<br />b1.Background = New _ SolidColorBrush(Colors.LightBlue)<br />b1.Width = 100<br />Declarative programming with XAML<br />UI and code easy to separate<br />1:1 matching between XAML and code<br />Easily toolable<br />
    9. 9. Demo<br />WPF applications<br />
    10. 10. WPF/Silverlight UI components<br />Controls<br />Layout (Canvas, Border, StackPanel, Grid)<br />Button, Calendar, Checkbox, Datagrid, DateTimePicker, GridSplitter, HyperLink, Image, ListBox, MediaElement, MultiScaleImage, Popup, Radio, Slider, TextBox, TextBlock, Toggle, Tooltip, etc.<br />User Control – aggregation of existing controls<br />Styling<br />Reuse of UI properties across multiple controls<br />Templating<br />Override the way a control displays itself<br />Data templating for customization of how data is displayed<br />Data Binding<br />Allows binding of DataContext to a DataSource<br />
    11. 11. Demo<br />XAML and Silverlight anatomy<br />
    12. 12. Silverlight behind the scenes<br />Background processing on separate thread<br />System.ComponentModel.BackgroundWorker<br />Web Services<br />SOAP 1.1 BP + Duplex, JSON, REST, RSS<br />Sockets<br />Only ports 4502-4534 are supported <br />Isolated Storage<br />Per user, per application or per site/domain<br />1Mb quota is the default, can be changed<br />File Open Dialog<br />Allows user to choose file, access the file stream, upload<br />
    13. 13. Demo<br />Behind the scenes<br />
    14. 14. Silverlight 3/4 Features<br />Silverlight 3<br />60+ new controls added<br />Data Forms<br />Deep Linking<br />Multi-page Application<br />Element to Element binding<br />Out of Browser <br />Silverlight 4<br />Printing support<br />Rich text support<br />32 new languages + right to left support<br />Elevated privileges and COM automation (OOB)<br />Webcam/Mic support<br />
    15. 15. WPF and Silverlight applications<br />The paradigm shift<br />WPF not a natural fit for a WinForms, VB6, MFC developer that has grown up on GDI/User32<br />XAML mark-up language more familiar to Web developers<br />Visual Studio 2010 and Expression Blend generate XAML<br />WPF/Silverlight/XBAP – too many options?<br />Decision is much simpler than you think<br />If you develop and deploy WinForms applications today<br />WPF is the natural choice – full fidelity .NET<br />If you develop WinForms applications and deployment is a problem, then XBAP could be the answer<br />Restricted to browser sandbox – full fidelity .NET<br />Also consider Out of Browser Silverlight<br />If you target the browser today and are moving to RIA<br />Silverlight is the natural next step<br />
    16. 16. ADO.NET Entity Framework<br />Another data access technology!?!<br />Not designed to replace what has gone before<br />Addresses the OOP versus Relational problem<br />OOP very well established<br />Relational have been around even longer<br />Bridging the gap has mostly been a manual task<br />Some 3rd party solutions, core problem remains<br />Objects != Relational Data<br />Fundamental problem is that relational data and objects in a programming language are NOT the same!<br />They have different semantics, languages, etc.<br />But both are still needed in most applications<br />
    17. 17. ADO.NET Entity Framework<br />Entity Data Model<br />Models Entities and relationships between those Entities<br />How does it bridge the gap between OOP and Relational<br />Common type system<br />Inheritance<br />Complex types<br />EDM is scoped to just modeling design of application data<br />Entity Framework<br />Provides services for consuming an EDM<br />Object Services<br />Entity Client (EntityConnection, EntityDataReader, etc.)<br />Entity SQL<br />LINQ To Entities<br />Provider model for 3rd party databases<br />
    18. 18. Entity Data Model<br />Application model<br />Mapped to a persistence store<br />Comprised of three layers:<br />Conceptual (CSDL)<br />Mapping (MSL)<br />Storage (SSDL)<br />Database agnostic<br />Not compiled<br />Embed as a resource<br />Store externally<br />Entity Data Model<br />Conceptual<br />Mapping<br />Storage<br />
    19. 19. Demo<br />Entity Data Model <br />
    20. 20. Entity Framework<br />EDM consumption options:<br />Entity Client<br />Entity SQL<br />Object Services<br />Entity SQL<br />LINQ To Entities<br />
    21. 21. Entity Framework – Service Stack<br />LINQ To Entities<br />Entity SQL<br />Object Services<br />Entity Client<br />ADO.NET Provider<br />
    22. 22. Entity Client<br />Familiar ADO.NET object model:<br />EntityCommand<br />EntityConnection<br />EntityDataReader<br />Entity Parameter<br />EntityTransaction<br />Text-based results<br />Read-only<br />Uses Entity SQL<br />
    23. 23. Entity SQL<br /><ul><li>SQL-like query language
    24. 24. Targets conceptual model
    25. 25. Database agnostic</li></ul>T-SQL<br />Entity SQL<br />
    26. 26. Object Services<br />Object materialized queries<br />ObjectContext<br />ObjectQuery<T><br />Built on top of Entity Client<br />Two query options:<br />Entity SQL<br />LINQ<br />Runtime services:<br />Unit of work<br />Identity tracking<br />Eager/explicit loading<br />
    27. 27. Entity Framework features<br />Many to many relationships<br />Join tables ignored by designer in EDM<br />Side-effect, relationships cannot contain data<br />LINQ supports this via the aggregate functions<br />Inheritance<br />Allows Entities to be specialized<br />Maps to CLR inheritance<br />Fully supported in queries<br />3 types of inheritance<br />Table per type<br />Table per hierarchy<br />Table per concrete type<br />
    28. 28. Entity Framework features (2)<br />Entity splitting<br />Single entity split across multiple tables, something you may do with very large tables<br />Stored procedures<br />Most asked question about EF<br />Fully supported for CUD, map CUD functions to SPs<br />Mainly supported for queries, but doesn’t support composable queries, dynamic SQL within SPs<br />No metadata available at design-time<br />Working against principles of EF<br />Don’t use EF if you do this<br />Consider using TVF instead of SPs<br />
    29. 29. Entity Framework 4.0 new features<br />Model-first development<br />Automatic pluralization<br />Foreign keys in models<br />POCO class support<br />Lazy loading<br />T4 Code Generation<br />Template customization<br />IObjectSet<br />Virtual SaveChanges<br />ObjectStateManagercontrol<br />Self-tracking entities<br />SQL generation improvements<br />More LINQ operator support<br />LINQ extensibility<br />ExecuteStoreQuery<br />ExecuteStoreCommand<br />SPROC import improvements<br />Model defined functions<br />WPF designer integration<br />
    30. 30. Demo<br />Entity Framework<br />
    31. 31. Data Service over HTTP<br />HTML + JavaScript<br />DLL + XAML<br />Mashup UI<br />Data (XML, etc)<br />Data (XML, etc)<br />Data (XML, etc)<br />Data Feeds<br />AJAX Applications<br />Silverlight Applications<br />Online Services<br />Mashups<br />
    32. 32. Data Services today<br />Web Service (ASMX, WCF)<br />1) GetCustomer(int id)<br />2) GetCustomers()<br />3) GetCustomers(string orderBy)<br />4) GetCustomers(string orderBy, string sortDirection)<br />5) GetCustomers(string orderBy, string sortDirection,<br />int offset, int count)<br />6) GetCustomers(string orderBy, string sortDirection,<br />int offset, int count,<br /> string filter, string filterValue)<br />
    33. 33. WCFData Services<br />Data publishing service using a RESTful interface<br />Just uses HTTP<br />Therefore is able to use existing authentication mechanisms, and other infrastructure components such as caching and proxies<br />Uniform URL Syntax<br />Every piece of information is addressable<br />Predictable and flexible URL syntax<br />Multiple representations<br />ATOM<br />JSON<br />POX<br />
    34. 34. WCFData Services (2)<br />Exposes an object model (not a database) over the web<br />Entity Data Model – WCFDS designed to work with EDM<br />LINQ To SQL model, read-only<br />Custom IQueryable<T> provider<br />Operation semantics, mapping of HTTP verbs for CRUD operations<br />GET – retrieve resource<br />POST – create a resource<br />PUT – update a resource<br />DELETE – delete a resource<br />
    35. 35. URL Conventions<br />Addressing entities and sets<br />Presentation options<br />
    36. 36. Filters<br />Logical operators<br />and, or , asc, desc, eq, ne, true, false, gt, ge, lt, le, not, null<br />Arithmetic operators<br />add, sub, div, mul, mod<br />String functions<br />endswith, indexof, replace, startswith, tolower, toupper, trim, substring, substringof, concat, length<br />Date functions<br />year, month, day, hour, minute, second<br />Math functions<br />round, floor, ceiling<br />Type functions<br />Is, Cast<br />
    37. 37. Demo<br />WCFData Services<br />
    38. 38. Securing and Customizing Data Services<br />Visibility<br />Control visibility per container<br />Read, Query, and Write options<br />Authentication<br />Integrates with the hosting environment<br />ASP.NET, WCF, or Custom authentication module<br />Interceptors<br />Execute before HTTP GET/PUT/POST/DELETE<br />Enable validation, custom row-level security<br />Maintain the REST interface<br />Service operations<br />Allow you to inject methods into URI if you need to<br />
    39. 39. Clients<br />Data Service<br />
    40. 40. SilverlightClient<br />Server<br />Client<br />Data<br />Service<br />Data<br />Service<br />Context<br />HTTP<br />Data<br />Model<br />Object<br />Model<br />
    41. 41. Demo<br />Silverlight WCF Data Services Client<br />