亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? datalayer.vb

?? TaskVision 應(yīng)用程序展示了用于個人和公司相關(guān)任務(wù)管理的一個完整的 n 層應(yīng)用程序。該示例附帶了用于運行某個私有任務(wù)服務(wù)器應(yīng)用程序的隨時可運行的示范客戶端、全部客戶端源代碼
?? VB
字號:
Imports System.Net
Imports System.Threading
Imports System.Web.Services.Protocols
Imports TaskVision.DataWS
Imports TaskVision.AuthWS

Public Enum DataLayerResult
    None = 0
    Success = 1
    ServiceFailure = 2
    UnknownFailure = 3
    ConnectionFailure = 4
    AuthenticationFailure = 5
End Enum

Public Class DataLayer

    Public DsTasks As New DataSetTasks()
    Public DsProjects As New DataSetProjects()
    Public DsLookupTables As New DataSetLookupTables()
    Public DsProjectHistory As New DataSetProjectHistory()
    Public CurrentUserInformation As New UserInformation()

    Private m_Ticket As String = Nothing
    Private m_WsData As New DataService()
    Private m_WsAuth As New AuthService()
    Private Const c_wsTimeout As Integer = 30000 '30 seconds

    Public Sub New()

        'CurrentUserInformation is a type that exists on the web service
        'hence we lose default implementation
        CurrentUserInformation.UserID = -1
        CurrentUserInformation.UserEmail = String.Empty
        CurrentUserInformation.UserFullName = String.Empty
        CurrentUserInformation.UserName = String.Empty
        CurrentUserInformation.UserPassword = String.Empty

        m_WsData.Timeout = c_wsTimeout
        m_WsAuth.Timeout = c_wsTimeout
    End Sub

#Region " Login "
    Public Function Login(ByVal userName As String, ByVal userPassword As String) As DataLayerResult
        'save the user information
        CurrentUserInformation.UserName = userName
        CurrentUserInformation.UserPassword = userPassword

        'try to get a ticket
        Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
        If ticketResult = DataLayerResult.Success Then
            Dim newUserInfo As UserInformation

            'try to get the current user information
            Try
                newUserInfo = m_WsAuth.GetUserInfo(m_Ticket)
            Catch ex As Exception
                Return HandleException(ex)
            End Try

            'this shouldn't happen unless the above
            If newUserInfo Is Nothing Then
                Return DataLayerResult.AuthenticationFailure
            End If

            'keep the returned information
            CurrentUserInformation.UserID = newUserInfo.UserID
            CurrentUserInformation.UserName = newUserInfo.UserName
            CurrentUserInformation.UserFullName = newUserInfo.UserFullName
            CurrentUserInformation.UserEmail = newUserInfo.UserEmail
            CurrentUserInformation.IsAdministrator = newUserInfo.IsAdministrator
            CurrentUserInformation.IsAccountLocked = newUserInfo.IsAccountLocked

            Return DataLayerResult.Success
        Else
            Return ticketResult
        End If
    End Function
#End Region

#Region " Auth Service "
    Private Function GetAuthorizationTicket() As DataLayerResult
        Try
            m_Ticket = m_WsAuth.GetAuthorizationTicket(CurrentUserInformation.UserName, CurrentUserInformation.UserPassword)
        Catch ex As Exception
            m_Ticket = Nothing
            Return HandleException(ex)
        End Try

        If m_Ticket Is Nothing Then
            'username/password failed
            Return DataLayerResult.AuthenticationFailure
        End If

        Return DataLayerResult.Success
    End Function

    'note: userID is ByRef
    Public Function InsertUser(ByRef userID As Integer, ByVal newUserInfo As UserInformation) As DataLayerResult
        Try
            userID = m_WsAuth.InsertUser(m_Ticket, newUserInfo)

            'all TaskVision web services return nothing to indicate an expired ticket
            If userID = -1 Then
                'get a new ticket and try the call again
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                userID = m_WsAuth.InsertUser(m_Ticket, newUserInfo)

                'this next block should never happen
                If userID = -1 Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        Return DataLayerResult.Success
    End Function

    Public Function UpdateUser(ByVal updatedUserInfo As UserInformation) As DataLayerResult
        Dim uInfo As UserInformation
        Try
            uInfo = m_WsAuth.UpdateUser(m_Ticket, updatedUserInfo)

            'all TaskVision web services return nothing to indicate an expired ticket
            If uInfo Is Nothing Then
                'get a new ticket and try the call again
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                uInfo = m_WsAuth.UpdateUser(m_Ticket, updatedUserInfo)

                'this next block should never happen. It means it took more than TIMEOUT 
                '(default is 2 min) between GetAuthTicket and GetProjects
                If uInfo Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        Return DataLayerResult.Success
    End Function

    Public Function ChangePassword(ByVal updatedUserInfo As UserInformation) As DataLayerResult
        Dim uInfo As UserInformation
        Try
            uInfo = m_WsAuth.ChangePassword(m_Ticket, updatedUserInfo)

            'all TaskVision web services return nothing to indicate an expired ticket
            If uInfo Is Nothing Then
                'get a new ticket and try the call again
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                uInfo = m_WsAuth.ChangePassword(m_Ticket, updatedUserInfo)

                'this next block should never happen. It means it took more than TIMEOUT 
                '(default is 2 min) between GetAuthTicket and GetProjects
                If uInfo Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        Return DataLayerResult.Success
    End Function
