Subversion Repository Public Repository

litesoft

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package org.litesoft.initfrom.server.boviews.podataproviders;

import org.litesoft.bo.views.*;
import org.litesoft.bo.views.server.*;
import org.litesoft.commonfoundation.exceptions.*;
import org.litesoft.initfrom.client.boviews.*;
import org.litesoft.initfrom.server.*;
import org.litesoft.initfrom.server.pos.*;
import org.litesoft.initfrom.server.pos.UserRestrictedResourcePair;
import org.litesoft.orsup.base.*;
import org.litesoft.orsup.selection.*;
import org.litesoft.orsup.transact.*;
import org.litesoft.security.*;

import java.util.*;

public class UserViewPoServerVoDataProvider extends SecurityUserViewPoServerVoDataProvider<UserView, User, RestrictedResource> implements UserViewNames {
    public UserViewPoServerVoDataProvider( MetaDataStore pMetaDataStore ) {
        super( UserViewMetaData.getInstance(), pMetaDataStore,
               "akern@testsite.com", // ....... Anthony Kern
               "saly@testsite.com", // ........ Sally Dispop
               "dsteele@testsite.com", // ..... Donald Steele
               //
               "hdeskman@asmeds.com", // ...... Helpy Deskman
               "slick@asmeds.com", // ......... Slick Salesman
               "centralinvmgr@savrx.com", // .. Jack Barta
               //
               "peds@sns.to", // .............. George Smith
               "dm@testsite.com" // ........... Dee Man
        );
    }

    @Override
    protected SecurityUser<User> findUserByEmail( Finder pFinder, String pLogonEmail ) {
        return pFinder.findOne( User.class, WCF.isEqual( User.CD_LogonEmail, pLogonEmail ) );
    }

    @Override
    protected WhereClause augment_getMatchingVOs( WhereClause pWhereClause ) {
        User zUser = CurrentUserAccessor.get().getRequiredUser();
        if ( !zUser.canAccessAllRestrictedResources() ) // If no user it will blow up with a null pointer exception which is appropriate.
        {
            pWhereClause =
                    WCF.and( pWhereClause, User.getLimitToCurrentRestrictedResourceAndVisible() ); // Add filter to where clause to only select based on site.
        }
        return super.augment_getMatchingVOs( pWhereClause );
    }

    @Override
    public UserView currentLoggedInUserView() {
        return CurrentUserAccessor.get().getUserView( getDefaultUserLoginEmail() );
    }

    @Override
    public void logoutUser() {
        CurrentUserAccessor.get().logout();
        CurrentRestrictedResourceAccessor.get().logout();
    }

    @Override
    public SecurityUserView switchRestrictedResources( SecurityRestrictedResourceView pRestrictedResourceView ) {
        User zUser = CurrentUserAccessor.get().getRequiredUser();
        RestrictedResource zRestrictedResource = (RestrictedResource) getNotUsDataProvider( RestrictedResourceView.class )
                .getExistingPO( DataStoreLocator.get().getUnfilteredFinder(), (RestrictedResourceView) pRestrictedResourceView );
        if ( zRestrictedResource == null ) {
            throw new DisplayableRuntimeException( "RestrictedResourceNotFound", pRestrictedResourceView.toString() );
        }
        UserRestrictedResourcePair zPair = zUser.loginToRestrictedResourceIfAcceptable( zRestrictedResource );
        return finiUserLogin( zPair.getUser(), zPair.getRestrictedResource() );
    }

    @Override
    protected SecurityUserView finiUserLogin( SecurityUser<User> pUser ) {
        return finiUserLogin( pUser, CurrentRestrictedResourceAccessor.get().getOptionalRestrictedResource() );
    }

    protected SecurityUserView finiUserLogin( SecurityUser<User> pUser, SecurityRestrictedResource<RestrictedResource> pRestrictedResource ) {
        UserRestrictedResourcePair zUserRestrictedResourcePair = ((User) pUser).getLoginRestrictedResource( (RestrictedResource) pRestrictedResource );
        User zUser = zUserRestrictedResourcePair.getUser();
        RestrictedResource zRestrictedResource = zUserRestrictedResourcePair.getRestrictedResource();
        CurrentRestrictedResourceAccessor zRestrictedResourceAccessor = CurrentRestrictedResourceAccessor.get();
        zRestrictedResourceAccessor.updateRestrictedResource( zRestrictedResource );
        if ( !zRestrictedResource.equals( zUser.getLastRestrictedResource() ) ) {
            Transaction zTransaction = zUser.getFinder().createTransaction();
            zUser = zUser.copyInto( zTransaction );
            zUser.setLastRestrictedResource( zRestrictedResource );
            zTransaction.commit();
        }
        zRestrictedResourceAccessor.updateRestrictedResource( zRestrictedResource );
        UserView zUserView = CurrentUserAccessor.get().updateUser( zUser );
        zUserView.setCurrentRestrictedResource( zRestrictedResourceAccessor.getRestrictedResourceView() );
        if ( !zUser.canAccessAllRestrictedResources() ) {
            zUserView.setAlternateRestrictedResourceOptions(
                    convertToRestrictedResourceOptions( zUser.getAlternateRestrictedResourceOptions( zRestrictedResource ) ) );
        }
        return zUserView;
    }

    private AlternateRestrictedResourceOption[] convertToRestrictedResourceOptions( RestrictedResource[] pRestrictedResources ) {
        AlternateRestrictedResourceOption[] rv = new AlternateRestrictedResourceOption[pRestrictedResources.length];
        PoServerVoDataProvider<RestrictedResourceView> zRestrictedResourceViewDP = getNotUsDataProvider( RestrictedResourceView.class );
        for ( int i = 0; i < pRestrictedResources.length; i++ ) {
            rv[i] = zRestrictedResourceViewDP.createView( pRestrictedResources[i], false );
        }
        Arrays.sort( rv );
        return rv;
    }
}

Commits for litesoft/trunk/GWT_Sandbox/InitFrom/src/org/litesoft/initfrom/server/boviews/podataproviders/UserViewPoServerVoDataProvider.java

Diff revisions: vs.
Revision Author Commited Message
953 Diff Diff GeorgeS picture GeorgeS Fri 20 Jun, 2014 23:12:43 +0000

Drop Nas-Video.
Normalize the SecurityPOs.

950 Diff Diff GeorgeS picture GeorgeS Thu 19 Jun, 2014 17:57:04 +0000

New Lines

948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

939 Diff Diff GeorgeS picture GeorgeS Mon 02 Jun, 2014 21:30:31 +0000

Extracting commonfoundation

804 Diff Diff GeorgeS picture GeorgeS Wed 15 Aug, 2012 12:48:51 +0000
802 Diff Diff GeorgeS picture GeorgeS Wed 15 Aug, 2012 04:04:47 +0000
801 Diff Diff GeorgeS picture GeorgeS Wed 15 Aug, 2012 03:59:02 +0000
459 GeorgeS picture GeorgeS Sun 21 Aug, 2011 00:42:41 +0000