Hi,

I have followed the instructions here. Using 2.3.1

http://turbine.apache.org/turbine/turbine-2.3.1/services/torque-security-service.html

To use an extended user class. But I am getting a NoSuchMethodException on line 656 of GroupPeerManager.java

The method looks like this

    public static Group getNewGroup(Persistent p)
    {
        Group g = null;
        try
        {
            Class groupWrapperClass = TurbineSecurity.getGroupClass();

            Class [] clazz = new Class [] { Persistent.class };
            Object [] params = new Object [] { p };

            g = (Group) groupWrapperClass
                .getConstructor(clazz)
                .newInstance(params);
        }
        catch (Exception e)
        {
            log.error("Could not instantiate a new group from supplied persistent: ", e);
        }

        return g;
    }

Reading the instructions on torque-security-service.html page it says

Group Implementation org.apache.turbine.services.security.torque.TorqueGroup
Peer org.apache.turbine.services.security.torque.om.TurbineGroupPeer
Persistent object org.apache.turbine.services.security.torque.om.TurbineGroup


I am only using my own TurbineUser substitute, not any of the other security classes, so I expect from this
" Turbine uses the following configuration for accessing the Torque schema. If you just want to use the default Peers, you don't need any of the following configuration, these are the defaults:" That it will use the default stated above, so I am surprised to see it using "class org.apache.turbine.om.security.TurbineGroup"

But the class being used is in fact sub class of BaseObject and therefore does have an empty  constructor, so I cannot work out why it is throwing this exception anyway?

here are the relevant sections of my TurbineResources.properties

services.SecurityService.classname = org.apache.turbine.services.security.torque.TorqueSecurityService
...
# This is the Peer class used to access the user peer (org.apache.turbine.services.security.torque.om.TurbineUserPeer)
services.SecurityService.user.manager = org.apache.turbine.services.security.torque.TorqueUserManager
services.SecurityService.torque.userPeer.class = com.stpenable.se.om.ExtendedUserPeer
services.SecurityService.user.class = com.stpenable.se.security.ExtendedUserImpl
database.maps.builder = com.stpenable.se.util.db.map.TurbineMapBuilderAdapter
# This is the class that implements the ACL interface.
services.SecurityService.acl.class = org.apache.turbine.util.security.TurbineAccessControlList


Is there some configuration the article does not mention?

thanks

David


--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to