#End Region

#Region " Data Service "
    Public Function GetProjects() As DataLayerResult
        Dim ds As DataSetProjects
        Try
            ds = m_WsData.GetProjects(m_Ticket)

            ' All TaskVision web services return nothing to indicate an expired ticket
            If ds Is Nothing Then
                ' Get a new ticket and try the call again
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                ds = m_WsData.GetProjects(m_Ticket)

                ' This next block should never happen. It means it took more than TIMEOUT 
                ' (default is 2 min) between GetAuthTicket and GetProjects
                If ds Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        DsProjects.Clear()
        DsProjects.Merge(ds)
        Return DataLayerResult.Success
    End Function

    Public Function GetTasks(ByVal projectID As Integer, ByVal clearData As Boolean) As DataLayerResult
        Dim ds As DataSetTasks
        Try
            ds = m_WsData.GetTasks(m_Ticket, projectID)

            If ds Is Nothing Then
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                ds = m_WsData.GetTasks(m_Ticket, projectID)

                If ds Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        If clearData Then DsTasks.Tasks.Clear()

        DsTasks.Merge(ds)
        Return DataLayerResult.Success
    End Function

    Public Function GetLookUpTables() As DataLayerResult
        Dim ds As DataSetLookupTables
        Try
            ds = m_WsData.GetLookupTables(m_Ticket)

            If ds Is Nothing Then
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                ds = m_WsData.GetLookupTables(m_Ticket)

                If ds Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        DsLookupTables.Priorities.Clear()
        DsLookupTables.Users.Clear()
        DsLookupTables.Statuses.Clear()
        DsLookupTables.Merge(ds)
        Return DataLayerResult.Success
    End Function

    Public Function InsertProject(ByRef projectID As Integer, ByVal projectName As String, ByVal projectDescription As String) As DataLayerResult
        Try
            'note: projectID is ByRef
            projectID = m_WsData.InsertProject(m_Ticket, projectName, projectDescription)

            '-1 is our magic number for nothing, like above the ws returns nothing if the ticket is expired
            If projectID = -1 Then
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                projectID = m_WsData.InsertProject(m_Ticket, projectName, projectDescription)

                If projectID = -1 Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        Return DataLayerResult.Success
    End Function

    Public Function UpdateTasks(ByVal projectID As Integer) As DataLayerResult
        Dim ds As DataSetTasks
        Try
            'note that we are sending the whole dataset
            'if during data collision handling, the web service breaks
            'we'll be stuck with a short dataset
            ds = m_WsData.UpdateTasks(m_Ticket, projectID, DsTasks)

            If ds Is Nothing Then
                Dim ticketResult As DataLayerResult = GetAuthorizationTicket()
                If ticketResult <> DataLayerResult.Success Then
                    Return ticketResult
                End If

                ds = m_WsData.UpdateTasks(m_Ticket, projectID, DsTasks)

                If ds Is Nothing Then
                    Return DataLayerResult.AuthenticationFailure
                End If
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        DsTasks.Tasks.Clear()
        DsTasks.Merge(ds)
        Return DataLayerResult.Success
    End Function

    Public Function BeginGetTasks(ByVal projectID As Integer) As IAsyncResult
        Try
            'workaround for the expiring ticket during idle time
            'start an async call for ticket
            Dim authAr As IAsyncResult = m_WsAuth.BeginGetAuthorizationTicket(CurrentUserInformation.UserName, CurrentUserInformation.UserPassword, Nothing, Nothing)

            'start an async call for the dataset and send the ticket async result along for the ride
            Return m_WsData.BeginGetTasks(m_Ticket, projectID, Nothing, authAr)
        Catch ex As Exception
            LogError.Write(ex.Message & vbNewLine & ex.StackTrace)
            Return Nothing
        End Try
    End Function

    Public Function EndGetTasks(ByVal ar As IAsyncResult) As DataLayerResult
        Dim ds As DataSetTasks

        Try
            'this method was called after checking that both results are completed
            'grab the new ticket
            m_Ticket = m_WsAuth.EndGetAuthorizationTicket(CType(ar.AsyncState, IAsyncResult))

            'grab the new dataset
            ds = m_WsData.EndGetTasks(ar)

            If ds Is Nothing Then
                Return DataLayerResult.AuthenticationFailure
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        DsTasks.Tasks.Clear()
        DsTasks.Merge(ds)
        Return DataLayerResult.Success
    End Function

    Public Function BeginGetProjectHistory(ByVal projectID As Integer) As IAsyncResult
        Try
            'note: there is an assumption here that our ticket is always valid
            'because this method called immediately after a project or task request.

            'start an async call for the dataset
            Return m_WsData.BeginGetProjectHistory(m_Ticket, projectID, Nothing, New Object() {projectID})
        Catch ex As Exception
            LogError.Write(ex.Message & vbNewLine & ex.StackTrace)
            Return Nothing
        End Try
    End Function

    Public Function EndGetProjectHistory(ByVal ar As IAsyncResult) As DataLayerResult
        Dim ds As DataSetProjectHistory

        Try
            'grab the new dataset
            ds = m_WsData.EndGetProjectHistory(ar)

            If ds Is Nothing Then
                Return DataLayerResult.AuthenticationFailure
            End If
        Catch ex As Exception
            Return HandleException(ex)
        End Try

        DsProjectHistory.ProjectHistory.Clear()
        DsProjectHistory.Merge(ds)
        Return DataLayerResult.Success
    End Function
