public class Transaction extends java.lang.Object implements java.io.Serializable, BOLoaderWithCacheI, BOProcHolderI
TransactionProviderI
.Modifier and Type | Class and Description |
---|---|
static class |
Transaction.Additional |
static class |
Transaction.FillBOResult |
class |
Transaction.Savepoint |
BOQueryLoaderI.InternalHelper
Modifier and Type | Field and Description |
---|---|
IndexedHashSet<BO> |
bos
The BOs which are included in the Transaction and for which modifications
are recorded; a subset of "refs".
|
java.lang.Integer |
clientSaveLock
synchronize saves of this tx in the client / GUI
|
java.lang.String |
description |
static int |
GET_ORIGNODE_DEFAULT_VALUE |
static int |
LOG_LEVEL_DEBUG |
static int |
LOG_LEVEL_DISABLE |
static int |
LOG_LEVEL_ERROR |
static int |
LOG_LEVEL_INFO |
static int |
LOG_LEVEL_WARN |
IndexedHashSet<BO> |
newbos
The BOs which were newly created in this Transaction; a subset of "bos".
|
java.util.ArrayList<BOProc> |
procs
The procedures to be executed when restoring to the server
|
static byte |
PROPERTY_SCOPE_COMMIT
A property stored with this scope is removed after commit.
|
static byte |
PROPERTY_SCOPE_PERSISTENT
A property stored with this scope is transferred to the server and available there and additionally stored as
a persistent property of the BT created from this TX.
|
static byte |
PROPERTY_SCOPE_SAVEPOINT
A property stored with this scope is present in the current Savepoint
and is removed once the Savepoint is rollback()ed.
|
static byte |
PROPERTY_SCOPE_SERVER
A property stored with this scope is transferred to the server,
so you can do some things on the server with it.
|
static byte |
PROPERTY_SCOPE_TRANSACTION
A property stored with (only) this scope is present within this transaction object
as long as the transaction lives, but not transmitted from client to server
or vice versa.
|
IndexedHashSet<BO> |
purges
The BOs which were marked for removal (purging) from the database within this transaction; a subset of "bos".
|
IndexedHashSet<BO> |
refs
BOs that are somehow associated with this Transaction, either because they
are included or are used as a parameter in a BOProc; a superset of "bos".
|
java.lang.String |
remarks |
boolean |
savePhase |
static java.lang.String |
SKIP_CLIENT_VERIFIES_FOR_ADMINS
If this property is set to Boolean.TRUE with scope
PROPERTY_SCOPE_COMMIT
or PROPERTY_SCOPE_TRANSACTION , verify on client and the before and after
variants are skipped for admins. |
static java.lang.String |
SKIP_RECALCS_FOR_DATA_REPAIR
If this property is set to Boolean.TRUE, the cancelRecalc method will return true
suppressing all recalcs, depending on the property scope, either on client side or
both client and server side.
|
static java.lang.String |
SKIP_SERVER_VERIFIES_FOR_ADMINS
If this property is set to Boolean.TRUE with scope
PROPERTY_SCOPE_SERVER ,
verify on server and the before and after variants are skipped for admins. |
Modifier and Type | Method and Description |
---|---|
void |
acquireReadLock()
Acquires the read lock for this Transaction.
|
void |
acquireWriteLock()
Acquires the write lock for this Transaction, thus synchronizing access to modifications to this Transaction.
|
void |
addFixingProc(BOProc bp)
Adds a BOProc to this Transaction that contains future local changes to fix data-inconsistencies during sync.
|
void |
addProc(BOProc bp)
Adds the given BOProc to the list of recorded changes by this transaction.
|
void |
addRemark(java.lang.String _str)
Convenience method that adds the given String to this Transactions "Remarks"
string with a newline prepended (if "Remarks" wasn't null or empty before).
|
java.lang.String |
allLocalsToString()
Returns a String containing all keys and values of the current txLocals.
|
java.lang.String |
allProcsToString()
wrapper for
#procsToString(int, int, boolean, BO, boolean, int, boolen, boolean)
that automatically collects and prints all available procs and formats the output to be grouped |
java.lang.String |
allProcsToString(boolean html) |
java.lang.String |
allProcsToString(boolean html,
BO onlyThisBO) |
java.lang.String |
allProcsToString(boolean html,
BO onlyThisBO,
boolean canonize) |
java.lang.String |
allProcsToString(boolean html,
BO onlyThisBO,
boolean canonize,
boolean limitToExplicitBO) |
java.lang.String |
allProcsToString(boolean html,
BO onlyThisBO,
boolean canonize,
boolean limitToExplicitBO,
boolean skipBackProcs) |
void |
appendDescription(java.lang.String _desc)
Appends the given String to an already existing description of this Transaction
or sets the description to the passed String, if none was set before.
|
void |
applyOtherTransactionsSaveSuccess(Transaction otx)
Iterates through the procs of the provided transaction and applies all modifications relevant to this transaction
to the cached BOs.
|
void |
assertWriteLock()
Checks whether the current thread holds a writelock upon this transaction and throws an exception if not.
|
BO |
assureBotClass(BO bo)
Assures that the actual class of the given
BO instance is consistent with (that is the same as) the class
the BOT of the instance represents. |
TransactionCanonification |
canonize(boolean modifyCurrent)
This calculates a canonification of this transaction.
|
TransactionCanonification |
canonize(boolean modifyCurrent,
int from) |
TransactionCanonification |
canonize(boolean modifyCurrent,
int from,
int till) |
void |
checkIntegrity(boolean addRemarkForUndeletedNewBOsWithoutProcs)
Checks the integrity of this transaction in regard to its recorded BOs.
|
void |
checkpoint() |
void |
close()
Closes this Transaction.
|
void |
closeAndClearLazyData()
Closes this Transaction.
|
void |
commit() |
void |
commitBLOBs() |
void |
continueWithTempIdsFrom(Transaction _tx)
Sets the start of temp ids given by this transaction to the current temp id
of the given Transaction; used to avoid overlapping of temp ids, FIXME!
|
void |
copyLocalsFrom(Transaction tx) |
void |
copyLocalsFrom(Transaction tx,
boolean excludeCurrentUser) |
void |
copyLocalsFrom(Transaction tx,
boolean excludeCurrentUser,
boolean skipExisting) |
java.util.Set |
createOrTouchAdditional(java.util.Date transactionDate,
Transaction.Additional addtx)
Memorizes
BOs that were created in addtx in the "new" list
of the PersistenceHandlerI and updates the Lmod of changed
BOs from addtx . |
java.lang.String |
currentSavepointToString()
Returns a String containing the name of the current savepoint or null if there is none.
|
Transaction |
deepClone(BOLoaderI bol,
SchemaI schema)
Creates a new Transaction from this Transaction having all BOs reloaded with the passed BOLoaderI
Also sets the passed schema as explicit schema, if it is not null, otherwise carries over the
explicit schema of this Transaction to the new one, if any.
|
Transaction |
deepClone(BOLoaderI bol,
SchemaI schema,
boolean preserveBLOBHandles) |
Transaction |
deepClone(BOLoaderI bol,
SchemaI schema,
boolean preserveBLOBHandles,
boolean preserveTxLocals) |
Transaction |
deepClone(BOLoaderI bol,
SchemaI schema,
boolean preserveBLOBHandles,
boolean preserveTxLocals,
boolean preserveCurrentUser) |
static Transaction |
deserialize(SerializedTransaction stx,
BOLoaderI bol,
SchemaI schema,
TemporaryIdSupplierI tempIdSupplier) |
void |
disableBORecalc()
Disables recalc of BO properties when calling set/add/remove
This setting bypasses all recalculation of BO properties which might be necessary to do delicate data repairs without
having the usual 'BO mechanics' in the way.
|
void |
disableClientVerification()
Disables client-side verification within this transaction for privileged users.
|
void |
disableServerVerification()
Disables server-side verification within this transaction for privileged users.
|
void |
disconnectBOs()
Deprecated.
|
void |
disconnectBOs(boolean clearLazyData) |
void |
drain()
Completely empties the current BOLoaderWithCacheI.
|
void |
dumpCache(org.apache.log4j.Logger l) |
void |
dumpProcs() |
void |
dumpProcs(java.util.ArrayList _procs) |
void |
dumpProcs(int _from,
int _to) |
void |
dumpProcs(int _from,
int _to,
java.util.List _procs) |
void |
dumpProcs(org.apache.log4j.Logger l)
Dumps the procedures in a human-readable format to the specified logger.
|
void |
dumpProcs(org.apache.log4j.Logger _log,
int _from,
int _to) |
void |
dumpProcs(org.apache.log4j.Logger _log,
int _from,
int _to,
java.util.List _procs) |
void |
dumpProcs(org.apache.log4j.Logger _log,
int _from,
int _to,
java.util.List _procs,
org.apache.log4j.Level _level) |
void |
dumpProcs(org.apache.log4j.Logger l,
org.apache.log4j.Level _level) |
void |
dumpProcs(org.apache.log4j.Logger l,
java.util.List _procs) |
void |
dumpProcs(org.apache.log4j.Logger l,
java.util.List _procs,
org.apache.log4j.Level _level) |
void |
enterSavePhase() |
Transaction.Additional |
evaluateVerifyOnServer(java.lang.Long nodeNumber,
Benutzer user)
This may generate and return new BOProcs; will be called shortly before commit if no conflicts have occurred.
|
Transaction.Additional |
evaluateVerifyOnServer(java.lang.Long nodeNumber,
Benutzer user,
java.util.Set explicitTouchedBOs) |
void |
execute(BatchedBackendRequestI[] srs) |
boolean |
exists(java.lang.Long id)
Returns true if a BO with the passed Id and class exists in the cache of this
Transaction or in the database, false if no such BO exists or the passed Id
is null or negative.
|
boolean |
exists(java.lang.Long id,
java.lang.Class<? extends BOI> classtip)
Returns true if a BO with the given id exists.
|
BO |
fillBO(BO bo,
BO copyIntoBO) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors) |
BO |
fillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors,
boolean recursiveCall) |
Transaction.Additional |
filterAdditionals(Transaction.Additional adds) |
void |
finalizeSaveProcedure(TransactionAnswer ta,
SaveBOListenerI sbl)
Calls
#replayAdditionalProcs(Collection for replaying and incorporating "relevant"
additional server-side changes (BOProcs) locally as well. |
void |
finishBLOBs() |
void |
fireAfterSave(java.lang.Long nodeNumber,
Benutzer user,
SaveException se)
Called by
DBMan after the save process finished, either successfully (se = null ) or due to an
"application level" error (se <> null ). |
void |
flagAsMassChange()
Marks this transaction as mass change.
|
void |
flagAsUserChoseToOverrideSaveVetoExceptions(java.lang.String message)
Marks this transaction as user chose to override (all) SaveVetoExceptions.
|
void |
flush()
Just like close, except that the cache remains intact and the transaction can continue.
|
void |
flushLocals() |
BO |
frapBO(BO bo)
This method assures that the given BO instance gets this Transaction set as
its BOLoader and also only references other BO instances that are in the
cache of this Transaction (are "known to it", see isKnown()) and have this
Transaction set as their BOLoader too.
|
BO |
frapBOAndHandleNonPersistentAttributes(BO bo)
Fraps the passed BO and additionally sets any set npattr values in the
BO to frap (or any BOs connected to it) which are not yet set in a
possibly cached local copy, so server-side calculated npattr values
are not lost but taken over into the BO from our cache.
|
BO |
frapFromCache(BO bo)
This method assures that the given BO instance gets this Transaction set as
its BOLoader and also only references other BO instances that are in the
cache of this Transaction (are "known to it", see isKnown()) and have this
Transaction set as their BOLoader too.
|
byte[] |
getBLOB(java.lang.Long id)
get the BLOB belonging to BO[id].
|
long |
getBLOB(java.lang.Long id,
java.io.DataOutput os)
Writes the BLOB belonging to BO[id] to the passed DataOutput.
|
long |
getBLOB(java.lang.Long id,
java.io.DataOutput os,
boolean closeOS)
Writes the BLOB belonging to BO[id] to the passed DataOutput.
|
long |
getBLOB(java.lang.Long id,
java.io.DataOutput os,
boolean closeOS,
java.lang.Long backuppingBPId)
Writes the BLOB belonging to BO[id] to the passed DataOutput.
|
byte[] |
getBLOB(java.lang.Long id,
java.lang.Long backuppingBPId)
get the BLOB belonging to BO[id].
|
long |
getBLOB(java.lang.Long id,
java.io.OutputStream os)
Writes the BLOB belonging to BO[id] to the passed OutputStream.
|
long |
getBLOB(java.lang.Long id,
java.io.OutputStream os,
boolean closeOS)
Writes the BLOB belonging to BO[id] to the passed OutputStream.
|
long |
getBLOB(java.lang.Long id,
java.io.OutputStream os,
boolean closeOS,
java.lang.Long backuppingBPId)
Writes the BLOB belonging to BO[id] to the passed OutputStream.
|
VFile |
getBLOBInfo(java.lang.Long id)
gathers information about the BLOB belonging to BO[i].
|
VFile |
getBLOBInfo(java.lang.Long id,
java.lang.Long backuppingBPId)
gathers information about the BLOB belonging to BO[i].
|
java.util.List<BOProc> |
getBLOBProcs()
Checks the existing
BOProc s of THIS if they are relevant to BLOB changes and if so put them
in a List |
java.util.List<BOProc> |
getBLOBProcs(BO bo) |
java.lang.Long[] |
getBLOBProcsBOIds()
Returns the Ids of all BOs that get their BLOB changed within this Transaction.
|
java.lang.Long[] |
getBLOBProcsBOIds(boolean skipNewBOs) |
BO |
getBO(BO bo)
Returns the passed Business Object (BO) in the context of this Transaction, if it is
involved in the Transaction, otherwise it is returned as is.
|
BO |
getBO(java.lang.Long id)
Returns the Business Object (BO) with the passed Id and class in the context of this Transaction.
|
BO |
getBO(java.lang.Long id,
java.lang.Class<? extends BOI> classtip)
Returns the BO with the given id.
|
BO |
getBO(java.lang.Long id,
java.lang.Class<? extends BOI> classtip,
boolean noFetch) |
BO |
getBOByAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.Object s)
FIXME:
nullIfNotFound: default 0, will signal Exception
ignoreNotUnique: default 0
onlyKnown: default 0
|
BO |
getBOByAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.Object s,
boolean nullIfNotFound) |
BO |
getBOByAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.Object s,
boolean nullIfNotFound,
boolean ignoreNotUnique) |
BO |
getBOByAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.Object s,
boolean nullIfNotFound,
boolean ignoreNotUnique,
boolean onlyKnown) |
BO |
getBOByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] s)
Calls getBOsByAttrs and does a uniqueness check by default.
|
BO |
getBOByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] s,
boolean nullIfNotFound) |
BO |
getBOByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] s,
boolean nullIfNotFound,
boolean ignoreNotUnique) |
BO |
getBOByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] s,
boolean nullIfNotFound,
boolean ignoreNotUnique,
boolean onlyKnown) |
BO |
getBOByStringAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.String s)
Deprecated.
|
BO |
getBOByStringAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.String s,
boolean nullIfNotFound) |
BO |
getBOByStringAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.String s,
boolean nullIfNotFound,
boolean ignoreNotUnique) |
BO |
getBOByStringAttr(java.lang.Class<? extends BOI> clazz,
java.lang.String attributeName,
java.lang.String s,
boolean nullIfNotFound,
boolean ignoreNotUnique,
boolean onlyKnown) |
BO |
getBOByStringAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.String[] s)
Deprecated.
|
BO |
getBOByStringAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.String[] s,
boolean nullIfNotFound) |
BO |
getBOByStringAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.String[] s,
boolean nullIfNotFound,
boolean ignoreNotUnique) |
BO |
getBOByStringAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.String[] s,
boolean nullIfNotFound,
boolean ignoreNotUnique,
boolean onlyKnown) |
BOLoaderI |
getBOLoader() |
BO[] |
getBOs()
Deprecated.
@see #getIncludedBOs
|
java.util.TreeMap<java.lang.Long,BO> |
getBOs(java.lang.Class<? extends BOI> _classTip)
Method to retrieve all the included BOs with a specific class.
|
BO[] |
getBOs(long[] ids)
Wrapper method for the method getBOs( Object, Class ),
such that we can call getBOs direct with an of array of Ids of the primitive type 'long'.
|
BO[] |
getBOs(java.lang.Long[] ids)
Wrapper method for the method getBOs( Object, Class ),
such that we can call getBOs direct with an array of Ids of type Long.
|
BO[] |
getBOs(long[] ids,
java.lang.Class<? extends BOI> classtip)
returns the BOs with the given ids.
|
BO[] |
getBOs(java.lang.Long[] ids,
java.lang.Class<? extends BOI> classtip)
returns the BOs with the given ids.
|
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values)
Retrieves Business Objects (BOs) by the specified attributes within this transaction and persistent storage.
|
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean onlyKnown) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean[] notValue) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean[] notValue,
int limit) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean[] notValue,
int limit,
java.util.Set<java.lang.Long> excludeBOIds) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean onlyKnown,
int limit) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean onlyKnown,
int limit,
boolean[] nots) |
java.util.List |
getBOsByAttrs(java.lang.Class<? extends BOI> clazz,
java.lang.String[] attributeNames,
java.lang.Object[] values,
boolean onlyKnown,
int limit,
boolean[] nots,
java.util.Set<java.lang.Long> excludeBOIds) |
BOT |
getBOT(java.lang.Class<? extends BOI> clazz) |
BO |
getBOUncached(BO _bo)
Retrieves a Business Object (BO) without using the cache.
|
BO |
getBOUncached(java.lang.Long id) |
BO |
getBOUncached(java.lang.Long id,
java.lang.Class<? extends BOI> classtip)
Loads and returns the BO with this Id with a non caching BOLoader.
|
BT |
getBT() |
java.lang.Long |
getBTId() |
java.util.List<BOProc> |
getCanonizedProcs()
Returns a list representing the procs after a
TransactionCanonification of this Transaction. |
java.util.List<BOProc> |
getCanonizedProcs(BO bo)
Filters the canonized BOProc-s of this Transaction to the ones affecting the passed BO and possibly the provided attribute.
|
java.util.List<BOProc> |
getCanonizedProcs(BO bo,
java.util.Set<java.lang.String> attrs)
Filters the canonized BOProc-s of this Transaction to the ones affecting the passed BO and the provided attributes.
|
java.util.List<BOProc> |
getCanonizedProcs(BO bo,
java.lang.String attributeName) |
java.lang.Long |
getClientSideId(BO bo)
Returns the client-side Id for the specified business object (BO).
|
CryptoHandlerI |
getCryptoHandler()
get a reference to the CryptoHandler used.
|
Benutzer |
getCurrentUser()
Returns the current user that controls this Transaction.
|
int |
getDeletedBOCount()
Returns the number of Business Objects (BOs) that are effectively marked as (soft) deleted within this transaction,
taking into account any subsequent (soft) undeletions of a BO.
|
int |
getDeletedBOCount(int offset)
Returns the number of Business Objects (BOs) that are effectively marked as (soft) deleted within this transaction,
taking into account any subsequent (soft) undeletions of a BO.
|
java.lang.Long[] |
getDeletedBOIds() |
java.lang.Long[] |
getDeletedBOIds(java.lang.Class<? extends BOI> _onlyForClass) |
java.lang.Long[] |
getDeletedBOIds(java.lang.Class<? extends BOI> _onlyForClass,
boolean _newBOs) |
java.util.List<java.util.Map> |
getDepMaps(BO bo) |
java.lang.String |
getDescription()
Returns the currently set description of this Transaction.
|
TransactionDumper |
getDumper() |
DBManEventProviderI |
getEventProvider()
Returns the DBManEventProviderI of this BOLoader, if any.
|
FeatureManagerI |
getFeatureManager() |
FileVaultI |
getFileVault() |
static byte |
getFinalScope(byte scope)
Returns the passed scope in the version that marks the value as unmodifiable.
|
static java.lang.String |
getHumanReadablePropertyScope(byte scope)
Returns a human readable String describing the passed Transaction property scope.
|
int |
getIncludedBOCount() |
java.lang.Long[] |
getIncludedBOIds() |
java.lang.Long[] |
getIncludedBOIds(java.lang.Class<? extends BOI> _onlyForClass) |
java.lang.Long[] |
getIncludedBOIds(java.lang.Class<? extends BOI> _onlyForClass,
boolean _newBOs) |
BO[] |
getIncludedBOs() |
BO[] |
getIncludedBOsFiltered()
Returns an array with all included BOs, but only of the passed class or subclasses of that.
|
BO[] |
getIncludedBOsFiltered(java.lang.Class<? extends BOI> onlyForClass) |
BO[] |
getIncludedBOsFiltered(java.lang.Class<? extends BOI> onlyForClass,
boolean alsoNewBOs) |
static Transaction |
getInstance(BOLoaderI _loader) |
static Transaction |
getInstance(BOLoaderI _loader,
SchemaI _schema) |
static Transaction |
getInstance(BOLoaderI _loader,
SchemaI _schema,
java.lang.String _desc) |
static Transaction |
getInstance(BOLoaderI _loader,
SchemaI _schema,
java.lang.String _desc,
TemporaryIdSupplierI _temporaryIdSupplier) |
static Transaction |
getInstance(BOLoaderI _loader,
java.lang.String _desc) |
static Transaction |
getInstance(BOLoaderI _loader,
java.lang.String _desc,
TemporaryIdSupplierI _temporaryIdSupplier) |
java.util.Collection<BO> |
getKnown(java.lang.Class<? extends BOI> clazz) |
BO |
getKnown(java.lang.Long id)
Returns the cached BO with this id.
|
java.util.Map<java.lang.Long,BO> |
getKnownBOs()
Returns an unmodifiable map with all known BOs.
|
java.util.Map<java.lang.Long,BO> |
getKnownBOs(java.lang.Class<? extends BOI> clazz) |
java.util.Map<java.lang.Long,BO> |
getKnownBOs(java.lang.Class<? extends BOI> clazz,
int limit) |
Transaction.Savepoint |
getLatestSavepoint(java.lang.Object owner)
Get the latest valid (read:youngest) savepoint filed under the given owner
|
long |
getLocalLastModifiedBOs() |
int |
getLogLevel() |
java.lang.String |
getLogPrefixForProgress() |
TransactionMessageBusI |
getMessageBus() |
java.lang.String |
getMiniDesc(BO bo) |
int |
getNewBOCount()
Returns the number of new BOs created within this Transaction.
|
BO[] |
getNewBOs() |
java.lang.Object |
getNewValue(BO bo,
java.lang.String attributeName)
Calculated the new value of the attribute att of the given BO bo.
|
java.lang.Long |
getNextId()
get a unique Long id from the backend.
|
java.lang.Object |
getOldValue(BO bo,
java.lang.String attributeName)
Calculated the old value of the attribute att of the given BO bo.
|
java.lang.Long |
getOrigBTId() |
java.lang.RuntimeException |
getOrigin() |
java.lang.Long |
getOrigNode() |
long |
getOrigNodeNN() |
java.util.Date |
getOrigTime() |
java.lang.Long |
getOrigUser() |
BOLoaderI |
getParentLoader()
returns the BOLoader which this BOLoader uses to load its objects.
|
PersistenceHandlerI |
getPersistenceHandlerInSavePhase() |
java.lang.Boolean |
getPersistentBooleanProperty(EntityI namespaceEntity,
java.lang.String name) |
java.math.BigDecimal |
getPersistentDecimalProperty(EntityI namespaceEntity,
java.lang.String name) |
java.lang.Long |
getPersistentLongProperty(EntityI namespaceEntity,
java.lang.String name) |
static java.lang.String |
getPersistentPropertyKey(EntityI namespaceEntity,
java.lang.String name) |
java.lang.String |
getPersistentStringProperty(EntityI namespaceEntity,
java.lang.String name) |
int |
getProcCount()
Gets the number of changes recorded in this transaction.
|
BOProc[] |
getProcs() |
java.util.List<BOProc> |
getProcs(BO bo)
Gets all recorded Procs for a bo and the provided attribute.
|
java.util.List<BOProc> |
getProcs(BO bo,
java.lang.String attributeName) |
java.lang.Object |
getProperty(java.lang.String name)
Returns object represented by name or null, if no property with the passed name is found.
|
TransactionProviderI |
getProvider() |
int |
getPurgedBOCount()
Returns the number of Business Objects (BOs) purged from the database within this transaction.
|
int |
getPurgedBOCount(int offset) |
BO[] |
getRelationBOs(java.lang.Long id,
java.lang.Class<? extends BOI> classtip,
java.lang.String attName)
this method is used by the lazy loading map/list implementation to load related
objects when needed.
|
java.lang.String |
getRemarks()
Returns a String containing all remarks that were set for this transaction.
|
BOLoaderI |
getRootLoader()
Returns the root BOLoader of this BOLoader or this if there is no more parent loader.
|
javax.swing.JRootPane |
getRootPaneToLockOnConnectionInterrupt() |
Transaction.Savepoint[] |
getSavepoints(java.lang.Object owner)
Get all valid savepoints filed under the given owner in a list, the latest snapshot at index 0.
|
java.lang.Integer |
getSavesCount() |
int |
getSavesCountNN() |
SchemaI |
getSchema()
Implements BOLoaderI#getSchema() by returning the schema of this transaction's BOLoaderI
getBOLoader() |
java.lang.String |
getSummary()
Prints a summary of this transaction (procs in a summarized, simplified form), e.g.
|
TemporaryIdSupplierI |
getTemporaryIdSupplier() |
boolean |
hasBLOB(java.lang.Long id) |
boolean |
hasBLOB(java.lang.Long id,
java.lang.Long backuppingBPId) |
boolean |
hasBLOBProcs() |
boolean |
hasNewBOs()
Checks if new BOs have been created with this transaction.
|
boolean |
hasPersistentProperty(EntityI namespaceEntity,
java.lang.String name) |
boolean |
hasProcs()
Checks if this holder has recorded any changes (procedures).
|
boolean |
hasProperty(java.lang.String key)
Returns true if a transaction property with the passed key exists.
|
boolean |
hasPurges()
Checks if BOs were marked for removal (purging) from the database within this transaction.
|
boolean |
hasSavepoint(java.lang.String name,
java.lang.Object owner)
Returns true if there is an active savepoint with the given name and owner.
|
boolean |
hasSavepoints() |
java.util.BitSet |
haveBLOB(long[] ids) |
BO |
include(BO bo) |
BO |
include(BO bo,
boolean forceNew) |
BO |
includeCopy(BO bo)
Copies attribute values and references from the given BO to a new BO.
|
BO |
includeCopy(BO bo,
java.util.Set<java.lang.String> skipAtts) |
BO |
includeCopy(BO bo,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations) |
BO |
includeCopy(BO bo,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate) |
BO |
includeCopy(BO bo,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate,
java.util.Map<java.lang.Long,BO> alreadyCreated) |
BO |
includeCopy(BO bo,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors) |
BO |
includeCopy(BO bo,
java.lang.String[] skipAtts)
Method to copy the attribute values from the given BO of the given Entity.
|
BO |
includeCopy(BO bo,
java.lang.String[] skipAtts,
boolean ignoreManyRelations) |
BO |
includeCopy(BO bo,
java.lang.String[] skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate) |
BO |
includeCopy(BO bo,
java.lang.String[] skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate,
java.util.Map<java.lang.Long,BO> alreadyCreated) |
BO |
includeCopy(BO bo,
java.lang.String[] skipAtts,
boolean ignoreManyRelations,
EntityI subentityToCreate,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors) |
void |
incorporateDiffOfConflictingBO(BO localBO,
BO conflictingBO,
SchemaI schema)
Incorporates into this Transactions the diff between the first passed (old) BO
and the second passed (new and conflicting) BO, i.e. all necessary changes that
are needed to transform
changedBO into conflictingBO . |
void |
increaseSavesCount() |
void |
initProcCache()
creates cache(s) for BOProcs for faster analysis
|
void |
initRemarks(java.lang.String _str)
Initializes the remarks to the given String.
|
boolean |
isActive()
Returns true if any proc(edure)s / changes were recorded in this transaction.
|
boolean |
isAlwaysReloadOnFrap() |
boolean |
isAnyAttributeChangedExcept(BO bo,
java.util.Set<java.lang.String> excludeNames)
Checks if any attribute for a BO has been changed except a list of allowed ones.
|
boolean |
isAnyAttributeChangedExcept(BO bo,
java.util.Set<java.lang.String> excludeNames,
boolean evenIfValueUnchanged) |
boolean |
isAnyAttributeChangedExcept(BO bo,
java.util.Set<java.lang.String> excludeNames,
boolean evenIfValueUnchanged,
boolean ignoreBooleanTriState) |
boolean |
isAnyAttributeChangedExcept(BO bo,
java.lang.String[] excludeNames) |
boolean |
isAnyAttributeChangedExcept(BO bo,
java.lang.String[] excludeNames,
boolean evenIfValueUnchanged) |
boolean |
isAnyAttributeChangedExcept(BO bo,
java.lang.String[] excludeNames,
boolean evenIfValueUnchanged,
boolean ignoreBooleanTriState) |
boolean |
isAttributeChanged(BO bo,
java.lang.String attributeName)
Returns true if the given attribute of the given BO was changed in this transaction
|
boolean |
isAttributeChanged(BO bo,
java.lang.String attributeName,
boolean evenIfValueUnchanged) |
boolean |
isAttributeChanged(BO bo,
java.lang.String attributeName,
boolean evenIfValueUnchanged,
boolean ignoreBooleanTriState) |
boolean |
isAttributeInitialized(BO bo,
java.lang.String attributeName)
Returns true if the given attribute of the given BO was changed from null to a non-null value in this transaction.
|
boolean |
isAttributeNulled(BO bo,
java.lang.String attributeName)
Returns true if the given attribute of the given BO was changed from a non-null value to null in this transaction.
|
boolean |
isBOOrAnyToOneReachableBOInvolved(BO bo)
Returns true/1 if the given BO or any via n-1 relations connected BO
is involved in this transaction (means the passed or any such
related BO has changed or it has been newly created).
|
boolean |
isBORecalcsDisabled()
Checks if the recalc of BO properties is disabled within this transaction and the current user may do so.
|
boolean |
isCaching()
If true, then this BOLoaderI uses an internal cache, holding all BOs hat were loaded or frapped into it.
|
boolean |
isClientVerificationDisabled()
Checks if client-side verification is disabled for this transaction and the current user has the privilege to bypass it.
|
boolean |
isClosed() |
boolean |
isClosing() |
boolean |
isCreated(BO bo)
Returns true/1 if the given BO was created in this transaction
|
boolean |
isDeletedOrNotInvolved(BO bo)
Returns true/1 if the given BO is not involved in this transaction or marked for deletion or is already deleted
|
boolean |
isDiffingMode() |
boolean |
isExplicitActive() |
boolean |
isForORMScript()
Returns true if this Transaction was marked as being used in the context of
an ORM update script.
|
boolean |
isIgnoreBotCoherency() |
boolean |
isIncluded(BO bo)
Returns true/1 if the given BO is included in this transaction
|
boolean |
isInhibitDefaults() |
boolean |
isInitEnvironmentMode() |
boolean |
isInOTRMode() |
boolean |
isInstance(Transaction otx)
Returns true if the passed Transaction is the same instance as this Transaction.
|
boolean |
isInvolved(BO bo)
Returns true/1 if the given BO is involved in this transaction
(means the BO has changed or it has been newly created).
|
boolean |
isKnown(BO bo)
Checks if a BO already exists within this transaction.
|
boolean |
isKnown(java.lang.Long id)
Checks if the transaction cache contains the provided id
|
boolean |
isLocked() |
java.lang.Boolean |
isLoggedIn(Benutzer _ben)
Tells if the given Benutzer is currently logged in.
|
boolean |
isLoggedInNN(Benutzer _ben)
Tells if the given Benutzer is currently logged in.
|
boolean |
isMassChange()
Returns true if this Transaction was marked as mass change.
|
boolean |
isNotPersistentParm(java.lang.Object o,
java.lang.String attrName,
java.lang.String attrUsage)
Checks if parameter o is a temporary BO that found its way into a transaction.
|
boolean |
isOnAuthoritativeSyncServer()
Tells if this transaction is handled on the authoritative sync server.
|
boolean |
isOneOfAttributesChanged(BO bo,
java.lang.String[] attributeNames)
Returns true if at least one of the given attributes of the given BO were changed in this transaction
|
boolean |
isOneOfAttributesChanged(BO bo,
java.lang.String[] attributeNames,
boolean evenIfValueUnchanged) |
boolean |
isOneOfAttributesChanged(BO bo,
java.lang.String[] attributeNames,
boolean evenIfValueUnchanged,
boolean ignoreBooleanTriState) |
static boolean |
isPropertyFinal(byte scope)
Returns true if the passed property scope qualifies the property as
PROPERTY_IS_FINAL . |
boolean |
isPurged(BO bo) |
boolean |
isRecording()
Returns true if this BOLoaderI records changes.
|
boolean |
isRecordNonPersistent() |
boolean |
isRepairMode() |
static boolean |
isScopeCommit(byte scope)
Returns true if the passed property scope represents
PROPERTY_SCOPE_COMMIT . |
static boolean |
isScopePersistent(byte scope)
Returns true if the passed property scope represents
PROPERTY_SCOPE_PERSISTENT . |
static boolean |
isScopeSavepoint(byte scope)
Returns true if the passed property scope represents
PROPERTY_SCOPE_SAVEPOINT . |
static boolean |
isScopeServer(byte scope)
Returns true if the passed property scope represents
PROPERTY_SCOPE_SERVER . |
static boolean |
isScopeTransaction(byte scope)
Returns true if the passed property scope represents
PROPERTY_SCOPE_TRANSACTION . |
static boolean |
isScopeValid(byte scope)
Checks if the passed property scope is valid and signals an IllegalArgumentException if not.
|
boolean |
isServerVerificationDisabled()
Checks if server-side verification is disabled for this transaction and the current user has the privilege to bypass it.
|
boolean |
isSkipClientVerifiesForAdmins()
Deprecated.
Use
isClientVerificationDisabled() instead. |
boolean |
isSkipServerVerifiesForAdmins()
Deprecated.
Use
isServerVerificationDisabled() instead. |
boolean |
isSyncMode()
Represents a savepoint within a transaction, enabling selective rollback of changes.
|
boolean |
isUnderAdminControl()
Determines if this transaction is executed by an administrator user.
|
boolean |
isUnderBackendControl()
Determines if this transaction is executed by the backend.
|
boolean |
isUnderServiceControl()
Determines if this transaction is executed by a service user.
|
boolean |
isUnderSystemUserControl()
Determines if this transaction is executed by a system user.
|
boolean |
isUndo()
Returns true if this Transaction was created in the context of an "undo" of a BT via BT#undo(TransactionProviderI, BOLoaderI).
|
boolean |
isUndoWithoutTimeTravel()
Returns true if this Transaction was created in the context of an "undo" of a BT via BT#undo(TransactionProviderI, BOLoaderI)
and a "time-travel" did not happen.
|
boolean |
isUndoWithTimeTravel()
Returns true if this Transaction was created in the context of an "undo" of a BT via BT#undo(TransactionProviderI, BOLoaderI)
and a "time-travel" did actually happen.
|
boolean |
isUserChoseToOverrideSaveVetoExceptions()
Returns true if this Transaction was marked as user chose to override (all) SaveVetoExceptions.
|
static void |
killNewProcsRunner()
This should only be called if a classloader is disposed of and we need to stop this class's NewProcsRunner!
|
void |
logDebug(java.lang.String _logmessage)
Adds the message to the remarks if the specified loglevel is equal/above Debug
|
void |
logError(java.lang.String _logmessage)
Adds the message to the remarks if the specified loglevel is equal/above Error
|
void |
logInfo(java.lang.String _logmessage)
Adds the message to the remarks if the specified loglevel is equal/above Info
|
void |
logWarn(java.lang.String _logmessage)
Adds the message to the remarks if the specified loglevel is equal/above Warn
|
void |
markForORMScript()
Marks this Transaction as being used in the context of an ORM update script,
so some checks may react upon that and be less strict.
|
void |
markForSkipClientVerifiesForAdmins()
Deprecated.
Use
disableClientVerification() instead. |
void |
markForSkipServerVerifiesForAdmins()
Deprecated.
Use
disableServerVerification() instead. |
void |
mergeIn(Transaction otherTx)
Merges in another Transaction into this Transaction under certain circumstances
and invalidates the merged in Transaction after that.
|
void |
mergeIn(Transaction otherTx,
boolean appendOtherDescriptions) |
void |
mergeIn(Transaction otherTx,
boolean appendOtherDescriptions,
boolean addOtherRemarks) |
java.lang.String |
newBOsToString()
Converts the new BOs to a human-readable string representation.
|
java.lang.String |
newBOsToString(boolean html)
Converts the new BOs to a human-readable string representation.
|
java.lang.String |
newBOsToString(boolean html,
int offset)
Converts the new BOs to a human-readable string representation.
|
void |
playReverse() |
void |
precommitBLOBs() |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors) |
Transaction.FillBOResult |
prepareFillBO(BO bo,
BO copyIntoBO,
java.util.Set<java.lang.String> skipAtts,
boolean ignoreManyRelations,
EntityI ent,
java.util.Map<java.lang.Long,BO> alreadyCreated,
boolean ignoreErrors,
boolean recursiveCall) |
BatchedBackendRequestI |
prepareQuery(java.lang.String s) |
BatchedBackendRequestI |
prepareQuery(java.lang.String s,
java.lang.Object[] o) |
void |
prependBTs(BT[] bts)
Applies changes from the provided BTs to make them appear to happen before any direct change of this transaction.
|
java.lang.String |
procsToString()
Converts the procedures of this transaction to a human-readable string representation.
|
java.lang.String |
procsToString(boolean html)
Converts the procedures to a human-readable string representation.
|
java.lang.String |
procsToString(boolean html,
BO onlyThisBO)
Converts the procedures affecting a specific BO to a human-readable string representation.
|
java.lang.String |
procsToString(boolean html,
BO onlyThisBO,
boolean canonize) |
java.lang.String |
procsToString(boolean html,
BO onlyThisBO,
boolean canonize,
boolean limitToExplicitBO) |
java.lang.String |
procsToString(boolean html,
BO onlyThisBO,
boolean canonize,
boolean limitToExplicitBO,
int maxProcs) |
java.lang.String |
procsToString(boolean html,
BO onlyThisBO,
boolean canonize,
boolean limitToExplicitBO,
int maxProcs,
boolean skipBackProcs) |
java.lang.String |
procsToString(boolean html,
boolean skipBackProcs,
BO onlyThisBO)
Converts the procedures affecting a specific BO to a human-readable string representation.
|
java.lang.String |
procsToString(int from,
int till)
Converts the procedures of this transaction to a human-readable string representation.
|
java.lang.String |
procsToString(int from,
int till,
boolean html) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO,
boolean limitToExplicitBO) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO,
boolean limitToExplicitBO,
int maxProcs) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO,
boolean limitToExplicitBO,
int maxProcs,
boolean grouped) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO,
boolean limitToExplicitBO,
int maxProcs,
boolean grouped,
boolean canonize) |
java.lang.String |
procsToString(int from,
int till,
boolean html,
BO onlyThisBO,
boolean limitToExplicitBO,
int maxProcs,
boolean grouped,
boolean canonize,
boolean skipBackProcs) |
de.ipcon.db.core.QueryResultsI |
query(BOQuery _eq)
query objects in an iterative way to hide backend processing time.
|
de.ipcon.db.core.QueryResultsI |
query(java.lang.String t)
wrapper for query(t, Object[0])
|
de.ipcon.db.core.QueryResultsI |
query(java.lang.String t,
java.lang.Object[] pvals)
query objects in an iterative way to hide backend processing time.
|
java.util.List |
queryBO(BOQuery _eq)
query objects and block until all objects are transferred, returns Objects as a List.
|
java.util.List |
queryBO(BOQuery _eq,
boolean includeKnownBOs) |
java.util.List |
queryBO(java.lang.String query)
wrapper for queryBO(String, Object[0])
|
java.util.List |
queryBO(java.lang.String query,
java.lang.Object[] pvals)
query objects and block until all objects are transferred, returns Objects as a List.
|
java.util.List |
queryBO(java.lang.String query,
java.lang.Object[] pvals,
boolean includeKnownBOs) |
de.ipcon.db.core.QueryResultsI |
queryRelation(long id,
java.lang.Class<? extends BOI> classtip,
java.lang.String attributeName)
does the same as @see #getRelationBOs, but returns a QueryResultsI like @see #query.
|
BO |
readBOInstance(SecureObjectInputI s) |
void |
readInstance(SecureObjectInputI s,
boolean stubClone) |
void |
readInstance(SecureObjectInputI s,
boolean stubClone,
boolean checkIntegrity) |
void |
readInstance(SecureObjectInputI s,
boolean stubClone,
boolean checkIntegrity,
boolean forDeepClone) |
BOProc |
readProcInstance(SecureObjectInputI s,
java.util.ArrayList<BO> boList,
boolean stubClone,
boolean forDeepClone) |
boolean |
recalcOfBOsShouldBeCanceled()
Returns true if this Transaction is in OTR mode, is in sync mode or is locked
and thus any recalcs in BOs loaded by this Transaction should be canceled.
|
void |
recordAdd(BO bo,
java.lang.String attributeName,
java.lang.Class ptyp,
java.lang.Object parm)
Records the addition of a related object to a Business Object (BO) within this transaction.
|
void |
recordAdd(BO bo,
java.lang.String attributeName,
java.lang.Class ptyp,
java.lang.Object parm,
BO oldParm) |
void |
recordPurge(BO bo)
Records a purge operation for the specified BO (Business Object) in this transaction.
|
void |
recordRemove(BO bo,
java.lang.String attributeName,
java.lang.Class ptyp,
java.lang.Object parm)
Records the removal of a related object from a Business Object (BO) within this transaction.
|
void |
recordSet(BO bo,
java.lang.String attributeName,
java.lang.Class ptyp,
java.lang.Object old,
java.lang.Object $new)
Records the modification of an attribute's value in a Business Object (BO) within this transaction.
|
BO |
refBO(BO bo) |
BO |
refBO(BO bo,
java.lang.String _whatMsg) |
BO |
refBO(BO bo,
java.lang.String _whatMsg,
BO debugBO) |
BO |
refBO(BO bo,
java.lang.String _whatMsg,
BO debugBO,
java.lang.String debugAttr) |
BO |
refBO(BO bo,
java.lang.String _whatMsg,
BO debugBO,
java.lang.String debugAttr,
BOProc debugProc) |
java.lang.Object |
refParm(java.lang.Object o) |
java.lang.Object |
refParm(java.lang.Object o,
java.lang.String what) |
java.lang.Object |
refParm(java.lang.Object o,
java.lang.String what,
BO debugBO) |
java.lang.Object |
refParm(java.lang.Object o,
java.lang.String what,
BO debugBO,
java.lang.String debugAttr) |
java.lang.Object |
refParm(java.lang.Object o,
java.lang.String what,
BO debugBO,
java.lang.String debugAttr,
BOProc debugProc) |
void |
reFrapAfterSave(TransactionConflictReport report,
boolean stubs)
Does maintenance to keep the internal object references in this Transaction
intact after saving.
|
void |
rehashCache() |
void |
releaseReadLock()
Releases the read lock for this Transaction again.
|
void |
releaseWriteLock()
Releases the write lock for this Transaction again, thus allowing modifications by another thread.
|
ManagedFileI |
removeBLOB(BO bo) |
void |
replay()
Replays the
BOProcs of this Transaction , applying the
recorded changes again. |
void |
replay(Transaction conflictingTX) |
void |
replayInStoreFinish(TransactionConflictReport report,
boolean isChangeByBenutzer) |
void |
replayInStoreLog(TransactionConflictReport report,
Benutzer user) |
TransactionConflictReport |
replayInStorePrepare(SchemaI schema,
Benutzer user)
Prepares this transaction for storage by reloading all associated objects through the persistence handler.
|
void |
replayInStoreWithoutLog(TransactionConflictReport report,
Benutzer user) |
void |
resetReversedMode()
internal use only
|
void |
restoreBLOBHandlesFrom(Transaction tx) |
void |
rollback() |
void |
rollbackBLOBs() |
boolean |
rollbackLatestSavepoint(java.lang.Object owner)
Roll back to the latest valid (read:youngest) savepoint filed under the given owner,
if there is one, and return true.
|
Transaction.Savepoint |
savepoint(java.lang.String name)
Creates and returns a savepoint with the given name in this transaction.
|
Transaction.Savepoint |
savepoint(java.lang.String name,
java.lang.Object owner)
Creates and returns a savepoint with the given name and owner in this transaction
|
boolean |
savepointBelongsHere(Transaction.Savepoint _sp)
Tells if the given Savepoint belongs to this Transaction.
|
SerializedTransaction |
serialize() |
void |
serverLocalTransactionStoreFinish(java.util.Date serverLocalTransactionDate,
boolean isChangeByBenutzer,
PersistenceHandlerI ph) |
TransactionConflictReport |
serverLocalTransactionStorePrepare(SchemaI schema)
Prepares this server-local transaction for storage, optimizing for the scenario where objects are already loaded server-side.
|
void |
setAlwaysReloadOnFrap(boolean $351) |
void |
setBOLoader(BOLoaderI l) |
void |
setBTId(java.lang.Long $347) |
void |
setCurrentUser(Benutzer ben)
Sets the current user that controls this Transaction.
|
void |
setDescription(java.lang.String _desc)
Sets the description (something like a commit message) of this Transaction.
|
void |
setDiffingMode(boolean $340) |
void |
setExplicitActive(boolean $353) |
void |
setIgnoreBotCoherency(boolean $349) |
void |
setInhibitDefaults(boolean $354) |
void |
setInitEnvironmentMode(boolean $341) |
void |
setLocalLastModifiedBOs(long $346) |
void |
setLogLevel(int $348) |
void |
setOrigBTId(java.lang.Long $343) |
void |
setOrigin(java.lang.RuntimeException $355) |
void |
setOrigNode(java.lang.Long $342) |
void |
setOrigTime(java.util.Date $345) |
void |
setOrigUser(java.lang.Long $344) |
void |
setPersistentBooleanProperty(EntityI namespaceEntity,
java.lang.String name,
java.lang.Boolean value) |
void |
setPersistentDecimalProperty(EntityI namespaceEntity,
java.lang.String name,
java.math.BigDecimal value) |
void |
setPersistentLongProperty(EntityI namespaceEntity,
java.lang.String name,
java.lang.Long value) |
void |
setPersistentStringProperty(EntityI namespaceEntity,
java.lang.String name,
java.lang.String value) |
void |
setProperty(java.lang.String name,
java.lang.Object value,
byte scope)
sets property value in current transaction context to specified value with the specified scope.
|
void |
setProperty(java.lang.String name,
java.lang.Object value,
byte scope,
boolean isFinal) |
void |
setProvider(TransactionProviderI $352) |
void |
setRecordNonPersistent(boolean $350) |
void |
setRepairMode(boolean $339) |
void |
setRootPaneToLockOnConnectionInterrupt(javax.swing.JRootPane $357) |
void |
setSavesCount(java.lang.Integer $356) |
void |
setSyncMode(boolean $338) |
void |
setTemporaryIdSupplier(TemporaryIdSupplierI _temporaryIdSupplier) |
long |
simulateSave() |
long |
simulateSave(boolean doVerify)
Use ONLY in test environments.
|
long |
simulateSave(long sid) |
long |
simulateSave(long sid,
boolean doVerify) |
ManagedFileI |
storeBLOB(BO bo,
java.io.InputStream is)
Reads binary data from an InputStream and stores it as BLOB of the passed BO.
|
Transaction |
stubClone(BOLoaderI bol) |
Transaction |
stubClone(BOLoaderI bol,
boolean doCanonize) |
java.lang.Long |
testAuth(Anmeldung a)
Tests wether given credentials can be verified.
|
boolean |
testAuth(de.ipcon.db.core.PasswortUeberpruefung a)
Tests wether given credentials can be verified.
|
java.lang.String |
toString() |
java.lang.String |
toString(boolean _showRuntimeInfo) |
boolean |
tryAcquireReadLock() |
void |
upgradeLocks() |
boolean |
wasBLOBChanged(BO bo)
Returns true/1 if the given BO had a BLOB-change in this transaction
|
boolean |
wasBLOBCreated(BO bo)
Returns true/1 if the given BO had a BLOB-creation in this transaction
|
boolean |
wasBLOBDeleted(BO bo)
Returns true/1 if the given BO had a BLOB-deletion in this transaction
|
boolean |
wasDeleted(BO bo)
Returns true/1 if the given BO was marked for deletion in this transaction
|
boolean |
weHaveReadLock() |
void |
writeBOInstance(SecureObjectOutputI s,
BO bo) |
void |
writeInstanceToServer(SecureObjectOutputI s,
java.lang.Thread savingThread) |
void |
writeInstanceWithoutBLOBTransfer(SecureObjectOutputI s) |
void |
writeProcInstance(SecureObjectOutputI s,
java.util.HashMap<BO,java.lang.Integer> indexMap,
BOProc proc,
boolean stubClone,
boolean forDeepClone) |
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait
frapBOArrayFromCache, frapBOIArrayFromCache, frapBOsFromCache, frapFromCache, isAncestorOf, isRootLoader, isServerSide, isTesting, prepareQuery
haveBLOB, haveBLOB
getOneBOByAttr, getUniqueBOByAttr
procsToString
public static final int LOG_LEVEL_DEBUG
public static final int LOG_LEVEL_INFO
public static final int LOG_LEVEL_WARN
public static final int LOG_LEVEL_ERROR
public static final int LOG_LEVEL_DISABLE
public static final int GET_ORIGNODE_DEFAULT_VALUE
public static final byte PROPERTY_SCOPE_SAVEPOINT
public static final byte PROPERTY_SCOPE_COMMIT
public static final byte PROPERTY_SCOPE_SERVER
PROPERTY_SCOPE_TRANSACTION
.public static final byte PROPERTY_SCOPE_TRANSACTION
public static final byte PROPERTY_SCOPE_PERSISTENT
public static final java.lang.String SKIP_CLIENT_VERIFIES_FOR_ADMINS
PROPERTY_SCOPE_COMMIT
or PROPERTY_SCOPE_TRANSACTION
, verify on client and the before and after
variants are skipped for admins.de.ipcon.gui.solstice.Client#saveBO(Transaction, boolean)
,
Constant Field Valuespublic static final java.lang.String SKIP_SERVER_VERIFIES_FOR_ADMINS
PROPERTY_SCOPE_SERVER
,
verify on server and the before and after variants are skipped for admins.public static final java.lang.String SKIP_RECALCS_FOR_DATA_REPAIR
public java.util.ArrayList<BOProc> procs
public IndexedHashSet<BO> newbos
public IndexedHashSet<BO> purges
public IndexedHashSet<BO> bos
public IndexedHashSet<BO> refs
public java.lang.String remarks
public java.lang.String description
public transient java.lang.Integer clientSaveLock
public transient boolean savePhase
public static void killNewProcsRunner()
public static java.lang.String getHumanReadablePropertyScope(byte scope)
public static boolean isScopeValid(byte scope)
public static boolean isScopeCommit(byte scope)
PROPERTY_SCOPE_COMMIT
.public static boolean isScopeTransaction(byte scope)
PROPERTY_SCOPE_TRANSACTION
.public static boolean isScopeServer(byte scope)
PROPERTY_SCOPE_SERVER
.public static boolean isScopePersistent(byte scope)
PROPERTY_SCOPE_PERSISTENT
.public static boolean isScopeSavepoint(byte scope)
PROPERTY_SCOPE_SAVEPOINT
.public static boolean isPropertyFinal(byte scope)
PROPERTY_IS_FINAL
.public static byte getFinalScope(byte scope)
public boolean isInstance(Transaction otx)
SaveBOListenerI.transactionSaveSuccess(de.ipcon.db.core.Transaction, java.util.function.Predicate<de.ipcon.db.core.Transaction>)
.public void acquireReadLock()
public boolean tryAcquireReadLock()
public boolean weHaveReadLock()
public void releaseReadLock()
public void acquireWriteLock()
public void releaseWriteLock()
public void assertWriteLock()
java.lang.IllegalStateException
- if this thread doesn't hold a writelock upon this transactionpublic void resetReversedMode()
public void setCurrentUser(Benutzer ben)
public final Benutzer getCurrentUser()
public void continueWithTempIdsFrom(Transaction _tx)
public boolean isOnAuthoritativeSyncServer()
public boolean recalcOfBOsShouldBeCanceled()
public boolean isInOTRMode()
public boolean isLocked()
public boolean isClosing()
public boolean isClosed()
public boolean isUndo()
public boolean isUndoWithTimeTravel()
public boolean isUndoWithoutTimeTravel()
public void disableClientVerification()
This setting bypasses all client-side verification steps, including pre- and post-verification handling, for the following user roles:
The disablement remains in effect for the entire duration of the transaction.
Important:
hasVerificationDisablingPrivileges()
. This change prevents unnoticed errors that
could occur in previous versions when this method was called without sufficient permissions.isClientVerificationDisabled()
/ isServerVerificationDisabled()
) would remain false
,
and all verifications would be performed despite calling the disabling methods. This is because these methods also check for
hasVerificationDisablingPrivileges()
and return false
if the user lacks the required permissions.java.lang.IllegalStateException
- if the user does not have privileges to bypass verifications.public boolean isClientVerificationDisabled()
true
if client-side verification is disabled for the current user, false
otherwise.public void disableServerVerification()
This setting bypasses all server-side verification steps, including pre- and post-verification handling, for the following user roles:
The disablement persists throughout the transaction's lifetime and across all server-side operations.
Important:
hasVerificationDisablingPrivileges()
. This change prevents unnoticed errors that
could occur in previous versions when this method was called without sufficient permissions.isClientVerificationDisabled()
/ isServerVerificationDisabled()
) would remain false
,
and all verifications would be performed despite calling the disabling methods. This is because these methods also check for
hasVerificationDisablingPrivileges()
and return false
if the user lacks the required permissions.java.lang.IllegalStateException
- if the user does not have privileges to bypass verifications.public boolean isServerVerificationDisabled()
true
if server-side verification is disabled for the current user, false
otherwise.public void disableBORecalc()
This setting bypasses all recalculation of BO properties which might be necessary to do delicate data repairs without having the usual 'BO mechanics' in the way.
Please use with utmost caution because you might introduce states with BOs which render them unusable
Doing so is only allowed for users of the 'Admins Datenkorrektur' group.
public boolean isBORecalcsDisabled()
@Deprecated public void markForSkipClientVerifiesForAdmins()
disableClientVerification()
instead.@Deprecated public boolean isSkipClientVerifiesForAdmins()
isClientVerificationDisabled()
instead.@Deprecated public void markForSkipServerVerifiesForAdmins()
disableServerVerification()
instead.@Deprecated public boolean isSkipServerVerifiesForAdmins()
isServerVerificationDisabled()
instead.public void markForORMScript()
public boolean isForORMScript()
public static Transaction getInstance(BOLoaderI _loader)
public static Transaction getInstance(BOLoaderI _loader, java.lang.String _desc)
public static Transaction getInstance(BOLoaderI _loader, java.lang.String _desc, TemporaryIdSupplierI _temporaryIdSupplier)
public static Transaction getInstance(BOLoaderI _loader, SchemaI _schema)
public static Transaction getInstance(BOLoaderI _loader, SchemaI _schema, java.lang.String _desc)
public static Transaction getInstance(BOLoaderI _loader, SchemaI _schema, java.lang.String _desc, TemporaryIdSupplierI _temporaryIdSupplier)
public TemporaryIdSupplierI getTemporaryIdSupplier()
public void setTemporaryIdSupplier(TemporaryIdSupplierI _temporaryIdSupplier)
public void setBOLoader(BOLoaderI l)
public BOLoaderI getBOLoader()
public PersistenceHandlerI getPersistenceHandlerInSavePhase()
public FeatureManagerI getFeatureManager()
getFeatureManager
in interface BOLoaderI
public SchemaI getSchema()
getBOLoader()
getSchema
in interface BOLoaderI
getSchema
in interface SchemaProviderI
public CryptoHandlerI getCryptoHandler()
BOLoaderI
getCryptoHandler
in interface BOLoaderI
public FileVaultI getFileVault()
getFileVault
in interface BOLoaderI
public java.lang.Long getClientSideId(BO bo)
bo
- the business object to get the client-side Id for.public BO getBO(BO bo)
BO.isNew()
), this method checks if it has a
Transaction with the same TemporaryIdSupplier as this Transaction. If it does, the method
looks up the BO in the cache of this Transaction (which might return a cloned instance if
a ::mergeIn took place before). If it does not have a Transaction with the same
TemporaryIdSupplier, the passed BO is returned as is.
Otherwise, this method returns the result of calling getBO(Long, Class)
.
Please note that this method shall always be preferred over getBO(Long, Class)
if you
already have a BO at hand, for the special checks this method does on new BOs, as explained
above.
It's important to note that this method always returns a freshly loaded instance if no BO
with that Id has been encountered and thus not been cached before. In contrast, the method
frapFromCache(BO)
has a slightly different behaviour, as such BOs are deep-cloned
and the copy is put into the cache, unless alwaysReloadOnFrap is set to true (which causes
BOs to be reloaded through ph/castor, so that instance tracking of castor doesn't break when
frapping on server-side).bo
- the BO to return in the context of this Transactionpublic boolean exists(java.lang.Long id)
exists
in interface BOLoaderI
id
- the Id of the BO to look forclasstip
- the class of the BO to look for (optional; defaults to BO.class)BOLoaderI.exists(Long, Class)
public boolean exists(java.lang.Long id, java.lang.Class<? extends BOI> classtip)
BOLoaderI
public BO getBO(java.lang.Long id)
frapBO(BO)
before it is returned, unless the parameter "noFetch" is passed
as "true" - in that case, the loader is not asked, and null is returned for a cache-miss.
This method should not be used if you already have a BO at hand, instead the getBO(BO)
variant should be preferred, as that one avoids returning a wrong new BO from the cache, having
has the same temporary Id as the passed Long that was possibly taken from that BO that shall be
re-fetched via this method.
It's important to note that this method always returns a freshly loaded instance if no BO
with that Id has been encountered and thus not been cached before. In contrast, the method
frapFromCache(BO)
has a slightly different behaviour, as such BOs are deep-cloned
and the copy is put into the cache, unless alwaysReloadOnFrap is set to true (which causes
BOs to be reloaded through ph/castor, so that instance tracking of castor doesn't break when
frapping on server-side).getBO
in interface BOLoaderI
id
- the Id of the BO to look forclasstip
- the class of the BO to look for (optional; defaults to BO.class)noFetch
- a boolean for configuring if on cache-miss the BO shall be loaded via
the loader of this Transaction; if false is passed, null will be returned upon a
cache-miss.BOLoaderI.getBO(Long, Class)
public BO getBO(java.lang.Long id, java.lang.Class<? extends BOI> classtip)
BOLoaderI
public BO getBOUncached(BO _bo)
_bo
- The BO to retrieve.null
if the input is null
.public BO getBOUncached(java.lang.Long id)
getBOUncached
in interface BOLoaderI
public BO getBOUncached(java.lang.Long id, java.lang.Class<? extends BOI> classtip)
BOLoaderI
BOLoaderI.isCaching()
BOLoaderI instances.getBOUncached
in interface BOLoaderI
public BO[] getBOs(java.lang.Long[] ids)
getBOs
in interface BOLoaderI
ids
- An array of ids, which are from the data type Long, for which we want to retrieve the specific BOs.classtip
- The class of the BOs which we want to retrieve.BOLoaderI.getBOs(Long[],Class)
public BO[] getBOs(java.lang.Long[] ids, java.lang.Class<? extends BOI> classtip)
BOLoaderI
getBOs
in interface BOLoaderI
ids
- array of Longs with ids for the requested BOs.classtip
- guess for classes which the BOs belong to, may be null.Transaction
public BO[] getBOs(long[] ids)
getBOs
in interface BOLoaderI
ids
- An array of ids, which are from the primitive data type long, for which we want to retrieve the specific BOs.classtip
- The class of the BOs which we want to retrieve.BOLoaderI.getBOs(long[],Class)
public BO[] getBOs(long[] ids, java.lang.Class<? extends BOI> classtip)
BOLoaderI
getBOs
in interface BOLoaderI
ids
- array of longs with ids for the requested BOs.classtip
- guess for classes which the BOs belong to, may be null.Transaction
public BO[] getRelationBOs(java.lang.Long id, java.lang.Class<? extends BOI> classtip, java.lang.String attName)
BOLoaderI
getRelationBOs
in interface BOLoaderI
id
- id of the BO which the requested BOs has a relation toclasstip
- common superclass of the requested bosattName
- name of the relation from the BO to the requested onespublic de.ipcon.db.core.QueryResultsI query(java.lang.String t)
BOLoaderI
query
in interface BOLoaderI
query
in interface BOQueryLoaderI
BOLoaderI.query(String, Object[])
public de.ipcon.db.core.QueryResultsI query(java.lang.String t, java.lang.Object[] pvals)
BOLoaderI
This sample shows how to query bla BOs though this method
do
it = bol.query("bla from pack.bo bla where not Ldel limit 2")
loop while it.hasNext()
bo = BO it.getCurrentObject() -- hopefully this IS a BO, depends on the query.
-- do whatever you have to do with the bo
finally
it.close()
end
The finally clause is very important to free up database and backend resources,
so please don't forget this step!query
in interface BOLoaderI
query
in interface BOQueryLoaderI
query
in interface GrooqlBOLoaderI
t
- the query to fetch, written in OQLpvals
- an object array corresponding with $n entries, $1 is pvals[0] and so forth. Must not be null.public de.ipcon.db.core.QueryResultsI query(BOQuery _eq)
BOLoaderI
public de.ipcon.db.core.QueryResultsI queryRelation(long id, java.lang.Class<? extends BOI> classtip, java.lang.String attributeName)
BOLoaderI
queryRelation
in interface BOLoaderI
public java.util.List queryBO(java.lang.String query) throws java.lang.IllegalArgumentException
queryBO
in interface BOLoaderI
queryBO
in interface BOQueryLoaderI
query
- the query to fetch, written in OQLpvals
- an object array corresponding with $n entries, $1 is pvals[0] and so forth. Must not be nullincludeKnownBOs
- flag that tells if new BOs not yet in the database but already known to the transaction
should also be included in the result. Please note that if this flag is given the full set of OQL queries is
not yet supported; an IllegalArgumentException
will be thrown if an unsupported query is encounteredjava.lang.IllegalArgumentException
- if includeKnownBOs
is given as 1/true and an unsupported query is
encounteredBOLoaderI.queryBO(String, Object[])
public java.util.List queryBO(java.lang.String query, java.lang.Object[] pvals) throws java.lang.IllegalArgumentException
BOLoaderI
queryBO
in interface BOLoaderI
queryBO
in interface BOQueryLoaderI
queryBO
in interface GrooqlBOLoaderI
query
- the query to fetch, written in OQLpvals
- an object array corresponding with $n entries, $1 is pvals[0] and so forth. Must not be null.java.lang.IllegalArgumentException
BOLoaderI.query(String, Object[])
public java.util.List queryBO(java.lang.String query, java.lang.Object[] pvals, boolean includeKnownBOs) throws java.lang.IllegalArgumentException
java.lang.IllegalArgumentException
public java.util.List queryBO(BOQuery _eq)
BOLoaderI
public java.util.List queryBO(BOQuery _eq, boolean includeKnownBOs)
public byte[] getBLOB(java.lang.Long id)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs to.public byte[] getBLOB(java.lang.Long id, java.lang.Long backuppingBPId)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs to.backuppingBPId
- instead of the current BLOB get and stream
the backup-BLOB that was stored because of this BP-Id from the backup-dirpublic long getBLOB(java.lang.Long id, java.io.OutputStream os)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the OutputStream to write the BLOB-bytes topublic long getBLOB(java.lang.Long id, java.io.OutputStream os, boolean closeOS)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the OutputStream to write the BLOB-bytes tocloseOS
- a boolean designating if the OutputStream shall be closed afterwards or not.public long getBLOB(java.lang.Long id, java.io.OutputStream os, boolean closeOS, java.lang.Long backuppingBPId)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the OutputStream to write the BLOB-bytes tocloseOS
- a boolean designating if the OutputStream shall be closed afterwards or not.backuppingBPId
- instead of the current BLOB get and stream
the backup-BLOB that was stored because of this BP-Id from the backup-dirpublic long getBLOB(java.lang.Long id, java.io.DataOutput os)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the DataOutput to write the BLOB-bytes topublic long getBLOB(java.lang.Long id, java.io.DataOutput os, boolean closeOS)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the DataOutput to write the BLOB-bytes tocloseOS
- a boolean designating if the DataOutput shall be closed afterwards or not.public long getBLOB(java.lang.Long id, java.io.DataOutput os, boolean closeOS, java.lang.Long backuppingBPId)
BLOBLoaderI
getBLOB
in interface BLOBLoaderI
id
- the id of the BO the BLOB belongs toos
- the DataOutput to write the BLOB-bytes tocloseOS
- a boolean designating if the DataOutput shall be closed afterwards or not.backuppingBPId
- instead of the current BLOB get and stream
the backup-BLOB that was stored because of this BP-Id from the backup-dirpublic VFile getBLOBInfo(java.lang.Long id)
BLOBLoaderI
getBLOBInfo
in interface BLOBLoaderI
id
- the id of the BO the BLOB-info belongs to.public VFile getBLOBInfo(java.lang.Long id, java.lang.Long backuppingBPId)
BLOBLoaderI
getBLOBInfo
in interface BLOBLoaderI
id
- the id of the BO the BLOB-info belongs to.backuppingBPId
- instead of the current BLOB get the VFile for
the backup-BLOB that was stored because of this BP-Id from the backup-dirpublic boolean hasBLOB(java.lang.Long id)
hasBLOB
in interface BLOBLoaderI
id
- the id of the BO the check for existence of a BLOB on the server.public boolean hasBLOB(java.lang.Long id, java.lang.Long backuppingBPId)
hasBLOB
in interface BLOBLoaderI
id
- the id of the BO the check for existence of a BLOB on the server.backuppingBPId
- instead of the current BLOB get the VFile for
the backup-BLOB that was stored because of this BP-Id from
the backup-dirpublic java.util.BitSet haveBLOB(long[] ids)
haveBLOB
in interface BLOBLoaderI
ids
- an array of ids of BOs the check for existence of a BLOB on the server.public java.lang.Long getNextId()
BOLoaderI
public java.lang.Long testAuth(Anmeldung a)
BOLoaderI
public boolean testAuth(de.ipcon.db.core.PasswortUeberpruefung a)
BOLoaderI
public BatchedBackendRequestI prepareQuery(java.lang.String s)
prepareQuery
in interface BOLoaderI
public BatchedBackendRequestI prepareQuery(java.lang.String s, java.lang.Object[] o)
prepareQuery
in interface BOLoaderI
public void execute(BatchedBackendRequestI[] srs)
public BOLoaderI getParentLoader()
BOLoaderI
getParentLoader
in interface BOLoaderI
public BOLoaderI getRootLoader()
BOLoaderI
getRootLoader
in interface BOLoaderI
public DBManEventProviderI getEventProvider()
BOLoaderI
getEventProvider
in interface BOLoaderI
public BO frapFromCache(BO bo)
frapFromCache
in interface BOLoaderI
bo
- the BO that should be frapped.public BO frapBO(BO bo)
bo
- the BO that should be frapped.public BO frapBOAndHandleNonPersistentAttributes(BO bo)
public java.lang.String getMiniDesc(BO bo)
public BO assureBotClass(BO bo)
BO
instance is consistent with (that is the same as) the class
the BOT
of the instance represents. Might need to reload the BO
instance from the database to
effectuate that.bo
- the BO
whose class consistency should be checkedBO
where the class of the instance is the same as the representing class of
its BOT
; may either be the instance passed in or a reloaded new instance from the databasepublic long getOrigNodeNN()
public BOProc[] getProcs()
getProcCount()
public boolean hasProcs()
BOProcHolderI
hasProcs
in interface BOProcHolderI
true
if at least one change has been recorded, false
otherwise.public int getProcCount()
public boolean hasBLOBProcs()
public boolean hasNewBOs()
true
, if this transaction contains BOs that are new (i.e., have not been persisted yet), false
otherwise.public BO[] getNewBOs()
getNewBOCount()
.public boolean hasPurges()
true
, if BOs were marked for removal (purging) from the database within this transaction, false
otherwise.public int getNewBOCount()
getNewBOCount
in interface BOProcHolderI
public int getPurgedBOCount()
This count reflects the number of BOs permanently removed from the database as a result of this transaction's operations. It may be useful for tracking the impact of the transaction or for auditing purposes.
offset
- An optional offset to apply to the procedures within this transaction when counting purged BOs.public int getPurgedBOCount(int offset)
public int getDeletedBOCount()
This count reflects the number of BOs effectively marked as (soft) deleted in the database as a result of this transaction's operations. It may be useful for tracking the impact of the transaction or for auditing purposes.
getDeletedBOCount
in interface BOProcHolderI
public int getDeletedBOCount(int offset)
This count reflects the number of BOs effectively marked as (soft) deleted in the database as a result of this transaction's operations. It may be useful for tracking the impact of the transaction or for auditing purposes.
offset
- An offset to apply to the procedures within this transaction when counting deleted BOs.public java.lang.Long[] getDeletedBOIds()
public java.lang.Long[] getDeletedBOIds(java.lang.Class<? extends BOI> _onlyForClass)
public java.lang.Long[] getDeletedBOIds(java.lang.Class<? extends BOI> _onlyForClass, boolean _newBOs)
public java.util.List<BOProc> getProcs(BO bo)
bo
- the bo to get procs for.attributeName
- the attribute of the bo
that the returned procs should represent a change of;
null means any change to the bo is relevant.public java.util.List<BOProc> getBLOBProcs()
BOProc
s of THIS if they are relevant to BLOB changes and if so put them
in a List
bo
- the bo to get BLOB procs for (optional parameter).List
containing BLOB changing BOProc
s; List
might be empty (but never NULL
)public java.lang.Long[] getBLOBProcsBOIds()
public java.lang.Long[] getBLOBProcsBOIds(boolean skipNewBOs)
public BO[] getBOs()
public BO[] getIncludedBOs()
public BO[] getIncludedBOsFiltered()
public BO[] getIncludedBOsFiltered(java.lang.Class<? extends BOI> onlyForClass)
public BO[] getIncludedBOsFiltered(java.lang.Class<? extends BOI> onlyForClass, boolean alsoNewBOs)
public int getIncludedBOCount()
public java.lang.Long[] getIncludedBOIds()
public java.lang.Long[] getIncludedBOIds(java.lang.Class<? extends BOI> _onlyForClass)
public java.lang.Long[] getIncludedBOIds(java.lang.Class<? extends BOI> _onlyForClass, boolean _newBOs)
public boolean isKnown(java.lang.Long id)
isKnown
in interface BOLoaderWithCacheI
id
- the id of a bo which should be checkedpublic BO getKnown(java.lang.Long id)
getKnown
in interface BOLoaderWithCacheI
id
- the id of the bo to lookup.public boolean isKnown(BO bo)
isKnown( Long )
is returned.
This method ignores any version a bo might have for not new BOs, e.g.
ignores a stale cache in the transaction.isKnown
in interface BOLoaderWithCacheI
bo
- the bo that should be checked against internal caches, nonnullpublic java.util.Collection<BO> getKnown(java.lang.Class<? extends BOI> clazz)
getKnown
in interface BOLoaderWithCacheI
public java.util.Map<java.lang.Long,BO> getKnownBOs()
clazz
- the Class to filter the known BOs to (optional)limit
- the maximum number of filtered BOs of a certain class to return (non-negative, optional)
FIXME? Including new BOs.
FIXME 2023-02-21 ps: clazz=null -> deleted BOs are included, clazz<>null -> not included. Optimize getBOsByAttrs if this changes.public java.util.Map<java.lang.Long,BO> getKnownBOs(java.lang.Class<? extends BOI> clazz)
public java.util.Map<java.lang.Long,BO> getKnownBOs(java.lang.Class<? extends BOI> clazz, int limit)
@Deprecated public BO getBOByStringAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.String[] s)
public BO getBOByStringAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.String[] s, boolean nullIfNotFound)
public BO getBOByStringAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.String[] s, boolean nullIfNotFound, boolean ignoreNotUnique)
public BO getBOByStringAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.String[] s, boolean nullIfNotFound, boolean ignoreNotUnique, boolean onlyKnown)
public BO getBOByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] s)
getBOByAttrs
in interface BOQueryLoaderI
class
- the clazz of the BO to getattributeNames
- a list of attribute names to check, nonnull.s
- a list of attribute values to check, paired by index with attrs-list, nonnull.nullIfNotFound
- if false (default), then an ObjectForCoditionNotFoundException is thrown if no BO matches
the provided filter. If true, then this method simply returns null in this case.ignoreNotUnique
- if false (default), then an ObjectForConditionNotUniqueException is thrown if two or
more objects match the provided filter. Otherwise, any one of these objects are returned.
This method makes no guarantees to return the same object on successive calls in this case.onlyKnown
- if false (default), then this method might execute a query to load objects, if true, then
only BOs of this transaction are considered.
Note: This setting might hide a duplicate BO located in the database.public BO getBOByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] s, boolean nullIfNotFound)
getBOByAttrs
in interface BOQueryLoaderI
public BO getBOByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] s, boolean nullIfNotFound, boolean ignoreNotUnique)
getBOByAttrs
in interface BOQueryLoaderI
public BO getBOByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] s, boolean nullIfNotFound, boolean ignoreNotUnique, boolean onlyKnown)
@Deprecated public BO getBOByStringAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.String s)
public BO getBOByStringAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.String s, boolean nullIfNotFound)
public BO getBOByStringAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.String s, boolean nullIfNotFound, boolean ignoreNotUnique)
public BO getBOByStringAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.String s, boolean nullIfNotFound, boolean ignoreNotUnique, boolean onlyKnown)
public BO getBOByAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.Object s)
getBOByAttr
in interface BOQueryLoaderI
BOQueryLoaderI.getBOByAttrs(java.lang.Class, java.lang.String[], java.lang.Object[], boolean, boolean)
public BO getBOByAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.Object s, boolean nullIfNotFound)
getBOByAttr
in interface BOQueryLoaderI
public BO getBOByAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.Object s, boolean nullIfNotFound, boolean ignoreNotUnique)
getBOByAttr
in interface BOQueryLoaderI
public BO getBOByAttr(java.lang.Class<? extends BOI> clazz, java.lang.String attributeName, java.lang.Object s, boolean nullIfNotFound, boolean ignoreNotUnique, boolean onlyKnown)
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean[] notValue)
getBOsByAttrs
in interface BOQueryLoaderI
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean[] notValue, int limit)
getBOsByAttrs
in interface BOQueryLoaderI
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean[] notValue, int limit, java.util.Set<java.lang.Long> excludeBOIds)
getBOsByAttrs
in interface BOQueryLoaderI
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values)
getBOsByAttrs
in interface BOQueryLoaderI
clazz
- The class of the desired BO.attributeNames
- An array of attribute names to filter by.values
- An array of attribute values to compare against. The values should correspond to the attributes specified in the 'attrs'
parameter.onlyKnown
- If set to true, limits the lookup to this transaction and does not query for additional BOs. (Default: false. When using
testBOLoader, it is always true)limit
- The maximum number of matching BOs to be returned. Use '0' for unlimited. (Default: unlimited)nots
- An array of booleans indicating whether the corresponding attribute-value check should be inverted.
If set to true for a given index, it means that the attribute should be unequal to the given value. (Default: null)excludeBOIds
- a nullable Set of Ids to exclude from the results. More efficient that multiple '!Id' entries.
Mostly exists here for compability to the Interface variant of this method, to exclude possibly 'outdated' BOs from lower sources.public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean onlyKnown)
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean onlyKnown, int limit)
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean onlyKnown, int limit, boolean[] nots)
public java.util.List getBOsByAttrs(java.lang.Class<? extends BOI> clazz, java.lang.String[] attributeNames, java.lang.Object[] values, boolean onlyKnown, int limit, boolean[] nots, java.util.Set<java.lang.Long> excludeBOIds)
public void initProcCache()
public boolean isCreated(BO bo)
public boolean isPurged(BO bo)
true
if the given BO was marked for removal (purging) from the database within this transaction.public boolean isIncluded(BO bo)
public boolean isInvolved(BO bo)
bo
- the BO to checkpublic boolean isBOOrAnyToOneReachableBOInvolved(BO bo)
bo
- the BO to checkpublic boolean isDeletedOrNotInvolved(BO bo)
public boolean wasDeleted(BO bo)
public boolean wasBLOBChanged(BO bo)
public boolean wasBLOBCreated(BO bo)
public boolean wasBLOBDeleted(BO bo)
public final boolean isUnderAdminControl()
true
if a user is associated with this transaction and she has administrator privileges, false
otherwise.BenutzerGroupAspects.isAdministratorUser()
public final boolean isUnderBackendControl()
A transaction is considered under backend control if it does not have a current user associated with it.
true
if the transaction is under backend control (i.e., has no user associated with it), false
otherwise.public final boolean isUnderSystemUserControl()
Checks if the current user associated with the transaction is a KernelModule system user, such as the alarm or notification system.
true
if a user is associated with this transaction and she is a system user, false
otherwise.BenutzerGroupAspects.isSystemUser()
,
Benutzer.SYSTEM_USER_NAMES
public final boolean isUnderServiceControl()
true
if a user is associated with this transaction and she is a service user, false
otherwise.BenutzerGroupAspects.isServiceUser()
,
Gruppe.RG_Services
public boolean isAttributeInitialized(BO bo, java.lang.String attributeName)
bo
- the Object on which the change shall be detectedattributeName
- the attribute that shall be tested for changespublic boolean isAttributeNulled(BO bo, java.lang.String attributeName)
bo
- the Object on which the change shall be detectedattributeName
- the attribute that shall be tested for changespublic boolean isAnyAttributeChangedExcept(BO bo, java.lang.String[] excludeNames)
Convenience method to allow usage of a nonnull String Array for the names of excluded attributes
to allow a more similar usage compared to similar methods.
public boolean isAnyAttributeChangedExcept(BO bo, java.lang.String[] excludeNames, boolean evenIfValueUnchanged)
public boolean isAnyAttributeChangedExcept(BO bo, java.lang.String[] excludeNames, boolean evenIfValueUnchanged, boolean ignoreBooleanTriState)
public boolean isAnyAttributeChangedExcept(BO bo, java.util.Set<java.lang.String> excludeNames)
isInvolved( BO )
to check against any changes.
Creates a list of the Attrs that exist on this bo that should be checked, excluding the names from the parameter,
and checks for changes via isOneOfAttributesChanged(BO, String[], boolean, boolean)
because this allows
usage of the proccache and result in faster evaluation for large transactions.bo
- the Object on which changes shall be detectedexcludeNames
- a nonnull Set
with all attribute names that are excempt from this test.ignoreBooleanTriState
- whether changes from false to null or null to false in boolean attributes shall be ignored, defaults to noevenIfValueUnchanged
- whether changes which do not actually change the original value of the attribute shall be reported as changes, defaults to noexcludeNames
was changed in this transaction for exacly this bo
.public boolean isAnyAttributeChangedExcept(BO bo, java.util.Set<java.lang.String> excludeNames, boolean evenIfValueUnchanged)
public boolean isAnyAttributeChangedExcept(BO bo, java.util.Set<java.lang.String> excludeNames, boolean evenIfValueUnchanged, boolean ignoreBooleanTriState)
public boolean isAttributeChanged(BO bo, java.lang.String attributeName)
bo
- the Object on which the change shall be detectedattributeName
- the attribute that shall be tested for changesignoreBooleanTriState
- whether changes from false to null or null to false in boolean attributes shall be ignored, defaults to noevenIfValueUnchanged
- whether changes which do not actually change the original value of the attribute shall be reported as changes, defaults to nopublic boolean isAttributeChanged(BO bo, java.lang.String attributeName, boolean evenIfValueUnchanged)
public boolean isAttributeChanged(BO bo, java.lang.String attributeName, boolean evenIfValueUnchanged, boolean ignoreBooleanTriState)
public boolean isOneOfAttributesChanged(BO bo, java.lang.String[] attributeNames)
bo
- the Object on which the change shall be detectedattributeNames
- a String-array with all attribute that shall be tested for changesignoreBooleanTriState
- whether changes from false to null or null to false in boolean attributes shall be ignored, defaults to noevenIfValueUnchanged
- whether changes which do not actually change the original value of the attribute shall be reported as changes, defaults to nopublic boolean isOneOfAttributesChanged(BO bo, java.lang.String[] attributeNames, boolean evenIfValueUnchanged)
public boolean isOneOfAttributesChanged(BO bo, java.lang.String[] attributeNames, boolean evenIfValueUnchanged, boolean ignoreBooleanTriState)
public java.lang.Object getOldValue(BO bo, java.lang.String attributeName)
public java.lang.Object getNewValue(BO bo, java.lang.String attributeName)
public TransactionMessageBusI getMessageBus()
public void addProc(BOProc bp)
public void addFixingProc(BOProc bp)
public BO refBO(BO bo, java.lang.String _whatMsg, BO debugBO, java.lang.String debugAttr, BOProc debugProc)
public java.lang.Object refParm(java.lang.Object o)
public java.lang.Object refParm(java.lang.Object o, java.lang.String what)
public java.lang.Object refParm(java.lang.Object o, java.lang.String what, BO debugBO)
public java.lang.Object refParm(java.lang.Object o, java.lang.String what, BO debugBO, java.lang.String debugAttr)
public java.lang.Object refParm(java.lang.Object o, java.lang.String what, BO debugBO, java.lang.String debugAttr, BOProc debugProc)
public boolean isNotPersistentParm(java.lang.Object o, java.lang.String attrName, java.lang.String attrUsage)
public void recordSet(BO bo, java.lang.String attributeName, java.lang.Class ptyp, java.lang.Object old, java.lang.Object $new)
This method tracks the change of an attribute's value within a BO during the transaction. It ensures the validity of the operation and maintains references to the affected BO. An `IllegalStateException` is thrown if the transaction is locked or if the BO is not part of the transaction (except in `diffingMode`).
bo
- The BO whose attribute is being modified.attributeName
- The name of the attribute being modified.ptyp
- The class of the new attribute value.old
- The original value of the attribute.newValue
- The new value being assigned to the attribute.java.lang.IllegalStateException
- If the transaction is locked or the BO is not included in the transaction (in non-diffing mode).public void recordAdd(BO bo, java.lang.String attributeName, java.lang.Class ptyp, java.lang.Object parm)
This method registers the association of a new related object with a BO during the transaction. It validates the operation and maintains references to the involved BOs. An `IllegalStateException` is thrown if the transaction is locked or if the BO is not part of the transaction (except in `diffingMode`).
bo
- The BO to which the related object is being added.attributeName
- The name of the attribute representing the relationship.ptyp
- The class of the added related object.parm
- The value of the added related object.oldParm
- The previous value of the attribute (an optional BO).java.lang.IllegalStateException
- If the transaction is locked or the BO is not included in the transaction (in non-diffing mode).public void recordAdd(BO bo, java.lang.String attributeName, java.lang.Class ptyp, java.lang.Object parm, BO oldParm)
public void recordRemove(BO bo, java.lang.String attributeName, java.lang.Class ptyp, java.lang.Object parm)
This method tracks the disassociation of a related object from a BO during the transaction. It ensures the validity of the operation and maintains references to the affected BOs. An `IllegalStateException` is thrown if the transaction is locked or if the BO is not part of the transaction (except in `diffingMode`).
bo
- The BO from which the related object is being removed.attributeName
- The name of the attribute representing the relationship.ptyp
- The class of the removed related object.parm
- The value of the removed related object.java.lang.IllegalStateException
- If the transaction is locked or the BO is not included in the transaction (in non-diffing mode).public void recordPurge(BO bo)
This method registers the intent to permanently delete the given BO from the database. It performs necessary checks to ensure the operation is valid and consistent with the transaction's state. This method should only be called by the backend. An IllegalStateException is thrown if the transaction is not called by the backend, the transaction is locked, or if the BO is not part of the transaction (except in diffingMode).
bo
- The BO to be purged from the database.java.lang.IllegalStateException
- If the method is not called by the backend, the transaction is locked,
or the BO is not included in the transaction (in non-diffing mode).public ManagedFileI storeBLOB(BO bo, java.io.InputStream is) throws java.io.IOException
is
- the InputStream to retrieve the BLOB data from; will be closed
after the data was read from it.java.io.IOException
public ManagedFileI removeBLOB(BO bo)
public void precommitBLOBs() throws java.io.IOException
java.io.IOException
public void commitBLOBs() throws java.io.IOException
java.io.IOException
public void rollbackBLOBs() throws java.io.IOException
java.io.IOException
public void finishBLOBs() throws java.io.IOException
java.io.IOException
public void enterSavePhase()
public void finalizeSaveProcedure(TransactionAnswer ta, SaveBOListenerI sbl)
#replayAdditionalProcs(Collection)
for replaying and incorporating "relevant"
additional server-side changes (BOProcs) locally as well.
The additional server-side changes are taken from the passed TransactionAnswer by replacing the "stubbed"
BOs within the additional BOProcs of the TransactionAnswer by their "real" instances which are taken from
this Transaction.
Additionally the passed SaveBOListenerI is notified via the transactionSaveSuccess-callback
about the successful save-process.
Finally this Transaction is "commit()"ted locally.
This only happens on the client-side, as additional BOProcs are only generated server-side and transmitted
back to the client in the TransactionAnswer.
Called by BOSaver.saveBO(Transaction, SaveBOImplementationI, SaveBOListenerI, boolean, int, int, Benutzer)
to do these common tasks after saving has been completed one way or the other.public void commit()
public void checkpoint()
public void flushLocals()
public void reFrapAfterSave(TransactionConflictReport report, boolean stubs)
de.ipcon.db.BOSaver#saveBO()
to do this common task after saving
has been completed one way or the other, unless only existing BOs were modified
and no conflicts arose during saving, in which case this maintenance is not necessary.public void close()
public void closeAndClearLazyData()
@Deprecated public void disconnectBOs()
close()
, as the Transaction will be closed and thus defunct after performing a disconnectBOs/close.public void disconnectBOs(boolean clearLazyData)
public void flush()
public long simulateSave(boolean doVerify)
doVerify
- if true, calls the different verify-methods when saving.public long simulateSave()
public long simulateSave(long sid)
public long simulateSave(long sid, boolean doVerify)
public void rehashCache()
public void drain()
drain
in interface BOLoaderI
drain
in interface BOLoaderWithCacheI
public boolean isCaching()
BOLoaderI
public boolean isRecording()
BOLoaderI
isRecording
in interface BOLoaderI
public java.util.TreeMap<java.lang.Long,BO> getBOs(java.lang.Class<? extends BOI> _classTip)
_classTip
- The class of the BOs which we want to retrievepublic boolean isActive()
public void rollback()
public void playReverse()
public TransactionCanonification canonize(boolean modifyCurrent)
modifyCurrent
- if true, then the TransactionCanonification modifies this Transaction,
if false, only a TransactionCanonification is returned for a what-if informationpublic TransactionCanonification canonize(boolean modifyCurrent, int from)
public TransactionCanonification canonize(boolean modifyCurrent, int from, int till)
public java.util.List<BOProc> getCanonizedProcs()
TransactionCanonification
of this Transaction.canonize(boolean modifyCurrent)
public java.util.List<BOProc> getCanonizedProcs(BO bo)
bo
- the BO to get BOProc-s for.attributeName
- the attribute of the BO that the returned BOProc-s should represent a change of;
null means any change to the BO is relevantpublic java.util.List<BOProc> getCanonizedProcs(BO bo, java.lang.String attributeName)
public java.util.List<BOProc> getCanonizedProcs(BO bo, java.util.Set<java.lang.String> attrs)
bo
- the BO to get BOProc-s for.attrs
- a Set of attributes of the BO that the returned BOProc-s should represent a change of;
empty means any change to the BO is relevantpublic void readInstance(SecureObjectInputI s, boolean stubClone) throws java.lang.ClassNotFoundException, java.io.IOException
java.lang.ClassNotFoundException
java.io.IOException
public void readInstance(SecureObjectInputI s, boolean stubClone, boolean checkIntegrity) throws java.lang.ClassNotFoundException, java.io.IOException
java.lang.ClassNotFoundException
java.io.IOException
public void readInstance(SecureObjectInputI s, boolean stubClone, boolean checkIntegrity, boolean forDeepClone) throws java.lang.ClassNotFoundException, java.io.IOException
java.lang.ClassNotFoundException
java.io.IOException
public void writeProcInstance(SecureObjectOutputI s, java.util.HashMap<BO,java.lang.Integer> indexMap, BOProc proc, boolean stubClone, boolean forDeepClone) throws java.io.IOException
java.io.IOException
public BOProc readProcInstance(SecureObjectInputI s, java.util.ArrayList<BO> boList, boolean stubClone, boolean forDeepClone) throws java.lang.ClassNotFoundException, java.io.IOException
java.lang.ClassNotFoundException
java.io.IOException
public void writeBOInstance(SecureObjectOutputI s, BO bo) throws java.io.IOException
java.io.IOException
public BO readBOInstance(SecureObjectInputI s) throws java.io.IOException
java.io.IOException
public void writeInstanceWithoutBLOBTransfer(SecureObjectOutputI s) throws java.io.IOException
java.io.IOException
public void writeInstanceToServer(SecureObjectOutputI s, java.lang.Thread savingThread) throws java.io.IOException
java.io.IOException
public void checkIntegrity(boolean addRemarkForUndeletedNewBOsWithoutProcs)
public void prependBTs(BT[] bts)
public void applyOtherTransactionsSaveSuccess(Transaction otx)
DefaultFormContext
to update the state of the current form and prevent
conflicts if the same user modifies the same BO in two forms concurrently.public void upgradeLocks()
public java.util.Set createOrTouchAdditional(java.util.Date transactionDate, Transaction.Additional addtx)
BOs
that were created in addtx
in the "new" list
of the PersistenceHandlerI
and updates the Lmod
of changed
BOs
from addtx
. Nothing is actually persisted here yet.Set
containing the created and modified BOs
from addtx
public TransactionConflictReport serverLocalTransactionStorePrepare(SchemaI schema)
This method handles server-local transactions differently from regular transactions, as it avoids reloading objects that are already present on the server. Instead, it focuses on updating the `lmod` (last modified) date for these objects.
schema
- The schema to use within the returned TransactionConflictReport.public TransactionConflictReport replayInStorePrepare(SchemaI schema, Benutzer user)
This method is crucial for detecting changes made to objects during transaction replay. By reloading the objects, the system can accurately identify modifications and ensure data consistency when committing the transaction.
schema
- The schema to use within the returned TransactionConflictReport.user
- The user initiating the saving of the transaction, to use within the returned TransactionConflictReport.public void serverLocalTransactionStoreFinish(java.util.Date serverLocalTransactionDate, boolean isChangeByBenutzer, PersistenceHandlerI ph)
public void replayInStoreFinish(TransactionConflictReport report, boolean isChangeByBenutzer)
public void replayInStoreLog(TransactionConflictReport report, Benutzer user)
public void replayInStoreWithoutLog(TransactionConflictReport report, Benutzer user)
public int getSavesCountNN()
public void increaseSavesCount()
public java.lang.String getDescription()
public void appendDescription(java.lang.String _desc)
public void setDescription(java.lang.String _desc)
public BT getBT()
public void replay()
BOProcs
of this Transaction
, applying the
recorded changes again.conflictingTX
- disable recording on the conflictingTX as well while replaying all changes on this.
See Solstice's Client.nrx for nonnull case, i.e. when reapplying and merging transaction conflicts.
Null in other cases.public void replay(Transaction conflictingTX)
public void incorporateDiffOfConflictingBO(BO localBO, BO conflictingBO, SchemaI schema)
changedBO
into conflictingBO
.
Covered are all changes: deletion / undeletion, setting of scalar or relation-attributes
as well as adding or removing objects to or from a relation.
Needed during BOSaver.saveBO(de.ipcon.db.core.Transaction, de.ipcon.db.SaveBOImplementationI)
in case of a conflict during save.
changedBO
and conflictingBO
must essentially be the same
BO
, that is must be of the same class and have the same
Id
, only as different in-memory instances.changedBO
- the instance of the BO
on which changes were
performed by the userconflictingBO
- the instance of the BO
which was modified
concurrently by/in another clientschema
- a SchemaI
for getting entities, attributes, etc.public java.lang.String getLogPrefixForProgress()
public Transaction.Additional evaluateVerifyOnServer(java.lang.Long nodeNumber, Benutzer user)
public Transaction.Additional evaluateVerifyOnServer(java.lang.Long nodeNumber, Benutzer user, java.util.Set explicitTouchedBOs)
public void fireAfterSave(java.lang.Long nodeNumber, Benutzer user, SaveException se)
DBMan
after the save process finished, either successfully (se = null
) or due to an
"application level" error (se <> null
). Not called when some internal error during saving
occurred.nodeNumber
- the node number of the server on which the saving is performeduser
- the Benutzer
in whose context the transaction was savedse
- if not null the SaveException
that was thrown during saving, for example because of some failed
verifyOnServer()
checks; if null the saving was finished successfullypublic Transaction.Additional filterAdditionals(Transaction.Additional adds)
public TransactionDumper getDumper()
public void dumpProcs()
public void dumpProcs(java.util.ArrayList _procs)
public void dumpProcs(int _from, int _to)
public void dumpProcs(int _from, int _to, java.util.List _procs)
public void dumpProcs(org.apache.log4j.Logger l, org.apache.log4j.Level _level)
public void dumpProcs(org.apache.log4j.Logger l)
BOProcHolderI
dumpProcs
in interface BOProcHolderI
l
- The logger to which the procedures should be dumped.public void dumpProcs(org.apache.log4j.Logger l, java.util.List _procs)
public void dumpProcs(org.apache.log4j.Logger l, java.util.List _procs, org.apache.log4j.Level _level)
public void dumpProcs(org.apache.log4j.Logger _log, int _from, int _to)
public void dumpProcs(org.apache.log4j.Logger _log, int _from, int _to, java.util.List _procs)
public void dumpProcs(org.apache.log4j.Logger _log, int _from, int _to, java.util.List _procs, org.apache.log4j.Level _level)
public java.lang.String getSummary()
public java.lang.String procsToString(int from, int till)
from
- Start index(inclusive) of the procs inside this Transaction that are to be printed.till
- End index(inclusive) of the procs inside this Transaction that are to be printed.
A value of -1 is equivalent to (getProcs().size() - 1)html
- Whether to format the output as HTML or plain text.onlyThisBO
- If not null, only BOProcs affecting this BO will be included in the output.limitToExplicitBO
- If false, all procs are being printed even when the onlyThisBO is not null.maxProcs
- Number of procs that are to be printed (exclusive). A value of -1 is equivalent to getProcs().size().grouped
- Whether the procs should be formatted to be grouped by the BO they are concerning or not.canonize
- Whether the procs of this transaction are to be canonized canonize(boolean)
.skipBackProcs
- Whether to skip "redundant" procs setting only back relations from the output. Only makes sense if
canonize is passed as true
as well.public java.lang.String procsToString(int from, int till, boolean html)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO, boolean limitToExplicitBO)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO, boolean limitToExplicitBO, int maxProcs)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO, boolean limitToExplicitBO, int maxProcs, boolean grouped)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO, boolean limitToExplicitBO, int maxProcs, boolean grouped, boolean canonize)
public java.lang.String procsToString(int from, int till, boolean html, BO onlyThisBO, boolean limitToExplicitBO, int maxProcs, boolean grouped, boolean canonize, boolean skipBackProcs)
public java.lang.String procsToString(boolean html, boolean skipBackProcs, BO onlyThisBO)
A wrapper for #procsToString(int, int, boolean, BO, boolean, int, boolen, boolean)
that automatically collects all available procs and formats the output to be grouped.
procsToString
in interface BOProcHolderI
html
- Whether to format the output as HTML or plain text.skipBackProcs
- Whether to skip "redundant" procs setting only back relations from the output.onlyThisBO
- If not null, only BOProcs affecting this BO will be included in the output.public java.lang.String procsToString()
html
- Whether to format the output as HTML or plain text.onlyThisBO
- If not null, only BOProcs affecting this BO will be included in the output.canonize
- Whether the procs of this transaction are to be canonized canonize(boolean)
.limitToExplicitBO
- If false, all procs are being printed even when the onlyThisBO is not null.maxProcs
- Number of procs that are to be printed (exclusive). A value of -1 is equivalent to getProcs().size().skipBackProcs
- Whether to skip "redundant" procs setting only back relations from the output. Only makes sense if
canonize is passed as true
as well.public java.lang.String procsToString(boolean html)
BOProcHolderI
procsToString
in interface BOProcHolderI
html
- Whether to format the output as HTML or plain text.public java.lang.String procsToString(boolean html, BO onlyThisBO)
BOProcHolderI
procsToString
in interface BOProcHolderI
html
- Whether to format the output as HTML or plain text.onlyThisBO
- If not null, only BOProcs affecting this BO will be included in the output.public java.lang.String procsToString(boolean html, BO onlyThisBO, boolean canonize)
public java.lang.String procsToString(boolean html, BO onlyThisBO, boolean canonize, boolean limitToExplicitBO)
public java.lang.String procsToString(boolean html, BO onlyThisBO, boolean canonize, boolean limitToExplicitBO, int maxProcs)
public java.lang.String procsToString(boolean html, BO onlyThisBO, boolean canonize, boolean limitToExplicitBO, int maxProcs, boolean skipBackProcs)
public java.lang.String allProcsToString()
#procsToString(int, int, boolean, BO, boolean, int, boolen, boolean)
that automatically collects and prints all available procs and formats the output to be groupedpublic java.lang.String allProcsToString(boolean html)
public java.lang.String allProcsToString(boolean html, BO onlyThisBO)
public java.lang.String allProcsToString(boolean html, BO onlyThisBO, boolean canonize)
public java.lang.String allProcsToString(boolean html, BO onlyThisBO, boolean canonize, boolean limitToExplicitBO)
public java.lang.String allProcsToString(boolean html, BO onlyThisBO, boolean canonize, boolean limitToExplicitBO, boolean skipBackProcs)
public java.lang.String allLocalsToString()
public java.lang.String currentSavepointToString()
public java.util.List<java.util.Map> getDepMaps(BO bo)
public java.lang.String newBOsToString()
public java.lang.String newBOsToString(boolean html)
BOProcHolderI
newBOsToString
in interface BOProcHolderI
html
- Whether to format the output as HTML or plain text.public java.lang.String newBOsToString(boolean html, int offset)
html
- Whether to format the output as HTML or plain text.offset
- An offset to apply to the procedures within this transaction when converting new BOs to a string representation.public void dumpCache(org.apache.log4j.Logger l)
public BO includeCopy(BO bo, java.lang.String[] skipAtts)
de.ipcon.db.core.BO#copyFrom()
,
BO.createCopy()
public BO includeCopy(BO bo, java.lang.String[] skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate)
public BO includeCopy(BO bo, java.lang.String[] skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate, java.util.Map<java.lang.Long,BO> alreadyCreated)
public BO includeCopy(BO bo, java.lang.String[] skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors)
public BO includeCopy(BO bo)
Relations are either only linked or copied, depending on the copy policy of that attribute or its 'new'-state. Many-Relations marked as dependent are copied, otherwise linked.
Attention: Any attribute of the given BO marked in the schema with "omitOnCopy" is excluded even if not specified as skipped attribute
bo
- the nonnull BO to copy.skipAtts
- a nullable Set of attribute names to explicitly exclude from being copied.ignoreManyRelation
- if true, then many relations to other BOs are skipped completely. Otherwise they're handled
according to the copy policy for this attribute.subentityToCreate
- If null, then the returned value has the same class/Entity as BO. If not null, then the
returned "copy" is an instance of the provided EntityI and a subclass of the provided BO.
Needs to be a subclass/subentity of the bo parameter.alreadyCreated
- nonnull but possibly empty Map to explicitly prevent creation of relation BOs, use the BO
linked to this key instead.ignoreErrors
- if true, then errors while copying attributes are ignored. If false, a FillBOException is thrown.
Has no effect on exceptions unrelated to filling BO.de.ipcon.db.core.BO#copyFrom()
,
BO.createCopy()
public BO includeCopy(BO bo, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations)
public BO includeCopy(BO bo, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate)
public BO includeCopy(BO bo, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate, java.util.Map<java.lang.Long,BO> alreadyCreated)
public BO includeCopy(BO bo, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI subentityToCreate, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors)
public BO fillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations)
public BO fillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent)
public BO fillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated)
public BO fillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors)
public BO fillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors, boolean recursiveCall)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors)
public Transaction.FillBOResult prepareFillBO(BO bo, BO copyIntoBO, java.util.Set<java.lang.String> skipAtts, boolean ignoreManyRelations, EntityI ent, java.util.Map<java.lang.Long,BO> alreadyCreated, boolean ignoreErrors, boolean recursiveCall)
public java.lang.Boolean isLoggedIn(Benutzer _ben)
BOLoaderI
isLoggedIn
in interface BOLoaderI
_ben
- the Benutzer for which the logged in state should be checkedpublic boolean isLoggedInNN(Benutzer _ben)
BOLoaderI
isLoggedInNN
in interface BOLoaderI
_ben
- the Benutzer for which the logged in state should be checkedpublic void mergeIn(Transaction otherTx)
public void mergeIn(Transaction otherTx, boolean appendOtherDescriptions)
public void mergeIn(Transaction otherTx, boolean appendOtherDescriptions, boolean addOtherRemarks)
public Transaction stubClone(BOLoaderI bol)
public Transaction stubClone(BOLoaderI bol, boolean doCanonize)
public SerializedTransaction serialize() throws IRuntimeException
IRuntimeException
public static Transaction deserialize(SerializedTransaction stx, BOLoaderI bol, SchemaI schema, TemporaryIdSupplierI tempIdSupplier) throws IRuntimeException
IRuntimeException
public Transaction deepClone(BOLoaderI bol, SchemaI schema)
bol
- the BOLoaderI to use for reloading the BOs of this Transaction; falls back to BOLoader of this Transaction, if null is passedschema
- the explicit schema to set in the clone; falls back to the Schema of this Transaction, if null is passedpreserveBLOBHandles
- if true, the BLOBHandles of this Transaction are also set in the clonepreserverTxLocals
- if true, the txLocals of this Transaction are copied to the clonepreserverCurrentUser
- if true, the current user of this Transaction is also set in the clone, after it has been frappedpublic Transaction deepClone(BOLoaderI bol, SchemaI schema, boolean preserveBLOBHandles)
public Transaction deepClone(BOLoaderI bol, SchemaI schema, boolean preserveBLOBHandles, boolean preserveTxLocals)
public Transaction deepClone(BOLoaderI bol, SchemaI schema, boolean preserveBLOBHandles, boolean preserveTxLocals, boolean preserveCurrentUser)
public void copyLocalsFrom(Transaction tx)
public void copyLocalsFrom(Transaction tx, boolean excludeCurrentUser)
public void copyLocalsFrom(Transaction tx, boolean excludeCurrentUser, boolean skipExisting)
public void restoreBLOBHandlesFrom(Transaction tx)
public boolean hasProperty(java.lang.String key)
public java.lang.Object getProperty(java.lang.String name)
name
- String with name of propertypublic void setProperty(java.lang.String name, java.lang.Object value, byte scope)
name
- String with the name of the propertyvalue
- Object value of the propertyscope
- Scope of this variableisFinal
- If this variable shall be "final", i.e. unmodifiablePROPERTY_SCOPE_COMMIT
,
PROPERTY_SCOPE_TRANSACTION
,
PROPERTY_SCOPE_SERVER
,
PROPERTY_SCOPE_PERSISTENT
,
savepoint(String)
public void setProperty(java.lang.String name, java.lang.Object value, byte scope, boolean isFinal)
public static java.lang.String getPersistentPropertyKey(EntityI namespaceEntity, java.lang.String name)
public boolean hasPersistentProperty(EntityI namespaceEntity, java.lang.String name)
public java.lang.String getPersistentStringProperty(EntityI namespaceEntity, java.lang.String name)
public void setPersistentStringProperty(EntityI namespaceEntity, java.lang.String name, java.lang.String value)
public java.lang.Long getPersistentLongProperty(EntityI namespaceEntity, java.lang.String name)
public void setPersistentLongProperty(EntityI namespaceEntity, java.lang.String name, java.lang.Long value)
public java.math.BigDecimal getPersistentDecimalProperty(EntityI namespaceEntity, java.lang.String name)
public void setPersistentDecimalProperty(EntityI namespaceEntity, java.lang.String name, java.math.BigDecimal value)
public java.lang.Boolean getPersistentBooleanProperty(EntityI namespaceEntity, java.lang.String name)
public void setPersistentBooleanProperty(EntityI namespaceEntity, java.lang.String name, java.lang.Boolean value)
public Transaction.Savepoint savepoint(java.lang.String name)
public Transaction.Savepoint savepoint(java.lang.String name, java.lang.Object owner)
name
- name of the savepointowner
- owner of the savepoint, needed for owner-oriented API calls, see belowgetSavepoints(Object)
,
getLatestSavepoint(Object)
,
rollbackLatestSavepoint(Object)
public Transaction.Savepoint[] getSavepoints(java.lang.Object owner)
owner
- owner object given previously to savepoint(String,Object)
savepoint(String,Object)
,
getLatestSavepoint(Object)
,
rollbackLatestSavepoint(Object)
public boolean hasSavepoint(java.lang.String name, java.lang.Object owner)
name
- desired String possibly given previously as name to savepoint(String,Object)
owner
- desired owner object possibly given previously to savepoint(String,Object)
savepoint(String,Object)
public Transaction.Savepoint getLatestSavepoint(java.lang.Object owner)
owner
- owner object given previously to savepoint(String,Object)
savepoint(String,Object)
,
getSavepoints(Object)
,
rollbackLatestSavepoint(Object)
public boolean hasSavepoints()
public boolean rollbackLatestSavepoint(java.lang.Object owner)
owner
- owner object given previously to savepoint(String,Object)
savepoint(String,Object)
,
getSavepoints(Object)
,
getLatestSavepoint(Object)
public boolean savepointBelongsHere(Transaction.Savepoint _sp)
_sp
- the Savepoint to checkpublic void flagAsUserChoseToOverrideSaveVetoExceptions(java.lang.String message)
public boolean isUserChoseToOverrideSaveVetoExceptions()
public void flagAsMassChange()
public boolean isMassChange()
public void addRemark(java.lang.String _str)
public void initRemarks(java.lang.String _str)
public java.lang.String getRemarks()
public java.lang.String toString()
toString
in class java.lang.Object
public java.lang.String toString(boolean _showRuntimeInfo)
public void logDebug(java.lang.String _logmessage)
public void logInfo(java.lang.String _logmessage)
public void logWarn(java.lang.String _logmessage)
public void logError(java.lang.String _logmessage)
public boolean isSyncMode()
This class provides a mechanism to create a snapshot of the transaction's state at a given point. If subsequent operations within the transaction encounter errors or need to be undone, you can roll back to this savepoint, discarding any changes made after its creation.
**Usage:**
Transaction.Savepoint sp = tx.savepoint("foo"); // Create a savepoint named "foo" try { // Perform operations that might need to be rolled back sp.commit(); // Mark the savepoint as successful; **MUST BE THE LAST STATEMENT IN THE TRY BLOCK** } finally { if (sp.isValid()) { sp.rollback(); // Roll back to the savepoint if it hasn't been committed or already rolled back } }
**Important:**
public void setSyncMode(boolean $338)
public boolean isRepairMode()
public void setRepairMode(boolean $339)
public boolean isDiffingMode()
public void setDiffingMode(boolean $340)
public boolean isInitEnvironmentMode()
public void setInitEnvironmentMode(boolean $341)
public java.lang.Long getOrigNode()
public void setOrigNode(java.lang.Long $342)
public java.lang.Long getOrigBTId()
public void setOrigBTId(java.lang.Long $343)
public java.lang.Long getOrigUser()
public void setOrigUser(java.lang.Long $344)
public java.util.Date getOrigTime()
public void setOrigTime(java.util.Date $345)
public long getLocalLastModifiedBOs()
public void setLocalLastModifiedBOs(long $346)
public java.lang.Long getBTId()
public void setBTId(java.lang.Long $347)
public int getLogLevel()
public void setLogLevel(int $348)
public boolean isIgnoreBotCoherency()
public void setIgnoreBotCoherency(boolean $349)
public boolean isRecordNonPersistent()
public void setRecordNonPersistent(boolean $350)
public boolean isAlwaysReloadOnFrap()
public void setAlwaysReloadOnFrap(boolean $351)
public TransactionProviderI getProvider()
public void setProvider(TransactionProviderI $352)
public boolean isExplicitActive()
public void setExplicitActive(boolean $353)
public boolean isInhibitDefaults()
public void setInhibitDefaults(boolean $354)
public java.lang.RuntimeException getOrigin()
public void setOrigin(java.lang.RuntimeException $355)
public java.lang.Integer getSavesCount()
public void setSavesCount(java.lang.Integer $356)
public javax.swing.JRootPane getRootPaneToLockOnConnectionInterrupt()
public void setRootPaneToLockOnConnectionInterrupt(javax.swing.JRootPane $357)
Copyright © 2000-2025 OAshi S.à r.l. All Rights Reserved.