Back To: DotNetNuke Silverlight IWebXAML

'
' DotNetNukeŽ - http://www.dotnetnuke.com
' Copyright (c) 2002-2006
' by DotNetNuke Corporation
'
' Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated 
' documentation files (the "Software"), to deal in the Software without restriction, including without limitation 
' the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and 
' to permit persons to whom the Software is furnished to do so, subject to the following conditions:
'
' The above copyright notice and this permission notice shall be included in all copies or substantial portions 
' of the Software.
'
' THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED 
' TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 
' THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF 
' CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 
' DEALINGS IN THE SOFTWARE.
'
Imports System
Imports System.Web
Imports System.Collections.Generic
Imports DotNetNuke
Imports DotNetNuke.Services.Personalization
Namespace DotNetNuke.Modules.IWebXAML
 
    Public Class IWebXAMLSupport
        Public Shared Function SetXAMLCall(ByVal objUser As UserInfo, ByVal ModuleId As Integer, ByVal HoursToExpire As Integer) As String
            Dim strPassword As String = ""
            If objUser.UserID > -1 Then
 
                'Get a random password
                Dim RandomClass As New Random()
                Dim intRandomNumber As Integer
                intRandomNumber = RandomClass.Next()
                Dim strSilverlightKey As String = CStr(intRandomNumber)
 
                'Get the users Personalization Info
                Dim PersonalizationController As New PersonalizationController()
                Dim PersonalizationInfo As New PersonalizationInfo()
                PersonalizationInfo = PersonalizationController.LoadProfile(objUser.UserID, objUser.PortalID)
 
                ' Store the encryption key in the users profile 
                DotNetNuke.Services.Personalization.Personalization.SetProfile(PersonalizationInfo, ModuleId.ToString, "SilverlightKey", strSilverlightKey)
                DotNetNuke.Services.Personalization.Personalization.SetProfile(PersonalizationInfo, ModuleId.ToString, "SilverlightKey_Expires", DateTime.Now.AddHours(HoursToExpire))
                PersonalizationController.SaveProfile(PersonalizationInfo, objUser.UserID, objUser.PortalID)
 
                strPassword = strSilverlightKey
 
            End If
            Return strPassword
        End Function
 
    End Class
 
End Namespace