#End Region

#Region " Helper Functions "
    Private Function HandleException(ByVal ex As Exception) As DataLayerResult
        LogError.Write(ex.Message & vbNewLine & ex.StackTrace)

        If ex.GetType() Is GetType(WebException) Then
            Return DataLayerResult.ConnectionFailure
        ElseIf ex.GetType() Is GetType(SoapException) Then
            Return DataLayerResult.ServiceFailure
        Else
            Return DataLayerResult.UnknownFailure
        End If
    End Function
#End Region

End Class

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区在线免费看| 亚洲一区二区黄色| 中文字幕不卡在线播放| 中文子幕无线码一区tr| 亚洲一二三区在线观看| 久久99热99| 91影院在线观看| 91麻豆精品国产91久久久久久久久| 日韩欧美一区中文| 国产精品资源在线观看| 激情丁香综合五月| 色又黄又爽网站www久久| 91精品国产91久久久久久一区二区 | 久久一二三国产| 国产精品天美传媒| 日本美女一区二区三区| 国产乱码精品一区二区三区五月婷 | 成人综合激情网| 欧美日韩国产成人在线免费| 精品国产麻豆免费人成网站| 亚洲色欲色欲www| 精品亚洲成av人在线观看| 色欧美乱欧美15图片| 精品国精品自拍自在线| 亚洲国产欧美在线| 成人国产一区二区三区精品| 欧美成人一区二区三区在线观看| 久久久久久久久一| 麻豆精品一区二区三区| 欧美主播一区二区三区| 国产丝袜欧美中文另类| 蜜乳av一区二区| 欧美日韩一区二区三区视频| 一区二区三区自拍| 成人黄页毛片网站| 欧美激情一区二区| 精品亚洲porn| 久久久久久久久97黄色工厂| 一本色道a无线码一区v| 久久午夜羞羞影院免费观看| 免费在线观看精品| 日韩一级黄色片| 国产一区二区三区在线观看精品| 国产三级三级三级精品8ⅰ区| 国产精品一区一区三区| 中文字幕第一区二区| www.日韩在线| 亚洲成av人片在www色猫咪| 欧美一三区三区四区免费在线看| 国产高清不卡一区| 国产精品久久国产精麻豆99网站| 欧美在线色视频| 黄网站免费久久| 亚洲欧洲精品天堂一级| 韩国欧美国产1区| 国产精品久久久久久亚洲毛片| 91在线porny国产在线看| 日本午夜精品一区二区三区电影 | 欧美一区二区网站| 国产高清亚洲一区| 亚洲男人天堂一区| 欧美成人欧美edvon| 成人综合日日夜夜| 日本中文字幕一区二区视频| 久久精品视频网| 欧美人与z0zoxxxx视频| 国产不卡视频在线播放| 天天色综合天天| 国产呦萝稀缺另类资源| 精品一区二区日韩| 亚洲精品免费视频| 欧美成人精品3d动漫h| 欧美系列在线观看| 95精品视频在线| 国产乱理伦片在线观看夜一区| 一区二区高清视频在线观看| 久久影视一区二区| 在线播放亚洲一区| 91网站在线播放| 国产激情精品久久久第一区二区| 首页国产丝袜综合| 亚洲国产婷婷综合在线精品| 国产日韩欧美高清在线| 精品国产一区二区三区av性色| 91一区二区三区在线观看| 国产美女av一区二区三区| 一区二区三区在线免费观看| 国产欧美va欧美不卡在线 | 国产喷白浆一区二区三区| 91精品在线一区二区| 欧美三级日韩在线| 欧美浪妇xxxx高跟鞋交| 欧美亚洲日本一区| 欧美猛男超大videosgay| 欧美日高清视频| 日韩午夜激情视频| 精品国产凹凸成av人网站| 日韩精品专区在线| 亚洲精品在线免费观看视频| 国产亚洲欧美日韩日本| 国产亚洲精品7777| 欧美激情中文字幕| 亚洲美女视频在线| 亚洲精品视频一区二区| 成人av在线电影| 欧美日韩一区高清| 久久亚洲精精品中文字幕早川悠里 | 亚洲va在线va天堂| 蜜桃在线一区二区三区| 国产一区二区三区观看| 国产999精品久久| 色香蕉成人二区免费| 精品视频一区二区三区免费| 91精品国产高清一区二区三区蜜臀 | 国产日产精品1区| 曰韩精品一区二区| 日本成人中文字幕在线视频| 国产一区二区福利| 在线视频欧美精品| 久久亚洲精华国产精华液| 精品一区二区影视| 国产精品久线观看视频| 欧美成人欧美edvon| 国产69精品久久久久毛片| 久久久久久久久久久久久夜| 成人性色生活片| 日韩成人一级片| 国产精品福利av| 91精品国产综合久久福利| 国产真实乱对白精彩久久| 中文字幕在线一区| 91精品国产乱码久久蜜臀| av一区二区三区四区| 久久se精品一区精品二区| 玉米视频成人免费看| 中文字幕久久午夜不卡| 精品视频一区二区三区免费| 韩国一区二区在线观看| 亚洲午夜电影在线观看| 日韩欧美亚洲一区二区| 91电影在线观看| 99天天综合性| 粉嫩嫩av羞羞动漫久久久 | 欧美经典一区二区三区| 久久你懂得1024| 欧美日韩精品专区| 91久久精品午夜一区二区| 国产精品资源网| 国产成人av电影在线| 国产成人精品网址| 午夜婷婷国产麻豆精品| 亚洲一区二区在线免费观看视频| 一区二区三区精密机械公司| 综合av第一页| 综合激情成人伊人| 一区二区三区国产精品| 亚洲欧美日韩在线播放| 精品一区二区三区日韩| 日韩主播视频在线| 亚州成人在线电影| 亚洲精品久久久蜜桃| 国产精品人成在线观看免费| 亚洲欧洲美洲综合色网| 久久综合丝袜日本网| 日韩视频免费观看高清完整版在线观看| 亚洲欧美激情在线| 亚洲美女在线国产| 综合中文字幕亚洲| 一区二区免费看| 亚洲精品免费电影| 亚洲精品免费播放| 日韩av不卡在线观看| 免费一级欧美片在线观看| 青娱乐精品视频| 九九精品视频在线看| 蜜芽一区二区三区| 另类欧美日韩国产在线| 奇米色777欧美一区二区| 国产在线视频精品一区| 成人午夜视频在线| 欧美色图12p| 中文字幕乱码一区二区免费| 一区av在线播放| 国产一区二区三区久久悠悠色av| 成人av在线资源网站| 在线观看亚洲精品| 欧美一区二区三区视频在线观看| 欧美福利视频导航| 欧美成人a∨高清免费观看| 亚洲天堂精品视频| 三级久久三级久久| 成人18视频日本| 精品久久久久久久人人人人传媒| 中文一区一区三区高中清不卡| 亚洲成人动漫在线观看| 成人av网站大全| 亚洲精品乱码久久久久久久久| 乱一区二区av| 欧美三级三级三级| 日本一区二区三区四区 |