How to: Enable Profiles in Open Ria Services

[ This document was written for WCF Services Version 1 Service Pack 2 and might not be up to date Please see Release Notes or Changelog for a list of changes since WCF RIA Services ]
This topic demonstrates how to enable profiles in your Open Ria Services solution if you have previously enabled authentication. Using profiles, you can retrieve and save properties for a user. Profiles in Open Ria Services build upon the profiles framework in ASP.NET. For more information about ASP.NET profiles, see ASP.NET Profile Properties Overview.
You can retrieve or save user profile properties only after the user has been authenticated. To configure the server and client projects for authentication, see How to: Enable Authentication in Open Ria Services.

To configure the server project

  1. 1.
    In the server project, open the Web.config file.
  2. 2.
    In the \ section, add a \ element.
  3. 3.
    In the \ element, add profile properties.
    The following example shows how to enable a profile and define a property named FriendlyName.
    <authentication mode="Forms"></authentication>
    <profile enabled="true">
    <add name="FriendlyName"/>
  4. 4.
    Open the file that contains the User class for the authentication service.
  5. 5.
    In the User class, add all of the profile properties that you added to the Web.config file.
    The following example shows how to add a property named FriendlyName that matches the property added to the Web.config file.
    Partial Public Class User
    Inherits UserBase
    Private _FriendlyName As String
    <DataMember()> _
    Public Property FriendlyName() As String
    Return _FriendlyName
    End Get
    Set(ByVal value As String)
    _FriendlyName = value
    End Set
    End Property
    End Class
    public partial class User : UserBase
    public string FriendlyName { get; set; }

To access profile properties from the client project

  1. 1.
    In the Silverlight client project, open a code-behind page.
  2. 2.
    In the code-behind page, set or retrieve profile properties on the User object of the current instance of WebContext.
    The following example shows how to set a profile property in a code-behind file.
    WebContext.Current.User.FriendlyName = "Mike"
    WebContext.Current.User.FriendlyName = "Mike";
  3. 3.
    If you want to make the WebContext object available in XAML, add the current WebContext instance to the application resources in the Application.Startup event before creating the root visual.
    The following example shows how to add the WebContext instance as an application resource.
    Private Sub Application_Startup(ByVal o As Object, ByVal e As StartupEventArgs) Handles Me.Startup
    Me.Resources.Add("WebContext", WebContext.Current)
    Me.RootVisual = New MainPage()
    End Sub
    private void Application_Startup(object sender, StartupEventArgs e)
    this.Resources.Add("WebContext", WebContext.Current);
    this.RootVisual = new MainPage();
    Using declarative syntax, you can retrieve the profile property. The following example shows how to retrieve a profile property in XAML.
    <TextBlock Text={Binding Source={StaticResource WebContext}, Path=User.FriendlyName}"/>

See Also