Yes, I still had a variable region declared in Person that was over-riding the one in the base class I guess, so the setter was setting the super class but the subclass value was being persisted.
On Thu, Nov 26, 2015 at 8:45 PM, Stephen Cameron <steve.cameron...@gmail.com > wrote: > My silly mistake! > > On Thu, Nov 26, 2015 at 8:40 PM, Stephen Cameron < > steve.cameron...@gmail.com> wrote: > >> That is not the problem then, >> >> Its a bit bizarre actually, I generated some logging and added some >> messages, I see that two objects Participation and Participant do have >> their region value set but the Person object doesn't. >> >> All these objects extend the same base class, but the SQL insert created >> for Person doesn't have the value whereas it does for the others. >> >> The code is as follows: >> >> @Programmatic >> public void setUpdatedBy(String updatedBy) { >> if (getCreatedBy() == null) { >> setCreatedBy(updatedBy); >> System.out.println(">>>updatedBy: " + updatedBy); >> if (userRepository != null) { >> System.out.println(">>>repositoryExists"); >> ApplicationUser user = >> userRepository.findByUsername(updatedBy); >> if (user != null && user.getTenancy() != null) { >> String path = user.getTenancy().getPath(); >> String name = path.substring(path.lastIndexOf("/") + >> 1); >> if (name.isEmpty()) >> name = "GLOBAL"; >> System.out.println(">>>setting Region for name: " + >> name); >> setRegion(regions.regionForName(name)); >> }else{ >> System.out.println(">>>>user tenancy not found"); >> setRegion(regions.regionForName("GLOBAL")); //TODO >> temp fix >> } >> } >> else{ >> System.out.println(">>>userRepository is null"); >> setRegion(regions.regionForName("GLOBAL")); //TODO temp >> fix >> } >> } else >> setLastModifiedBy(updatedBy); >> } >> >> The stdout: >> >> >> 20:20:25,720 [Native qtp209845522-18 DEBUG] SELECT >> 'au.com.scds.chats.dom.module.general.Person' AS >> NUCLEUS_TYPE,a0.createdby,a0.createdon,a0.lastmodifiedby,a0.lastmodifiedon,a0.birthdate,a0.email,a0.emailaddress,a0.firstname,a0.homephonenumber,a0.middlename,a0.mobilephonenumber,a0.oldid,a0.preferredname,a0.surname,a0.person_id >> FROM person a0 WHERE a0.surname = <'Ncks'> >> >>>updatedBy: sven >> >>>repositoryExists >> 20:20:25,732 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@76fe870e >> " >> 20:20:25,732 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@76fe870e >> " >> 20:20:25,732 [Native qtp209845522-18 DEBUG] SELECT >> 'org.isisaddons.module.security.dom.user.ApplicationUser' AS >> NUCLEUS_TYPE,a0.accounttype,a0.emailaddress,a0.encryptedpassword,a0.familyname,a0.faxnumber,a0.givenname,a0.knownas,a0.phonenumber,a0.status,a0.username, >> a0.id,a0.version FROM applicationuser a0 WHERE a0.username = <'sven'> >> >>>setting Region for name: GLOBAL >> 20:20:25,738 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7dfe372f >> " >> 20:20:25,738 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7dfe372f >> " >> 20:20:25,738 [Native qtp209845522-18 DEBUG] SELECT >> 'au.com.scds.chats.dom.module.general.names.Region' AS >> NUCLEUS_TYPE,a0.`name` FROM region a0 WHERE a0.`name` = <'GLOBAL'> >> 20:20:25,785 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@74efbe8f" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,785 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@74efbe8f" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,792 [Native qtp209845522-18 DEBUG] INSERT INTO >> person >> (birthdate,contacttype_name,email,emailaddress,englishskill_englishskill_id,firstname,homephonenumber,mailaddress_location_id,middlename,mobilephonenumber,oldid,preferredname,region_name,salutation_name,streetaddress_location_id,surname,createdby,createdon,lastmodifiedby,lastmodifiedon) >> VALUES >> (<1960-10-19>,<null>,<null>,<null>,<null>,<'Stevie'>,<null>,<null>,<null>,<null>,<null>,<null>,<null>,<null>,<null>,<'Nicks'>,<'sven'>,<2015-11-26 >> 20:20:25.74>,<null>,<null>) >> 20:20:25,795 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@74efbe8f" >> 20:20:25,795 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@74efbe8f" >> >>>updatedBy: sven >> >>>repositoryExists >> 20:20:25,808 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6822e803 >> " >> 20:20:25,808 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6822e803 >> " >> 20:20:25,809 [Native qtp209845522-18 DEBUG] SELECT >> 'org.isisaddons.module.security.dom.user.ApplicationUser' AS >> NUCLEUS_TYPE,a0.accounttype,a0.emailaddress,a0.encryptedpassword,a0.familyname,a0.faxnumber,a0.givenname,a0.knownas,a0.phonenumber,a0.status,a0.username, >> a0.id,a0.version FROM applicationuser a0 WHERE a0.username = <'sven'> >> >>>setting Region for name: GLOBAL >> 20:20:25,812 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6949a458 >> " >> 20:20:25,812 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6949a458 >> " >> 20:20:25,812 [Native qtp209845522-18 DEBUG] SELECT >> 'au.com.scds.chats.dom.module.general.names.Region' AS >> NUCLEUS_TYPE,a0.`name` FROM region a0 WHERE a0.`name` = <'GLOBAL'> >> 20:20:25,815 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@7fb858f5" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,815 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@7fb858f5" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,816 [Native qtp209845522-18 DEBUG] INSERT INTO >> participant >> (lifehistory_lifehistory_id,loneliness_loneliness_id,person_person_id,socialfactors_socialfactors_id,status,createdby,createdon,lastmodifiedby,lastmodifiedon,region_name) >> VALUES (<null>,<null>,<8>,<null>,<'ACTIVE'>,<'sven'>,<2015-11-26 >> 20:20:25.814>,<null>,<null>,<'GLOBAL'>) >> 20:20:25,817 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@7fb858f5" >> 20:20:25,817 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@7fb858f5" >> 20:20:25,825 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6eb9aa9a >> " >> 20:20:25,825 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@6eb9aa9a >> " >> 20:20:25,826 [Native qtp209845522-18 DEBUG] SELECT >> 'au.com.scds.chats.dom.module.participant.Participation' AS >> NUCLEUS_TYPE,a0.createdby,a0.createdon,a0.lastmodifiedby,a0.lastmodifiedon,a0.dropofftime,a0.oldid,a0.pickuptime,a0.roleid,a0.transportnotes,a0.participation_id >> FROM participation a0 WHERE a0.activity_activity_id = <1> >> 20:20:25,831 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@34a88772" >> 20:20:25,831 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@34a88772" >> 20:20:25,832 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@5578fea9 >> " >> 20:20:25,832 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@5578fea9 >> " >> 20:20:25,832 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.approximateenddatetime,b0.copiedfromactivityid,b0.costforparticipant,b0.description,b0.isrestricted,b0.`name`,b0.oldid,b0.scheduleid,b0.startdatetime,b0.activity_id,b0.classifier >> FROM participation a0 INNER JOIN activity b0 ON a0.activity_activity_id = >> b0.activity_id WHERE a0.participation_id = <3> >> 20:20:25,835 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@456274da" >> 20:20:25,835 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@456274da" >> 20:20:25,836 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@57f25c32 >> " >> 20:20:25,836 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@57f25c32 >> " >> 20:20:25,837 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.status,b0.participant_id >> FROM participation a0 INNER JOIN participant b0 ON >> a0.participant_participant_id = b0.participant_id WHERE a0.participation_id >> = <3> >> 20:20:25,839 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@1554ed8e" >> 20:20:25,839 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@1554ed8e" >> 20:20:25,840 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@76978806 >> " >> 20:20:25,840 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@76978806 >> " >> 20:20:25,840 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.birthdate,b0.email,b0.emailaddress,b0.firstname,b0.homephonenumber,b0.middlename,b0.mobilephonenumber,b0.oldid,b0.preferredname,b0.surname,b0.person_id >> FROM participant a0 INNER JOIN person b0 ON a0.person_person_id = >> b0.person_id WHERE a0.participant_id = <3> >> 20:20:25,843 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@66f47ad4" >> 20:20:25,843 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@66f47ad4" >> 20:20:25,844 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@64779748 >> " >> 20:20:25,844 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@64779748 >> " >> 20:20:25,844 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.approximateenddatetime,b0.copiedfromactivityid,b0.costforparticipant,b0.description,b0.isrestricted,b0.`name`,b0.oldid,b0.scheduleid,b0.startdatetime,b0.activity_id,b0.classifier >> FROM participation a0 INNER JOIN activity b0 ON a0.activity_activity_id = >> b0.activity_id WHERE a0.participation_id = <6> >> 20:20:25,845 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@e5ed16d" >> 20:20:25,845 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@e5ed16d" >> 20:20:25,846 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@328b4a67 >> " >> 20:20:25,846 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@328b4a67 >> " >> 20:20:25,846 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.status,b0.participant_id >> FROM participation a0 INNER JOIN participant b0 ON >> a0.participant_participant_id = b0.participant_id WHERE a0.participation_id >> = <6> >> 20:20:25,848 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@507670dd" >> 20:20:25,848 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@507670dd" >> 20:20:25,849 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@fec3f19 >> " >> 20:20:25,849 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@fec3f19 >> " >> 20:20:25,849 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.birthdate,b0.email,b0.emailaddress,b0.firstname,b0.homephonenumber,b0.middlename,b0.mobilephonenumber,b0.oldid,b0.preferredname,b0.surname,b0.person_id >> FROM participant a0 INNER JOIN person b0 ON a0.person_person_id = >> b0.person_id WHERE a0.participant_id = <6> >> 20:20:25,852 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@46f3839a" >> 20:20:25,852 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@46f3839a" >> 20:20:25,853 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7546f02f >> " >> 20:20:25,853 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7546f02f >> " >> 20:20:25,854 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.approximateenddatetime,b0.copiedfromactivityid,b0.costforparticipant,b0.description,b0.isrestricted,b0.`name`,b0.oldid,b0.scheduleid,b0.startdatetime,b0.activity_id,b0.classifier >> FROM participation a0 INNER JOIN activity b0 ON a0.activity_activity_id = >> b0.activity_id WHERE a0.participation_id = <7> >> 20:20:25,855 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@a3e5286" >> 20:20:25,855 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@a3e5286" >> 20:20:25,856 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@2b9465d6 >> " >> 20:20:25,856 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@2b9465d6 >> " >> 20:20:25,856 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.status,b0.participant_id >> FROM participation a0 INNER JOIN participant b0 ON >> a0.participant_participant_id = b0.participant_id WHERE a0.participation_id >> = <7> >> 20:20:25,858 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@3c2b0e6c" >> 20:20:25,858 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@3c2b0e6c" >> 20:20:25,859 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@676002a >> " >> 20:20:25,859 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@676002a >> " >> 20:20:25,859 [Native qtp209845522-18 DEBUG] SELECT >> b0.createdby,b0.createdon,b0.lastmodifiedby,b0.lastmodifiedon,b0.birthdate,b0.email,b0.emailaddress,b0.firstname,b0.homephonenumber,b0.middlename,b0.mobilephonenumber,b0.oldid,b0.preferredname,b0.surname,b0.person_id >> FROM participant a0 INNER JOIN person b0 ON a0.person_person_id = >> b0.person_id WHERE a0.participant_id = <7> >> 20:20:25,863 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@41ab2f40" >> 20:20:25,863 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@41ab2f40" >> >>>updatedBy: sven >> >>>repositoryExists >> 20:20:25,871 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@65dc18d2 >> " >> 20:20:25,871 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@65dc18d2 >> " >> 20:20:25,871 [Native qtp209845522-18 DEBUG] SELECT >> 'org.isisaddons.module.security.dom.user.ApplicationUser' AS >> NUCLEUS_TYPE,a0.accounttype,a0.emailaddress,a0.encryptedpassword,a0.familyname,a0.faxnumber,a0.givenname,a0.knownas,a0.phonenumber,a0.status,a0.username, >> a0.id,a0.version FROM applicationuser a0 WHERE a0.username = <'sven'> >> >>>setting Region for name: GLOBAL >> 20:20:25,875 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7a2183e6 >> " >> 20:20:25,875 [Datastore qtp209845522-18 DEBUG] Closing >> PreparedStatement >> "org.datanucleus.store.rdbms.datasource.dbcp.DelegatingPreparedStatement@7a2183e6 >> " >> 20:20:25,881 [Native qtp209845522-18 DEBUG] SELECT >> 'au.com.scds.chats.dom.module.general.names.Region' AS >> NUCLEUS_TYPE,a0.`name` FROM region a0 WHERE a0.`name` = <'GLOBAL'> >> 20:20:25,885 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@63c44673" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,885 [Datastore qtp209845522-18 DEBUG] Using >> PreparedStatement >> "org.datanucleus.store.rdbms.ParamLoggingPreparedStatement@63c44673" for >> connection >> "org.datanucleus.store.rdbms.datasource.dbcp.PoolingDataSource$PoolGuardConnectionWrapper@15e2c48d >> " >> 20:20:25,886 [Native qtp209845522-18 DEBUG] INSERT INTO >> participation >> (activity_activity_id,arrivingtransporttype_name,departingtransporttype_name,dropofftime,oldid,participant_participant_id,pickuptime,roleid,transportnotes,createdby,createdon,lastmodifiedby,lastmodifiedon,region_name) >> VALUES >> (<1>,<null>,<null>,<null>,<null>,<8>,<null>,<null>,<null>,<'sven'>,<2015-11-26 >> 20:20:25.883>,<null>,<null>,<'GLOBAL'>) >> >> >> On Thu, Nov 26, 2015 at 8:11 PM, Dan Haywood < >> d...@haywood-associates.co.uk> wrote: >> >>> If you just new them up: >>> >>> Customer cust = new Customer(); >>> >>> then the framework doesn't know about it and any services will be null. >>> >>> You can then use: >>> >>> domainObjectContainer.injectServicesInto(cust); >>> >>> ~~~ >>> >>> Alternatively, use: >>> >>> Customer cust = container.newTransientInstance(Customer.class); >>> >>> to do both steps in one. >>> >>> HTH >>> Dan >>> >>> >>> On 26 November 2015 at 09:09, Stephen Cameron < >>> steve.cameron...@gmail.com> >>> wrote: >>> >>> > Hi, >>> > >>> > I think I've read somewhere that domain services aren't always injected >>> > into entities by default and you sometimes have to trigger this >>> yourself? >>> > >>> > Is this a correct? >>> > >>> > Thank >>> > >>> > >>> > On Thu, Nov 26, 2015 at 10:00 AM, Stephen Cameron < >>> > steve.cameron...@gmail.com> wrote: >>> > >>> > > I cannot try alternatives till later this evening, will let you know >>> > > of results. If I cannot get tenancies working for tomorrow its not >>> the >>> > end >>> > > of the world. I was getting "record not found" errors last night due >>> to >>> > > making region allowsNull="false", so a bit of a panic, given its >>> > > mostly been working very smoothly now for a while. >>> > > >>> > > On Thu, Nov 26, 2015 at 9:40 AM, Dan Haywood < >>> > d...@haywood-associates.co.uk >>> > > > wrote: >>> > > >>> > >> On 25 November 2015 at 22:26, Stephen Cameron < >>> > steve.cameron...@gmail.com >>> > >> > >>> > >> wrote: >>> > >> >>> > >> > Hi Dan, >>> > >> > >>> > >> > I did not explain it that well sorry. >>> > >> > >>> > >> > I want to get rid of nulls completely, the fact that I do handle >>> them >>> > is >>> > >> > just a work-around for the fact that they are still being >>> created, but >>> > >> only >>> > >> > for People. That is, if a new Participant is registered it looks >>> to >>> > see >>> > >> if >>> > >> > there is an existing Person with the same details then adds a new >>> one >>> > if >>> > >> > not present (a single Person can be a Participant and/or a >>> Volunteer). >>> > >> The >>> > >> > Participant is getting its region set in setUpdatedBy() but the >>> Person >>> > >> is >>> > >> > not, I need to debug this. >>> > >> > >>> > >> > >>> > >> In 1.10.0, a better approach is probably to add a subscriber to the >>> > >> lifecycle events: >>> > >> >>> > >> @DomainService(nature=NatureOfService.DOMAIN) >>> > >> public class RegionSubscriber extends AbstractSubscriber { >>> > >> >>> > >> @Subscribe >>> > >> public void on(ObjectPersistingEvent ev) { >>> > >> Object domainObject = ev.getSource(); >>> > >> } >>> > >> >>> > >> @Subscribe >>> > >> public void on(ObjectUpdatingEvent ev) { >>> > >> Object domainObject = ev.getSource(); >>> > >> } >>> > >> } >>> > >> >>> > >> >>> > >> >>> > >> >>> > >> > As general interest is handling such things via such a service >>> better, >>> > >> that >>> > >> > is to avoid injecting services into entities if possible? >>> > >> > >>> > >> > >>> > >> There's nothing wrong with injecting services into entities; it >>> allows >>> > >> them >>> > >> to perform their responsibilities without leaking details of how >>> they do >>> > >> it >>> > >> (their implementation) to the caller. I don't hold by this "pass >>> in the >>> > >> services" and "double dispatch"... I see that as a code smell. >>> > >> >>> > >> On the other hand, we now have a very rich set of domain events; in >>> AOP >>> > >> terms these are jointpoints (or is it pointcuts? see [1]), anyway >>> they >>> > are >>> > >> a different way to cause "stuff to happen". >>> > >> >>> > >> Should one have the entity call a services, or rely on subscribers >>> to >>> > >> domain events? With the latter, the entity is very clean and the >>> > >> responsibility kept completely separate. On the other hand, with >>> events >>> > >> the order in which the subscribers fire is non-deterministic. >>> > >> >>> > >> >>> > >> >>> > >> >>> > >> >>> > >> >>> > >> > Last minute tweeks aren't the best idea, but the tests that I do >>> have >>> > >> are >>> > >> > proving their value. These particular issues are probably a >>> result of >>> > no >>> > >> > integration tests yet. >>> > >> > >>> > >> > >>> > >> It's not clear to me if my suggestion to use the TenancyEvaluator >>> SPI >>> > >> helped ? Or, indeed, whether you have a reasonable workaround in >>> your >>> > >> current handling of the nulls? >>> > >> >>> > >> >>> > >> >>> > >> >>> > >> > Thanks >>> > >> > >>> > >> > >>> > >> >>> > >> [1] >>> > >> >>> > >> >>> > >>> http://stackoverflow.com/questions/15447397/spring-aop-whats-the-difference-between-joinpoint-and-pointcut >>> > >> >>> > >> >>> > >> > On Thu, Nov 26, 2015 at 8:09 AM, Dan Haywood < >>> > >> d...@haywood-associates.co.uk >>> > >> > > >>> > >> > wrote: >>> > >> > >>> > >> > > Hi Steve, >>> > >> > > >>> > >> > > Not sure I follow quite all the ins-and-outs of this, but what >>> could >>> > >> well >>> > >> > > be of use is the optional ApplicationTenancyPathEvaluator domain >>> > >> > > service[1]. If an implementation is registered (on the >>> classpath), >>> > >> then >>> > >> > > the security module will delegate to this [2] in order to >>> determine >>> > >> who >>> > >> > > gets to see/edit what. >>> > >> > > >>> > >> > > From what I did follow, it sounds like you need to treat objects >>> > with >>> > >> a >>> > >> > > null region in a particular way? If so, then hopefully you can >>> put >>> > >> this >>> > >> > > "special case" logic in an implementation of said service. >>> > >> > > >>> > >> > > HTH >>> > >> > > Dan >>> > >> > > >>> > >> > > >>> > >> > > >>> > >> > > [1] >>> > >> > > >>> > >> > > >>> > >> > >>> > >> >>> > >>> https://github.com/isisaddons/isis-module-security/blob/master/dom/src/main/java/org/isisaddons/module/security/dom/tenancy/ApplicationTenancyPathEvaluator.java >>> > >> > > [2] >>> > >> > > >>> > >> > > >>> > >> > >>> > >> >>> > >>> https://github.com/isisaddons/isis-module-security/blob/master/dom/src/main/java/org/isisaddons/module/security/facets/TenantedAuthorizationFacetFactory.java#L72 >>> > >> > > >>> > >> > > >>> > >> > > On 25 November 2015 at 20:25, Stephen Cameron < >>> > >> > steve.cameron...@gmail.com> >>> > >> > > wrote: >>> > >> > > >>> > >> > > > Hi, >>> > >> > > > >>> > >> > > > I have a problem with Application Tenancies not working the >>> way I >>> > >> > want, I >>> > >> > > > want to drive it off a field 'region', such that a person is >>> > >> assigned a >>> > >> > > > tenancy of GLOBAL, NORTH, SOUTH, NORTH-WEST and these are >>> also the >>> > >> > > regions >>> > >> > > > that they are working in too, so when they create a record >>> their >>> > >> region >>> > >> > > > gets assigned to the new record and that controls who else >>> can see >>> > >> the >>> > >> > > > record. >>> > >> > > > >>> > >> > > > This mostly works, but there is one small glitch. The main >>> > problem I >>> > >> > have >>> > >> > > > is setting it up so that region is non-null and any records >>> > created >>> > >> by >>> > >> > a >>> > >> > > > GLOBAL tenancy user are seen by all users, while those >>> created by >>> > a >>> > >> > > NORTH, >>> > >> > > > SOUTH or NORTH-WEST user are seen only by users with the same >>> > >> tenancy. >>> > >> > By >>> > >> > > > changing the region of a record it can change tenancy. >>> > >> > > > >>> > >> > > > Presently this is broken, or at least it I think it was >>> working >>> > >> > correctly >>> > >> > > > when I allowed a record with a region of null to be the GLOBAL >>> > >> ones. I >>> > >> > > need >>> > >> > > > to have this working for a demo tomorrow, so advice is >>> welcomed on >>> > >> how >>> > >> > > best >>> > >> > > > to set this up properly. >>> > >> > > > >>> > >> > > > My base class that controls all this here: >>> > >> > > > >>> > >> > > > >>> > >> > > >>> > >> > >>> > >> >>> > >>> https://github.com/Stephen-Cameron-Data-Services/isis-chats/blob/master/dom/src/main/java/au/com/scds/chats/dom/AbstractChatsDomainEntity.java >>> > >> > > > >>> > >> > > > The other small glitch is that a person record created in the >>> > >> process >>> > >> > of >>> > >> > > > creating a participant doesn't get assigned a region >>> > automatically. >>> > >> I >>> > >> > > have >>> > >> > > > a work-around for that in place at present, anything that has >>> a >>> > null >>> > >> > > region >>> > >> > > > gets presented as having a global tenancy. >>> > >> > > > >>> > >> > > > >>> > >> > > > Thanks >>> > >> > > > >>> > >> > > > Steve Cameron >>> > >> > > > >>> > >> > > >>> > >> > >>> > >> >>> > > >>> > > >>> > >>> >> >> >