public class BO extends Synchable implements BOI, SaveVetoI, SaveAwareI, java.io.Serializable, java.lang.Cloneable, java.io.Externalizable, DescribableI, LazyDataProviderI
Modifier and Type | Field and Description |
---|---|
static java.lang.String |
BLOB_KEY |
static java.lang.String |
CANCEL_RECALC_CALLED |
static java.math.BigDecimal |
D_0 |
static java.math.BigDecimal |
D_1 |
static java.math.BigDecimal |
D_10 |
static java.math.BigDecimal |
D_100 |
static java.math.BigDecimal |
D_1000 |
static java.math.BigDecimal |
D_10000 |
static java.math.BigDecimal |
D_5 |
static java.math.BigDecimal |
D_MINUS_1 |
static java.math.BigDecimal |
D_MINUS_ONE |
static java.math.BigDecimal |
D_ONE |
static java.math.BigDecimal |
D_ZERO |
static java.lang.ThreadLocal |
doExWriteLRMFunction
ThreadLocal
|
static BO[] |
EMPTY_ARRAY |
static java.lang.Float |
F_0 |
static java.lang.Float |
F_1 |
static java.lang.Long |
L_0 |
static java.lang.String |
L10N_KEY_BO_INSTANTIATION |
static java.lang.String |
L10N_KEY_BO_WITH_PROTECTED_CONSTRUCTOR |
static NullAggregate |
NULL_AGGREGATE |
static de.ipcon.db.core.NullIterator |
NULL_ITERATOR |
ATT_Badge, ATT_Badge2, ATT_Badge3, ATT_Badge4, ATT_BLOBCreatedBy, ATT_BLOBCreatedOn, ATT_BLOBDeletedBy, ATT_BLOBDeletedOn, ATT_BLOBLastModifiedBy, ATT_BLOBLastModifiedOn, ATT_Bot, ATT_Crea, ATT_CreatedBy, ATT_CreatedModifiedText, ATT_Id, ATT_InvolvedInProcs, ATT_LastModifiedBy, ATT_Ldel, ATT_Lmod, ATT_Procs, ENT_BO
Constructor and Description |
---|
BO() |
Modifier and Type | Method and Description |
---|---|
void |
_set(java.lang.String pn,
java.lang.Object value,
boolean fromGroovy) |
void |
$(java.util.Map attrs2values)
Sets the values of the given attribute-value-map attr2Values.
|
java.lang.Object |
$(java.lang.String attrName)
Returns the value of the attribute with the given attrName.
|
void |
$(java.lang.String attrName,
java.lang.Object value)
Sets the value of the attribute with the given attrName to value.
|
java.util.List<java.lang.Object> |
$$(java.lang.String attrPath)
Fetches the value of the given attribute path via projection from the server.
|
BO |
$$bo(java.lang.String attrPath) |
java.lang.Object |
$$o(java.lang.String attrPath) |
java.util.Map |
$$r(java.lang.String attrPath) |
java.util.Iterator |
$$ri(java.lang.String attrPath)
Fetches an iterator of attribute path specified via projection from the server.
|
java.util.Iterator |
$$ri(java.lang.String attrPath,
java.util.Map mapToFill) |
void |
acquireTxWriteLock()
Tries to acquire the write-lock of the loading tx, if any.
|
void |
add(java.lang.String attrName,
BO value) |
void |
afterSaveOnClient(BasicClientContextI ctx,
SaveException failure)
Called on all included
BO s of the saved Transaction (only!) |
void |
afterSaveOnServer(java.lang.Long nodeNumber,
Benutzer user,
Transaction tr,
SaveException failure)
Called from
Transaction.fireAfterSave(Long, Benutzer, SaveException)
by DBMan after the save process finished, either
successfully (se = null ) or due to an "application level" error (se <> null ). |
void |
afterVerifyOnClient(BasicClientContextI ctx)
Called on all included
BO s of the to-be-saved Transaction (only!) |
void |
afterVerifyOnServer(java.lang.Long nodeNumber,
Benutzer user,
Transaction tr) |
AggregateFunctionI |
aggregate(AggregateFunctionI a,
java.lang.String pathlist) |
AggregateFunctionI |
aggregate(java.lang.String s,
java.lang.String pathlist) |
AggregateFunctionI |
aggregate(java.lang.String s,
java.lang.String pathlist,
java.lang.String parameters) |
static java.util.Map |
badge(java.util.Map _m,
java.lang.String _badge)
badges any element within the specified map with the given string
|
static java.util.Map |
badge(java.util.Map _m,
java.lang.String _badge,
int _i) |
void |
beforeVerifyOnClient(BasicClientContextI ctx)
Called on all included
BO s of the to-be-saved Transaction (only!) |
void |
beforeVerifyOnServer(java.lang.Long nodeNumber,
Benutzer user,
Transaction tr) |
void |
bumpVersion()
increase version value to signal a modification
|
java.lang.Object |
cacheLocally(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func)
This method is used for caching the results of consecutive expensive method calls in BOs
in the transient properties map of the BO.
|
java.lang.Object |
cacheLocally(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func,
boolean versioned) |
java.lang.Object |
cacheLocallyAndThrowUnwrappedCause(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func)
Same as
#cacheLocally(String, Supplier but throws the originally
encountered exception that was potentially thrown during the initial calculation of the
result of the given Supplier instead of an IRuntimeException that otherwise would wrap that. |
java.lang.Object |
cacheLocallyAndThrowUnwrappedCause(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func,
boolean versioned) |
java.lang.Object |
cacheLocallyAndThrowUnwrappedUncheckedCause(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func)
Same as
#cacheLocally(String, Supplier but throws the originally
encountered exception that was potentially thrown during the initial calculation of the
result of the given Supplier - if it is a unchecked one - instead of an IRuntimeException
that otherwise would wrap that. |
java.lang.Object |
cacheLocallyAndThrowUnwrappedUncheckedCause(java.lang.String key,
java.util.function.Supplier<java.lang.Object> func,
boolean versioned) |
boolean |
cancelCheckConstraints()
This method is used to determine if certain constraint-checks may be skipped.
|
boolean |
cancelRecalc()
Returns true if we are not part of a Transaction or if the Transaction
is in OTR mode, is in sync mode or is locked.
|
boolean |
cancelRecalcViaLoadingTransaction()
Returns true if we were not loaded by a Transaction or if the loading
Transaction is in OTR mode, is in sync mode or is locked.
|
java.lang.Object |
clone() |
void |
commitTransaction() |
java.lang.Object |
computeTransientPropertyIfAbsent(java.lang.String name,
java.util.function.Supplier<java.lang.Object> computer,
boolean versioned) |
java.lang.String |
conciseDesc()
Returns a concise description for this DescribableI consisting of classname, Id
and Ldel/New status.
|
static java.lang.String |
conciseDesc(BO bo)
Null-safe static version of conciseDesc, which returns the 'null' String for a null BO and calls conciseDesc on the BO otherwise.
|
static java.lang.String |
conciseDesc(BO bo,
boolean showRuntimeInfo) |
static java.lang.String |
conciseDesc(BO bo,
boolean showRuntimeInfo,
boolean showCreaLmod) |
static java.lang.String |
conciseDesc(BO bo,
boolean showRuntimeInfo,
boolean showCreaLmod,
boolean useClientSideId) |
java.lang.String |
conciseDesc(boolean showRuntimeInfo)
Returns a concise description for this DescribableI consisting of classname, Id
and Ldel/New status.
|
java.lang.String |
conciseDesc(boolean showRuntimeInfo,
boolean showCreaLmod)
Returns a concise description for this DescribableI consisting of classname, Id
and Ldel/New status.
|
java.lang.String |
conciseDesc(boolean showRuntimeInfo,
boolean showCreaLmod,
boolean useClientSideId)
Returns a concise description for this DescribableI consisting of classname, Id
and Ldel/New status.
|
void |
consumeAndAssureTransientPropertyExists(java.lang.String name,
java.util.function.Consumer operation,
java.lang.Object[] args)
Performs the given Consumer operation on the passed args.
|
ManagedFileI |
copyBLOBFrom(BO blobSource)
Store the BLOB from the passed BO as BLOB of this BO.
|
void |
copyFrom(BO s)
Deprecated.
|
void |
copyFrom(BO s,
Transaction _tx) |
BO |
createCopy()
Creates a copy of this
BO . |
BO |
createCopy(Transaction _tx) |
BO |
deepClone() |
BO |
deepClone(BOLoaderI bol) |
void |
delete()
Recursively marks this and any BOs in dependent many-relations as (soft) deleted.
|
java.lang.String |
describe()
Returns a nice description of this DescribableI.
|
static java.lang.String |
describe(BO bo)
Returns a nice description of the given BO.
|
static java.lang.String |
describe(BO bo,
java.lang.String pattern) |
static java.lang.String |
describe(BO bo,
java.lang.String pattern,
boolean evenWhenStub)
Returns a nice description of the given BO.
|
static java.lang.String |
describe(BO bo,
java.lang.String pattern,
boolean evenWhenStub,
java.lang.String nullString) |
static java.lang.String |
describe(BO bo,
java.lang.String pattern,
boolean evenWhenStub,
java.lang.String nullString,
boolean addId) |
java.lang.String |
describe(java.lang.String _pattern)
Returns a nice description of this DescribableI.
|
java.lang.String |
describe(java.lang.String _pattern,
boolean _evenWhenStub) |
java.lang.String |
describe(java.lang.String _pattern,
boolean _evenWhenStub,
SchemaI _schema) |
java.lang.String |
describe(java.lang.String _pattern,
boolean _evenWhenStub,
SchemaI _schema,
boolean _addId) |
java.lang.String |
describeId()
Returns a nice description of this BO with appended Id in brackets.
|
static java.lang.String |
describeId(BO bo)
Returns a nice description of the given BO with appended Id in brackets.
|
static java.lang.String |
describeId(BO bo,
java.lang.String pattern) |
static java.lang.String |
describeId(BO bo,
java.lang.String pattern,
boolean evenWhenStub) |
static java.lang.String |
describeId(BO bo,
java.lang.String pattern,
boolean evenWhenStub,
java.lang.String nullString) |
java.lang.String |
describeId(java.lang.String _pattern) |
java.lang.String |
describeId(java.lang.String _pattern,
boolean _evenWhenStub) |
java.lang.String |
describeId(java.lang.String _pattern,
boolean _evenWhenStub,
SchemaI _schema) |
static java.lang.String |
describeNE(BO bo)
Returns a nice description of the given BO.
|
static java.lang.String |
describeNE(BO bo,
java.lang.String pattern) |
static java.lang.String |
describeNE(BO bo,
java.lang.String pattern,
boolean evenWhenStub) |
static java.lang.String |
describeNE(BO bo,
java.lang.String pattern,
boolean evenWhenStub,
java.lang.String nullString) |
static java.lang.String |
describeNE(BO bo,
java.lang.String pattern,
boolean evenWhenStub,
java.lang.String nullString,
boolean addId) |
BO |
destub(BOLoaderI bol)
Returns the "real" BO for this "stubbed" BO, loaded via the passed BOLoaderI.
|
boolean |
equalPayload(BO s)
Compare the payload of this to the provided BO.
|
boolean |
equalPayload(BO other,
java.util.Collection<java.lang.String> attrs)
Returns true if the payloads of the this BO and the passed BO are the same
regarding the passed attribute names.
|
boolean |
equalPayload(BO other,
java.util.Collection<java.lang.String> attrs,
java.util.Collection<java.lang.String> otherAttrs) |
boolean |
equalPayload(BO other,
java.lang.String[] attributeNames)
Returns true if the payloads of the this BO and the passed BO are the same
regarding the passed attribute names.
|
boolean |
equalPayload(BO other,
java.lang.String[] attributeNames,
java.lang.String[] otherAttrs) |
boolean |
equals(java.lang.Object o)
Checks if this BO equals the passed object.
|
boolean |
equalsBO(BOI bo)
nullSafeEqualsBO(BOI, BOI) is called with this BOI as first parameter and the passed BOI as second one. |
boolean |
equalsBO(BOI bo,
boolean idComparisonOnly)
nullSafeEqualsBO(BOI, BOI) is called with this BOI as first parameter and the passed BOI as second one. |
boolean |
equalsRegardingAttrs(BO _bo,
java.lang.String[] _attributeNames)
Equals variant which compares only the given _attrs for equality.
|
void |
exportBLOB(java.io.File target)
Write the attached BLOB, if given, to the provided
File . |
static java.lang.String |
exReadString(java.io.ObjectInput s)
Null aware String reader function, with a workaround for 64k prob of readUtf().
|
static void |
exWriteString(java.io.ObjectOutput s,
java.lang.String val)
Null aware String writer function, with a workaround for 64k prob of writeUtf().
|
static java.util.Collection |
filterDeleted(BO[] arr)
Filters the passed BO array and returns only BO-instances that are not deleted.
|
static java.util.Collection |
filterDeleted(java.util.Collection col)
Filters the passed Collection and returns only BO-instances that are not deleted.
|
static java.util.Collection |
filterDeleted(java.util.Map map)
Filters the passed Map and returns only values which are BO-instances and not deleted.
|
void |
forgetTransientBLOBHandle() |
static BO |
frap(BOLoaderI bol,
BO bo)
Static convenience method, which fraps the passed BO using the passed BOLoaderI in a null-safe way.
|
java.util.Map<java.lang.Long,IssueReport> |
getAsBOInIssueReports() |
java.util.Iterator<IssueReport> |
getAsBOInIssueReportsIterator() |
java.lang.String |
getAsString(java.lang.String attrName)
Returns the value of the attribute with the given attrName as String values,
respecting schema defined formatting rules.
|
BackendBOLoaderWithPersistenceHandlerI |
getBackendBOLoaderWithPersistenceHandler()
Returns the first BackendBOLoaderWithPersistenceHandlerI of this BO in
its loader-chain if it was loaded in the backend and has such a loader.
|
java.lang.String |
getBadge() |
java.lang.String |
getBadge(int i) |
java.lang.String |
getBadge2() |
java.lang.String |
getBadge3() |
java.lang.String |
getBadge4() |
byte[] |
getBLOB()
For congruency of *BLOB -method names:
If this BO has a BLOB on the current server, returns the bytes of it.
|
long |
getBLOB(java.io.DataOutput target)
Writes this BO's BLOB to the given DataOutput
|
long |
getBLOB(java.io.DataOutput target,
boolean closeOS) |
long |
getBLOB(java.io.OutputStream target)
Streams this BO's BLOB to the given stream
|
long |
getBLOB(java.io.OutputStream target,
boolean closeOS)
Streams this BO's BLOB to the given stream
|
BLOBDataInputStream |
getBLOBAsDataInput()
Returns a BLOBDataInputStream that the data of this BOs BLOB is written into.
|
java.lang.String |
getBLOBAsEncodedString(java.nio.charset.Charset charset)
If this BO has a BLOB on the current server, returns the bytes of it as a String encoded using the passed charset.
|
java.lang.String |
getBLOBAsEncodedString(java.lang.String charsetName)
If this BO has a BLOB on the current server, returns the bytes of it as a String encoded using the passed charset.
|
BLOBInputStream |
getBLOBAsInputStream()
Returns a BLOBInputStream that the data of this BOs BLOB is streamed into.
|
java.lang.String |
getBLOBAsUTF8EncodedString()
If this BO has a BLOB on the current server, returns the bytes of it as an UTF-8 encoded String.
|
Benutzer |
getBLOBCreatedBy()
Returns the user in the transaction of the BP that created
the BLOB of this BO or null if no BLOB was created yet.
|
java.util.Date |
getBLOBCreatedOn()
Returns the user in the transaction of the BP that created
the BLOB of this BO or null if no BLOB was created yet.
|
Benutzer |
getBLOBDeletedBy()
Returns the user in the transaction of the BP that deleted
the BLOB of this BO or null if the BLOB was not deleted.
|
java.util.Date |
getBLOBDeletedOn()
Returns the user in the transaction of the BP that created
the BLOB of this BO or null if no BLOB was created yet.
|
VFile |
getBLOBInfo() |
Benutzer |
getBLOBLastModifiedBy()
Returns the user in the transaction of the most recent BP that affected
the BLOB of this BO or null if the BO is still new and unsaved.
|
java.util.Date |
getBLOBLastModifiedOn()
Returns the user in the transaction of the BP that created
the BLOB of this BO or null if no BLOB was created yet.
|
BOLoaderI |
getBOLoader()
Returns the BOLoaderI of this BO.
|
BOT |
getBot() |
int |
getBOVersion()
A value that is incremented each time the BO is modified.
|
byte[] |
getBytes()
If this BO has a stream on the current server, returns the bytes of it.
|
static CacheI |
getCache(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz) |
static CacheI |
getCache(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz,
java.lang.String fetchQuery) |
static CacheI |
getCache(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz,
java.lang.String fetchQuery,
java.lang.Class mapClass) |
static CacheI |
getCacheNT(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz) |
static CacheI |
getCacheNT(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz,
java.lang.String fetchQuery) |
static CacheI |
getCacheNT(BOLoaderI bol,
java.lang.String title,
java.lang.Class clazz,
java.lang.String fetchQuery,
java.lang.Class mapClass) |
SessionScopedCacheProviderI |
getCacheProvider() |
static SessionScopedCacheProviderI |
getCacheProvider(BOLoaderI bol) |
java.lang.Class<? extends BOI> |
getClazz() |
Benutzer |
getCreatedBy()
Returns the user in the transaction of the BP that created
this BO or null if the BO is still new and unsaved.
|
java.lang.String |
getCreatedModifiedText()
Returns a String for the current state this BO, i.e. whom was it created
by and when, whom was is last modified by and when.
|
java.util.List |
getDefaultScriptImportsList() |
static java.util.List<ScriptImport> |
getDefaultScriptImportsList(SchemaI schema) |
static java.util.List<ScriptImport> |
getDefaultScriptImportsList(java.lang.String packageNameBOs) |
BOWrapperI |
getDescribingBOWrapper()
Encapsulates BO into Wrapper object which returns the standard CBOFormat string on toString() calls.
|
BOWrapperI |
getDescribingBOWrapper(java.lang.String frmat)
Encapsulates BO into Wrapper object which returns given CBOFormat string value on toString() calls.
|
DBManEventProviderI |
getEventProvider() |
static DBManEventProviderI |
getEventProvider(BOLoaderI _bol) |
java.lang.Long |
getId()
copyFrom kopiert das uebergebene Synchable-Objekt in das eigene Objekt hinein.
|
java.util.Map<java.lang.Long,BP> |
getInvolvedInProcs() |
java.util.Iterator<BP> |
getInvolvedInProcsIterator() |
Benutzer |
getLastModifiedBy()
Returns the user in the transaction of the most recent BP that affected
this BO or null if the BO is still new and unsaved.
|
java.lang.Object |
getLazyData() |
Transaction |
getLoadingTransaction()
Returns the Transaction this BO has been loaded by or is included in.
|
java.util.Iterator |
getNullIterator() |
static BO |
getOrCreate(java.lang.Class<? extends BOI> clazz,
BOLoaderI bol,
java.util.Map attrs2values)
Checks if one of the given _bosHave matches the given _attrs2values; if yes
returns that; if not creates a new instance of _clazz with newInstance() and
returns that.
|
static BO |
getOrCreate(java.lang.Class<? extends BOI> clazz,
BOLoaderI bol,
java.util.Map attrs2values,
BO[] bosHave) |
static BO |
getOrCreate(java.lang.Class<? extends BOI> clazz,
BOLoaderI bol,
java.util.Map attrs2values,
BO[] bosHave,
java.util.Set attrsPrimary) |
static BO |
getOrCreate(java.lang.Class<? extends BOI> clazz,
BOLoaderI bol,
java.util.Map attrs2values,
BO[] bosHave,
java.util.Set attrsPrimary,
boolean includeIfTx) |
static BO |
getOrCreate(java.lang.Class<? extends BOI> clazz,
BOLoaderI bol,
java.util.Map attrs2values,
BO[] bosHave,
java.util.Set attrsPrimary,
boolean includeIfTx,
java.lang.Class<? extends BOI> clazzToCreate) |
static BO |
getOrCreate(java.lang.Class<? extends BOI> _clazz,
Transaction _tx,
java.util.Map _attrs2values)
Method version that takes the set of (possibly) existing matching BOs from
the TX.
|
static BO |
getOrCreate(java.lang.Class<? extends BOI> _clazz,
Transaction _tx,
java.util.Map _attrs2values,
java.util.Set _attrsPrimary) |
PermissionHandlerI |
getPermissionHandler()
Returns the
PermissionHandlerI for this BO , i.e. the one of the
SchemaI of this BO's BOLoaderI or null if this BO
has no BOLoaderI or SchemaI . |
java.util.Map<java.lang.Long,BP> |
getProcs() |
java.util.Iterator<BP> |
getProcsIterator() |
SchemaI |
getRootLoaderSchema()
Returns the SchemaI of the root loader of this BO's BOLoaderI.
|
SchemaI |
getSchema()
Returns the currently used SchemaI, i.e. the SchemaI of this BO's BOLoaderI.
|
int |
getSizeFast(java.lang.String _what)
Determines the size of a many-relation, if still lazy by querying the database (i.e. sizeFast) thus not reflecting changes being made in the current transaction!
|
Transaction |
getTransaction()
Returns the Transaction this BO is included in, null otherwise.
|
java.lang.Object |
getTransientProperty(java.lang.String name)
Returns the value that was saved using the given transient property name.
|
java.lang.Object |
getTransientProperty(java.lang.String name,
boolean rawwrapped) |
WrappedValue |
getWrappedTransientProperty(java.lang.String name,
boolean filterExpired) |
boolean |
hasActiveTransaction()
Returns true if this BO is included in a Transaction.
|
boolean |
hasBLOB() |
boolean |
hasBLOBOnServerSide()
Returns true, if there is a stream resource attached to this BO on server-side.
|
boolean |
hasBOAssignedTempId() |
int |
hashCode()
Returns a hash code value for this business object (BO).
|
static boolean |
hasRelationObjects(java.util.Map m)
Returns true if the given map contains at least one (if specified: not deleted) entry, false otherwise
|
static boolean |
hasRelationObjects(java.util.Map m,
boolean ignoreDeleted) |
boolean |
hasSessionAssignedTempId() |
boolean |
hasTempId() |
boolean |
hasTempIdForNewBOs() |
boolean |
hasTransientProperty(java.lang.String name)
Returns true, if a transient property with the given name currently exists.
|
boolean |
hasTransientPropertyUnfiltered(java.lang.String name)
Returns true, if a transient property with the given name exists or existed,
i.e. not filtering out already expired versions.
|
boolean |
includeAllowed(Transaction includeInTx)
Returns true if inclusion of this BO in the passed Transaction is actually allowed.
|
void |
includeInTransaction(Transaction includeInTx)
Includes this BO instance in the passed Transaction if it is allowed.
|
void |
invalidateBLOBCache() |
static boolean |
isBOAssignedTempId(java.lang.Long l) |
static boolean |
isCompoundChangeInProgress() |
boolean |
isCurrentTransactionUnderAdminControl()
Returns true, if we are part of a Transaction that has an Admin as current user.
|
boolean |
isIgnoreModificationConstraints() |
boolean |
isMandatory(AttributeI att)
Tells if the passed
AttributeI is mandatory in the context of this BO
(for the UI and access via the schema). |
boolean |
isNew()
Checks whether this BO has been created recently.
|
boolean |
isReadOnly(AttributeI att)
Tells if the passed
AttributeI is read-only in the context of this BO
(for the UI and access via the schema). |
boolean |
isServerSideAndLoadedReadOnly()
Returns true if this BO was loaded read-only in the backend.
|
static boolean |
isSessionAssignedTempId(java.lang.Long l) |
boolean |
isStub()
Returns true if this BO is a "stub".
|
static boolean |
isTempId(java.lang.Long l) |
static boolean |
isTempIdForNewInstance(java.lang.Long l) |
boolean |
isTemporary() |
boolean |
isVisible(AttributeI att)
Tells if the passed
AttributeI is visible in the UI (i.e. it may be read
from the database) in the context of this business object (BO) by calling the client-side
PermissionHandlerI.checkReadAllowed(BOI, String) and testing the result via
PermissionHandlerDecisionI.granted() . |
boolean |
isWriteable(AttributeI att)
Tells if the passed
AttributeI is writeable (i.e. a value for the attribute
may be written to the database) in the context of this business object (BO) by calling the client-side
PermissionHandlerI.checkWriteAllowed(BOI, String) and testing the result via
PermissionHandlerDecisionI.granted() . |
static void |
markCompoundChangeInProgress() |
void |
markDelete()
Marks this BO as (soft) deleted, without actually calling the delete() method, thereby
keeping linked relations intact.
|
void |
markUndelete() |
Transaction |
needLoadingTransaction()
Returns the Transaction this BO has been loaded by or is included in.
|
boolean |
needsReload()
Returns true if this BO needs to be reloaded, i.e. the current class does not match its defined clazz.
|
Transaction |
needTransactionInclusion()
Returns the Transaction this BO is included in.
|
static BO |
newInstance(java.lang.Class<? extends BOI> clazz,
BOLoaderI loader)
Creates new instance of given BO subclass, sets the given BOLoaderI or includes
it if the passed BOLoaderI is a Transaction and includeIfTx was passed as true.
|
static BO |
newInstance(java.lang.Class<? extends BOI> clazz,
BOLoaderI loader,
java.util.Map attrs2values) |
static BO |
newInstance(java.lang.Class<? extends BOI> clazz,
BOLoaderI loader,
java.util.Map attrs2values,
boolean includeIfTx) |
static BO |
newInstance(EntityI ent,
BOLoaderI loader)
Creates new instance of given EntityI, sets the given BOLoaderI or includes
it if the passed BOLoaderI is a Transaction and includeIfTx was passed as true.
|
static BO |
newInstance(EntityI ent,
BOLoaderI loader,
java.util.Map attrs2values) |
static BO |
newInstance(EntityI ent,
BOLoaderI loader,
java.util.Map attrs2values,
boolean includeIfTx) |
static java.lang.Long |
nextTempId()
Returns the next free temporary Id.
|
void |
notifyMessageBus(AttributeI attr)
Notify the messageBus of the LoadingTransaction of a changed value on a non persistent attribute.
|
void |
notifyMessageBus(AttributeI attr,
java.lang.Object newValue) |
void |
notifyMessageBus(AttributeI attr,
java.lang.Object newValue,
java.lang.Object oldValue) |
void |
notifyMessageBus(java.lang.String attributeName)
Convenience method for
notifyMessageBus(AttributeI, Object, Object) to lookup the attribute for the given
name. |
void |
notifyMessageBus(java.lang.String attributeName,
java.lang.Object newValue) |
void |
notifyMessageBus(java.lang.String attributeName,
java.lang.Object newValue,
java.lang.Object oldValue) |
void |
notifyMessageBusOfAdd(AttributeI attr,
BO added)
Notify the message bus of the loadingTransaction of an added BO on a virtual many relation.
|
void |
notifyMessageBusOfRemove(AttributeI attr,
BO removed)
Notify the message bus of the loadingTransaction of a removed BO on a virtual many relation.
|
static int |
nullSafeCompareTo(java.lang.Comparable first,
java.lang.Object second)
Compares first object with second object for order without failing if any of them is null.
|
static int |
nullSafeCompareTo(java.lang.Comparable first,
java.lang.Object second,
boolean nullIsSmaller) |
static boolean |
nullSafeContainsBO(java.util.Collection<? extends BOI> c,
BOI bo)
Returns true if the passed (BO-)Collection contains the passed BO (using #equalsBO(BO)).
|
static boolean |
nullSafeContainsBO(java.util.Map<java.lang.Long,? extends BOI> m,
BOI bo)
Returns true if the passed (relation-)Map contains the passed BO.
|
static boolean |
nullSafeEquals(java.lang.Object o1,
java.lang.Object o2)
Returns true if the passed Objects are equal.
|
static boolean |
nullSafeEqualsBO(BOI bo1,
BOI bo2)
Returns true if the passed BOs are either object-identic or they have the same Id.
|
static boolean |
nullSafeEqualsBO(BOI bo1,
BOI bo2,
boolean idComparisonOnly) |
static BO |
ofStub(BO bo)
Returns a "stubbed" instance of the passed BO, i.e. containing only the Id
and the BOT of the passed BO.
|
java.lang.Object |
propertyMissing(java.lang.String pn)
Missing getter.
|
void |
propertyMissing(java.lang.String s,
java.lang.Object value)
Missing setter.
|
void |
readExternal(java.io.ObjectInput s)
For better transfer performance, the serialization is done via Externalizable interface.
|
static void |
releaseCompoundChangeInProgress() |
void |
releaseTxWriteLock()
Tries to release the write-lock of the loading tx, if any.
|
void |
remove(java.lang.String attrName,
BO value) |
ManagedFileI |
removeBLOB()
Any BO can have a physical file (BLOB) which is stored on server-side and synchronized to all sync nodes.
|
java.util.Map |
requireNonEmptyRelation(java.lang.String attPath) |
java.lang.Object |
requireNonNullAttribute(java.lang.String attPath) |
static BO[] |
requireNonNullAttributes(BO[] bos,
java.lang.String[] attPaths)
Checks if ANY of the given values along the passed attribute paths are missing on ANY of the given BOs.
|
static java.util.Collection |
requireNonNullAttributes(java.util.Collection bos,
java.util.Collection attPaths)
Checks if ANY of the given values along the passed attribute paths are missing on ANY of the given BOs.
|
void |
requireNonNullAttributes(java.lang.String[] attPaths)
Deprecated.
please use the requireNonNullAttributes functions taking separate attribute path parameters instead
|
void |
requireNonNullAttributes(java.lang.String attPath1,
java.lang.String attPath2) |
void |
requireNonNullAttributes(java.lang.String attPath1,
java.lang.String attPath2,
java.lang.String attPath3) |
void |
requireNonNullAttributes(java.lang.String attPath1,
java.lang.String attPath2,
java.lang.String attPath3,
java.lang.String attPath4) |
void |
requireNonNullAttributes(java.lang.String attPath1,
java.lang.String attPath2,
java.lang.String attPath3,
java.lang.String attPath4,
java.lang.String attPath5) |
void |
setAsString(java.lang.String attrName,
java.lang.String value)
Sets the value of the attribute with the given attrName to value which is a string and will automatically converted to the required attribute type.
|
void |
setBadge(java.lang.String s) |
void |
setBadge(java.lang.String s,
int i) |
void |
setBadge2(java.lang.String s) |
void |
setBadge3(java.lang.String s) |
void |
setBadge4(java.lang.String s) |
void |
setBOLoader(BOLoaderI newLoader)
this method is overridden by subclasses to set n-1 relations to the same BOLoader
|
void |
setBOLoaderNoCascade(BOLoaderI newLoader)
special version which is only overridden by subclass BOT and must not be overwritten by any other subclass, changes just this very BO
|
void |
setBOLoaderNoCascade(BOLoaderI newLoader,
boolean ignoreAlreadyBOAssignedTempId) |
void |
setBot(BOT $133) |
void |
setId(java.lang.Long newId) |
void |
setId(java.lang.Long newId,
boolean iKnowWhatImDoing) |
void |
setIgnoreModificationConstraints(boolean $135) |
void |
setLazyData(java.lang.Object $134) |
void |
setTempId()
Initializes the Id of this BO with the next free temporary id.
|
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value)
Saves a transient value with the provided name for this BO.
|
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value,
boolean versioned) |
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value,
boolean versioned,
int explicitVersion) |
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value,
boolean versioned,
int explicitVersion,
java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue) |
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value,
java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue)
Saves a versioned transient value with the provided name for this BO.
|
java.lang.Object |
setTransientProperty(java.lang.String name,
java.lang.Object value,
int explicitVersion,
java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue)
Saves a versioned transient value with the provided name for this BO.
|
void |
slim()
This method removes all many-relation collections to save memory.
|
void |
slim(boolean force) |
void |
slim(java.util.HashSet rechash) |
void |
slim(java.util.HashSet rechash,
boolean force) |
ManagedFileI |
storeBLOB(byte[] bytes)
Creates a ByteArrayInputStream from the passed byte-array, then calls
storeBLOB(InputStream) |
ManagedFileI |
storeBLOB(java.io.File f)
Store the passed file as BLOB of this BO.
|
ManagedFileI |
storeBLOB(java.io.InputStream is)
Any BO can have a physical file (BLOB) which is stored on server-side and synchronized to all sync nodes.
|
ManagedFileI |
storeBLOB(java.lang.String s)
Fill this BOs BLOB with the given String content.
|
ManagedFileI |
storeBLOB(java.lang.String s,
java.lang.String charsetName) |
BO |
stub()
Returns a "stubbed" version of this BO, i.e. a new instance
containing only the Id and the BOT of this BO.
|
static java.util.Map |
toMap(BO bo)
Returns a
Map containing the given BO keyed by its Id |
static java.util.Map |
toMap(BO[] bos)
Returns a
Map containing the given BOs keyed by their Ids, ordered by their Id |
static java.util.Map |
toMap(BO[] bos,
boolean unmodifiable) |
static java.util.Map |
toMap(BO bo,
boolean unmodifiable) |
static java.util.Map |
toMap(BOLoaderI loader,
long[] ids,
java.lang.Class<? extends BOI> classTip)
Returns a
Map containing the BOs for the given Ids keyed by the Ids, ordered by their Id |
static java.util.Map |
toMap(BOLoaderI loader,
java.lang.Long[] ids,
java.lang.Class<? extends BOI> classTip)
Returns a
Map containing the BOs for the given Ids keyed by the Ids, ordered by their Id |
static java.util.Map |
toMap(BOLoaderI loader,
long[] ids,
java.lang.Class<? extends BOI> classTip,
boolean unmodifiable) |
static java.util.Map |
toMap(BOLoaderI loader,
java.lang.Long[] ids,
java.lang.Class<? extends BOI> classTip,
boolean unmodifiable) |
static java.util.Map |
toMap(BOLoaderI loader,
java.lang.Long boid,
java.lang.Class<? extends BOI> classTip)
Returns a
Map containing the BO for the given Id keyed by its Id |
static java.util.Map |
toMap(BOLoaderI loader,
java.lang.Long boid,
java.lang.Class<? extends BOI> classTip,
boolean unmodifiable) |
static java.util.Map |
toMap(java.util.Collection col)
Returns a
Map containing the BOs in the passed Collection, keyed by their Ids, ordered by their Id |
static java.util.Map |
toMap(java.util.Collection col,
boolean unmodifiable) |
static java.util.Map |
toRelationMapRO()
Returns an unmodifiable sorted
Map with the same entries as the passed Map,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(BO bo)
Returns an unmodifiable
Map containing the passed BO, keyed by its Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(BO[] bos)
Returns an unmodifiable
Map containing the passed BOs, keyed by their Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(BOLoaderI loader,
long[] ids,
java.lang.Class<? extends BOI> classTip)
Returns an unmodifiable
Map containing the BOs for the given Ids, keyed by the Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(BOLoaderI loader,
java.lang.Long[] ids,
java.lang.Class<? extends BOI> classTip)
Returns an unmodifiable
Map containing the BOs for the given Ids keyed by the Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(BOLoaderI loader,
java.lang.Long boid,
java.lang.Class<? extends BOI> classTip)
Returns an unmodifiable
Map containing the BO for the given Id, keyed by its Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(java.util.Collection col)
Returns an unmodifiable
Map containing the BOs in the passed Collection, keyed by their Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation. |
static java.util.Map |
toRelationMapRO(java.util.Map m) |
java.lang.String |
toString() |
void |
undelete()
Recursively marks this and any BOs in dependent many-relations as not (soft) deleted.
|
void |
verifyOnClient(BasicClientContextI ctx) |
void |
verifyOnServer(java.lang.Long nodeNumber,
Benutzer user,
Transaction tr) |
java.lang.RuntimeException |
wrapIfGroovy(java.lang.RuntimeException re,
java.lang.String pn,
boolean fromGroovy) |
void |
writeExternal(java.io.ObjectOutput s)
For better transfer performance, the serialization is done via Externalizable interface.
|
getCrea, getLdel, getLmod, isDeleted, isLdel, setCrea, setLdel, setLdel, setLmod
getInstanceSpecificLocale, getInstanceSpecificPaths, l10n, l10n, l10n, l10n, l10n, l10n, l10n
contains, getAttribute, getAttribute, getCrea, getEntity, getEntity, isDeleted, isSubEntityOf, isSubEntityOf, toRelationMapRO
collectIds, collectIds, getCommaSeparatedIdList, toMap, toMap
collectDescribe, collectDescribe, conciseDesc, conciseDesc, conciseDesc, conciseDesc, describe, describe, describeAndConciseDesc, describeAndConciseDesc, describeAndConciseDesc, describeAndConciseDesc, describeAndConciseDesc, describeNE, describeNE, join, join, join, notEmptyDescription
public static final BO[] EMPTY_ARRAY
public static final java.lang.ThreadLocal doExWriteLRMFunction
public static final java.math.BigDecimal D_MINUS_1
public static final java.math.BigDecimal D_0
public static final java.math.BigDecimal D_1
public static final java.math.BigDecimal D_5
public static final java.math.BigDecimal D_10
public static final java.math.BigDecimal D_100
public static final java.math.BigDecimal D_1000
public static final java.math.BigDecimal D_10000
public static final java.lang.Float F_0
public static final java.lang.Float F_1
public static final java.lang.Long L_0
public static final java.math.BigDecimal D_ZERO
public static final java.math.BigDecimal D_ONE
public static final java.math.BigDecimal D_MINUS_ONE
public static final de.ipcon.db.core.NullIterator NULL_ITERATOR
public static final NullAggregate NULL_AGGREGATE
public static final java.lang.String BLOB_KEY
public static final java.lang.String CANCEL_RECALC_CALLED
public static final java.lang.String L10N_KEY_BO_WITH_PROTECTED_CONSTRUCTOR
public static final java.lang.String L10N_KEY_BO_INSTANTIATION
public java.util.Iterator getNullIterator()
public static BO ofStub(BO bo)
public void verifyOnServer(java.lang.Long nodeNumber, Benutzer user, Transaction tr)
verifyOnServer
in interface SaveVetoI
public void verifyOnClient(BasicClientContextI ctx)
verifyOnClient
in interface SaveVetoI
public void beforeVerifyOnClient(BasicClientContextI ctx) throws SaveException
SaveAwareI
BO
s of the to-be-saved Transaction
(only!) by Client#saveBO()
(that is only from the Solstice GUI client!) before the SaveVetoI.verifyOnClient(BasicClientContextI)
calls or the actual saving is done.beforeVerifyOnClient
in interface SaveAwareI
ctx
- the client context from which the saving is doneSaveException
public void afterVerifyOnClient(BasicClientContextI ctx) throws SaveException
SaveAwareI
BO
s of the to-be-saved Transaction
(only!) by Client#saveBO()
(that is only from the Solstice GUI client!) after the SaveVetoI.verifyOnClient(BasicClientContextI)
calls have been performed but before the actual saving is done.afterVerifyOnClient
in interface SaveAwareI
ctx
- the client context from which the saving is doneSaveException
public void beforeVerifyOnServer(java.lang.Long nodeNumber, Benutzer user, Transaction tr) throws SaveException
beforeVerifyOnServer
in interface SaveAwareI
SaveException
public void afterVerifyOnServer(java.lang.Long nodeNumber, Benutzer user, Transaction tr) throws SaveException
afterVerifyOnServer
in interface SaveAwareI
SaveException
public void afterSaveOnClient(BasicClientContextI ctx, SaveException failure) throws SaveException
SaveAwareI
BO
s of the saved Transaction
(only!) by Client#saveBO()
(that is
only from the Solstice GUI client!) after the actual saving has been done or was canceled due to an "application
level" error.afterSaveOnClient
in interface SaveAwareI
ctx
- the client context from which the saving is donefailure
- if not null the SaveException
that was thrown during saving; if null the saving was
finished successfullySaveException
public void afterSaveOnServer(java.lang.Long nodeNumber, Benutzer user, Transaction tr, SaveException failure) throws SaveException
SaveAwareI
Transaction.fireAfterSave(Long, Benutzer, SaveException)
by 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.afterSaveOnServer
in interface SaveAwareI
nodeNumber
- the node number of the server on which the saving is performeduser
- the user in whose context the transaction was savedtr
- the already persisted transactionfailure
- if not null the SaveException
that was thrown during saving, for example because of some
failed SaveVetoI.verifyOnServer(Long, Benutzer, Transaction)
checks;
if null the saving was finished successfullySaveException
public java.lang.Long getId()
Synchable
getId
in interface Identifiable
getId
in class Synchable
public void setId(java.lang.Long newId)
public void setId(java.lang.Long newId, boolean iKnowWhatImDoing)
public final boolean isNew()
BOI
public boolean cancelCheckConstraints()
CBOAttribute
at the moment to skip read-only-checks
in setValue, add/removeRelationObject and clearRelation.cancelCheckConstraints
in interface BOI
public boolean isMandatory(AttributeI att)
AttributeI
is mandatory in the context of this BO
(for the UI and access via the schema).
Please note that the schema-defined, not BO-related mandatories are taken into account here as well,
i.e. the method will consistently return true if the attribute is marked in the schema as
unless overridden in a subclass. Subclasses may override this method to add their own rules. If no rule exists in the subclass, the decision should always be delegated to super instead of just returning false to avoid inadvertenly breaking the rules defined in super-classes or the schema. You must never change the signature of this method, as subclasses override this and a lot of code would break or need to be adjusted.
isMandatory
in interface BOI
AttributeI
is mandatory in the context of this BO
de.ipcon.tools.MissingArgumentException
- if no attribute was passedpublic boolean isReadOnly(AttributeI att)
AttributeI
is read-only in the context of this BO
(for the UI and access via the schema).
Please note that the schema-defined, not BO-related read-onlies are taken into account here as well,
i.e. the method will return false if a virtual attribute is marked in the schema as
unless overridden in a subclass. Subclasses may override this method to add their own rules. If no rule exists in the subclass, the decision should always be delegated to super instead of just returning false to avoid inadvertenly breaking the rules defined in super-classes or the schema. You must never change the signature of this method, as subclasses override this and a lot of code would break or need to be adjusted.
isReadOnly
in interface BOI
AttributeI
is read-only in the context of this BO
de.ipcon.tools.MissingArgumentException
- if no attribute was passedpublic boolean isWriteable(AttributeI att)
AttributeI
is writeable (i.e. a value for the attribute
may be written to the database) in the context of this business object (BO) by calling the client-side
PermissionHandlerI.checkWriteAllowed(BOI, String)
and testing the result via
PermissionHandlerDecisionI.granted()
.
Additionally the method defaults to true if the given AttributeI
is not persistent
(i.e. it is an npattr) or no client-side PermissionHandlerI
can be determined.
Please note that this method is not just the inversion of ::isReadOnly(AttributeI)
,
as it does not ask the AttributeI itself if it is read-only but only takes into account the
PermissionHandlerI
of the SchemaI
for this BO.
Subclasses may override this method to add their own rules. If no rule exists in the subclass,
the decision should always be delegated to super instead of just returning false to avoid
inadvertenly breaking the rules defined in super-classes.
You must never change the signature of this method, as subclasses override this and a lot of code
would break or need to be adjusted.AttributeI
is writeable in the context of this BO
de.ipcon.tools.MissingArgumentException
- if no attribute was passedpublic boolean isVisible(AttributeI att)
AttributeI
is visible in the UI (i.e. it may be read
from the database) in the context of this business object (BO) by calling the client-side
PermissionHandlerI.checkReadAllowed(BOI, String)
and testing the result via
PermissionHandlerDecisionI.granted()
.
Additionally the method defaults to true if no client-side PermissionHandlerI
can be determined.
Subclasses may override this method to add their own rules. If no rule exists in the subclass,
the decision should always be delegated to super instead of just returning false to avoid
inadvertenly breaking the rules defined in super-classes.
You must never change the signature of this method, as subclasses override this and a lot of code
would break or need to be adjusted.public final boolean isTemporary()
isTemporary
in interface BOI
public final boolean hasTempId()
public final boolean hasTempIdForNewBOs()
public final boolean hasBOAssignedTempId()
public final boolean hasSessionAssignedTempId()
public static final boolean isTempId(java.lang.Long l)
public static final boolean isTempIdForNewInstance(java.lang.Long l)
de.ipcon.mytism.MyTISMContantsI.INITIAL_TEMP_ID_BO
).public static final boolean isBOAssignedTempId(java.lang.Long l)
public static final boolean isSessionAssignedTempId(java.lang.Long l)
public int getBOVersion()
BOI
getBOVersion
in interface BOI
public void slim()
public void slim(java.util.HashSet rechash)
public void slim(java.util.HashSet rechash, boolean force)
public void slim(boolean force)
public final void acquireTxWriteLock()
public final void releaseTxWriteLock()
public java.lang.Object clone() throws java.lang.CloneNotSupportedException
public java.lang.Class<? extends BOI> getClazz()
public final boolean needsReload()
public final boolean isStub()
public BO stub()
public BO destub(BOLoaderI bol)
bol
- the BOLoaderI to load the "real" BO withpublic java.util.Map requireNonEmptyRelation(java.lang.String attPath) throws de.ipcon.tools.MissingArgumentException
attPath
- the attribute path to a many-relation to checkjava.lang.IllegalStateException
- if schema is missing.java.lang.IllegalArgumentException
- if the given attribute path does not point to a many-relationAttributeResolveException
- if an attribute along the attPath is unknown.de.ipcon.tools.MissingArgumentException
- if the relation is emptypublic java.lang.Object requireNonNullAttribute(java.lang.String attPath) throws de.ipcon.tools.MissingArgumentException
attPath
- the attribute path to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if an attribute along the attPath is unknown.de.ipcon.tools.MissingArgumentException
- if the value is nullpublic void requireNonNullAttributes(java.lang.String attPath1, java.lang.String attPath2) throws de.ipcon.tools.MissingArgumentException
attPath1
- the first attribute path to checkattPath2
- the second attribute path to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if one of the attributes along the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if a value is nullpublic void requireNonNullAttributes(java.lang.String attPath1, java.lang.String attPath2, java.lang.String attPath3) throws de.ipcon.tools.MissingArgumentException
attPath1
- the first attribute path to checkattPath2
- the second attribute path to checkattPath3
- the third attribute path to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if one of the attributes along the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if a value is nullpublic void requireNonNullAttributes(java.lang.String attPath1, java.lang.String attPath2, java.lang.String attPath3, java.lang.String attPath4) throws de.ipcon.tools.MissingArgumentException
attPath1
- the first attribute path to checkattPath2
- the second attribute path to checkattPath3
- the third attribute path to checkattPath4
- the fourth attribute path to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if one of the attributes along the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if a value is nullpublic void requireNonNullAttributes(java.lang.String attPath1, java.lang.String attPath2, java.lang.String attPath3, java.lang.String attPath4, java.lang.String attPath5) throws de.ipcon.tools.MissingArgumentException
attPath1
- the first attribute path to checkattPath2
- the second attribute path to checkattPath3
- the third attribute path to checkattPath4
- the fourth attribute path to checkattPath5
- the fifth attribute path to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if one of the attributes along the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if a value is null@Deprecated public void requireNonNullAttributes(java.lang.String[] attPaths) throws de.ipcon.tools.MissingArgumentException
attPaths
- a String-array with all attribute path to check for being non-null on this BOjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if an attribute along one of the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if a value is nullpublic static BO[] requireNonNullAttributes(BO[] bos, java.lang.String[] attPaths) throws de.ipcon.tools.MissingArgumentException
bos
- the BOs to check for non null propertiesattPaths
- the attribute paths to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if an attribute along on of the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if one or more values were null on one or more BOspublic static java.util.Collection requireNonNullAttributes(java.util.Collection bos, java.util.Collection attPaths) throws de.ipcon.tools.MissingArgumentException
bos
- the BOs to check for non null propertiesattPaths
- the attribute paths to checkjava.lang.IllegalStateException
- if schema is missing.AttributeResolveException
- if an attribute along on of the attPaths is unknown.de.ipcon.tools.MissingArgumentException
- if one or more values were null on one or more BOspublic static final void markCompoundChangeInProgress()
public static final void releaseCompoundChangeInProgress()
public static final boolean isCompoundChangeInProgress()
public static java.lang.String describeId(BO bo)
public static java.lang.String describeId(BO bo, java.lang.String pattern)
public static java.lang.String describeId(BO bo, java.lang.String pattern, boolean evenWhenStub)
public static java.lang.String describeId(BO bo, java.lang.String pattern, boolean evenWhenStub, java.lang.String nullString)
public static java.lang.String describe(BO bo)
public static java.lang.String describe(BO bo, java.lang.String pattern)
public static java.lang.String describe(BO bo, java.lang.String pattern, boolean evenWhenStub)
public static java.lang.String describe(BO bo, java.lang.String pattern, boolean evenWhenStub, java.lang.String nullString)
public static java.lang.String describe(BO bo, java.lang.String pattern, boolean evenWhenStub, java.lang.String nullString, boolean addId)
public static java.lang.String describeNE(BO bo)
public static java.lang.String describeNE(BO bo, java.lang.String pattern)
public static java.lang.String describeNE(BO bo, java.lang.String pattern, boolean evenWhenStub)
public static java.lang.String describeNE(BO bo, java.lang.String pattern, boolean evenWhenStub, java.lang.String nullString)
public static java.lang.String describeNE(BO bo, java.lang.String pattern, boolean evenWhenStub, java.lang.String nullString, boolean addId)
public java.lang.String describeId()
public java.lang.String describeId(java.lang.String _pattern)
public java.lang.String describeId(java.lang.String _pattern, boolean _evenWhenStub)
public java.lang.String describeId(java.lang.String _pattern, boolean _evenWhenStub, SchemaI _schema)
public java.lang.String describe()
DescribableI
describe
in interface DescribableI
public java.lang.String describe(java.lang.String _pattern)
DescribableI
describe
in interface DescribableI
public java.lang.String describe(java.lang.String _pattern, boolean _evenWhenStub)
public java.lang.String describe(java.lang.String _pattern, boolean _evenWhenStub, SchemaI _schema)
public java.lang.String describe(java.lang.String _pattern, boolean _evenWhenStub, SchemaI _schema, boolean _addId)
public SchemaI getRootLoaderSchema()
getRootLoaderSchema
in interface BOI
public SchemaI getSchema()
getSchema
in interface BOI
getSchema
in interface SchemaProviderI
public PermissionHandlerI getPermissionHandler()
PermissionHandlerI
for this BO
, i.e. the one of the
SchemaI
of this BO's BOLoaderI
or null if this BO
has no BOLoaderI
or SchemaI
.PermissionHandlerI
for this BO
public final boolean cancelRecalc()
public final boolean cancelRecalcViaLoadingTransaction()
public boolean isCurrentTransactionUnderAdminControl()
public int getSizeFast(java.lang.String _what)
_what
- Name of the many-relation-attribute, for which the size shall be determinedpublic static boolean hasRelationObjects(java.util.Map m)
public static boolean hasRelationObjects(java.util.Map m, boolean ignoreDeleted)
public static void exWriteString(java.io.ObjectOutput s, java.lang.String val) throws java.io.IOException
s
- the output to stream the String intoval
- a String, can be null and length can be >64kjava.io.IOException
public static java.lang.String exReadString(java.io.ObjectInput s) throws java.io.IOException
s
- the Input to read fromjava.io.IOException
public final BackendBOLoaderWithPersistenceHandlerI getBackendBOLoaderWithPersistenceHandler()
public final boolean isServerSideAndLoadedReadOnly()
public final BOLoaderI getBOLoader()
public void setBOLoader(BOLoaderI newLoader)
public void setBOLoaderNoCascade(BOLoaderI newLoader)
public void setBOLoaderNoCascade(BOLoaderI newLoader, boolean ignoreAlreadyBOAssignedTempId)
public void readExternal(java.io.ObjectInput s) throws java.lang.ClassNotFoundException, java.io.IOException
readExternal
in interface java.io.Externalizable
java.lang.ClassNotFoundException
java.io.IOException
public void writeExternal(java.io.ObjectOutput s) throws java.io.IOException
writeExternal
in interface java.io.Externalizable
java.io.IOException
public int hashCode()
The hash code is calculated using only the Id
attribute of the BO, as other attributes are subject to change.
This approach ensures consistency and avoids unexpected behavior when the object is used as a key in a HashMap.
It's important to note that the Id
attribute is immutable once the BO is no longer considered new.
However, caution is advised when using a BO as a key in a HashMap while it is still new, as its Id
will change upon saving.
hashCode
in class java.lang.Object
Id
attribute of this BO.public static final boolean nullSafeEquals(java.lang.Object o1, java.lang.Object o2)
#nullSafeEqualsBO(BO, BO)
is called,
otherwise the Objects are passed to NullCheckTools.nullSafeEquals(Object, Object)
.public static final boolean nullSafeEqualsBO(BOI bo1, BOI bo2)
equals(Object)
.public static final boolean nullSafeEqualsBO(BOI bo1, BOI bo2, boolean idComparisonOnly)
public final boolean equalsBO(BOI bo)
BOI
nullSafeEqualsBO(BOI, BOI)
is called with this BOI as first parameter and the passed BOI as second one.public final boolean equalsBO(BOI bo, boolean idComparisonOnly)
BOI
nullSafeEqualsBO(BOI, BOI)
is called with this BOI as first parameter and the passed BOI as second one.public boolean equals(java.lang.Object o)
equals
in class java.lang.Object
o
- a BO which should be compared to this objectpublic boolean equalPayload(BO s)
public boolean equalPayload(BO other, java.util.Collection<java.lang.String> attrs)
other
- a BO to compare the payload of this BO withattrs
- a Collection of Strings representing the attribute names for
the payload values to compareotherAttrs
- a Collection of Strings representing the attribute names for
the payload values of the passed other BO (optional, if not given
the attrs are used for the other BO as well)public boolean equalPayload(BO other, java.util.Collection<java.lang.String> attrs, java.util.Collection<java.lang.String> otherAttrs)
public boolean equalPayload(BO other, java.lang.String[] attributeNames)
other
- a BO to compare the payload of this BO withattributeNames
- a String array representing the attribute names for
the payload values to compareotherAttrs
- a String array representing the attribute names for
the payload values of the passed other BO (optional, if not given
the attrs are used for this BO and the other BO)public boolean equalPayload(BO other, java.lang.String[] attributeNames, java.lang.String[] otherAttrs)
public static boolean nullSafeContainsBO(java.util.Map<java.lang.Long,? extends BOI> m, BOI bo)
public static boolean nullSafeContainsBO(java.util.Collection<? extends BOI> c, BOI bo)
public static int nullSafeCompareTo(java.lang.Comparable first, java.lang.Object second)
public static int nullSafeCompareTo(java.lang.Comparable first, java.lang.Object second, boolean nullIsSmaller)
public BO deepClone()
public BO createCopy()
BO
. If a Transaction
is
given, the copy will first be included in this TX to record all the copy
operations. Uses copyFrom()
to copy the values from this to
the new instance.
CAUTION: *ALL* n-1-reachable objects will be copied as well!
Attention: Does not honour the "omitOnCopy" flag from the schema!_tx
- a Transaction
to include the newly created copy
in and to record the copy operationsBO
de.ipcon.db.core.BO#copyFrom()
,
de.ipcon.db.core.Transaction#includeCopy()
public BO createCopy(Transaction _tx)
@Deprecated public void copyFrom(BO s)
BO
into
this BO
. If a Transaction
is given previously
already existing objects that are referenced by -1 relations are frapped
via _tx.frapFromCache() before the reference is set in the copy; for new
objects a copy of that object is also created in the
Transaction
via createCopy()
.
Automatically overwritten in generated subclasses.
Attention: Does not honour the "omitOnCopy" flag from the schema!s
- the BO
whose data shall be copied to this
BO
_tx
- a Transaction
to frap or include relation objects
with/in; may be nullcreateCopy()
,
de.ipcon.db.core.Transaction#includeCopy()
public void copyFrom(BO s, Transaction _tx)
public final void markDelete()
public final void markUndelete()
public void delete()
public void undelete()
public void setTempId()
public static java.lang.Long nextTempId()
public static BO frap(BOLoaderI bol, BO bo)
bol
- the BOLoaderI to be used for frappingbo
- the BO to be frappedTransaction.frapFromCache(BO)
public final Transaction getTransaction()
public Transaction needTransactionInclusion()
NotIncludedInTransactionException
- if this BO is not included in a Transactionpublic Transaction getLoadingTransaction()
public Transaction needLoadingTransaction()
NotLoadedByTransactionException
- if this BO has not been loaded by or is not included in a Transaction.public final boolean hasActiveTransaction()
public void includeInTransaction(Transaction includeInTx)
includeInTx
- the Transaction to include this BO intopublic boolean includeAllowed(Transaction includeInTx)
includeInTx
- the Transaction to check if inclusion into it is allowedpublic void commitTransaction()
public ManagedFileI copyBLOBFrom(BO blobSource) throws java.io.IOException
src
- a BO to retrieve the BLOB data from.java.io.IOException
public final ManagedFileI storeBLOB(java.io.InputStream is) throws java.io.IOException
InputStream
and replaces the current BLOB
(if any) of this BO, if it is included in a transaction.is
- the InputStream to retrieve the BLOB data from; will be closed
after the data was read from it.java.io.IOException
public final ManagedFileI storeBLOB(java.io.File f) throws java.io.IOException, java.io.FileNotFoundException
f
- a File to retrieve the BLOB data from.java.io.IOException
java.io.FileNotFoundException
public final ManagedFileI storeBLOB(byte[] bytes) throws java.io.IOException
storeBLOB(InputStream)
bytes
- A byte-array of datajava.io.IOException
public final ManagedFileI storeBLOB(java.lang.String s) throws java.io.IOException
storeBLOB(byte[])
with the result of e.g. String.getBytes('UTF-8')s
- Some String datacharsetName
- The name of the charset to use for getting the bytes representing the passed Stringjava.io.IOException
public final ManagedFileI storeBLOB(java.lang.String s, java.lang.String charsetName) throws java.io.IOException
java.io.IOException
public final ManagedFileI removeBLOB()
public final void forgetTransientBLOBHandle()
public final boolean hasBLOB()
public final boolean hasBLOBOnServerSide()
public final VFile getBLOBInfo()
public final byte[] getBLOB()
null
is returned.
Delegates to getBytes()
public final long getBLOB(java.io.OutputStream target) throws java.io.IOException
public final long getBLOB(java.io.OutputStream target, boolean closeOS) throws java.io.IOException
public java.lang.String getBLOBAsEncodedString(java.lang.String charsetName)
null
is returned.charsetName
- a String representing the charset to use for encoding the bytes as Stringpublic java.lang.String getBLOBAsEncodedString(java.nio.charset.Charset charset)
null
is returned.charset
- the Charset to use for encoding the BLOB bytes as Stringpublic java.lang.String getBLOBAsUTF8EncodedString()
null
is returned.public final BLOBInputStream getBLOBAsInputStream() throws java.io.IOException
BLOBInputStream::isEmpty
to avoid problems down the road.java.io.IOException
public final BLOBDataInputStream getBLOBAsDataInput() throws java.io.IOException
BLOBDataInputStream::isEmpty
to avoid problems down the road.java.io.IOException
public final long getBLOB(java.io.DataOutput target) throws java.io.IOException
java.io.IOException
public final long getBLOB(java.io.DataOutput target, boolean closeOS) throws java.io.IOException
java.io.IOException
public final byte[] getBytes()
null
is returnedpublic final void invalidateBLOBCache()
public final void exportBLOB(java.io.File target) throws java.io.IOException
File
.target
- File to be written to{@link
- java.io.IOException} can occur when reading out the BLOB as InputStreamjava.io.IOException
public final void bumpVersion()
BOI
bumpVersion
in interface BOI
public final void notifyMessageBus(java.lang.String attributeName)
notifyMessageBus(AttributeI, Object, Object)
to lookup the attribute for the given
name.
Attribute has to exist on this Entity, no paths allowedjava.lang.IllegalStateException
- if the attribute is not found or is an attribute pathpublic final void notifyMessageBus(java.lang.String attributeName, java.lang.Object newValue)
public final void notifyMessageBus(java.lang.String attributeName, java.lang.Object newValue, java.lang.Object oldValue)
public final void notifyMessageBus(AttributeI attr)
attr
- the nonnull attributeI to notify a change fornewValue
- the newValue the attribute on this BO was changed to. For ManyRelations, a BO that was added.oldValue
- the optional oldValue from before the change. Can be null if not available. For ManyRelations, a BO that was removed.de.ipcon.tools.MissingArgumentException
- if no attribute was passedpublic final void notifyMessageBus(AttributeI attr, java.lang.Object newValue)
public final void notifyMessageBus(AttributeI attr, java.lang.Object newValue, java.lang.Object oldValue)
public final void notifyMessageBusOfAdd(AttributeI attr, BO added)
attr
- the virtual attribute the BO was added toadded
- the BO that was addedde.ipcon.tools.MissingArgumentException
- if no attribute or BO was passedpublic final void notifyMessageBusOfRemove(AttributeI attr, BO removed)
attr
- the virtual attribute the BO was removed fromremoved
- the BO that was removedde.ipcon.tools.MissingArgumentException
- if no attribute or BO was passedpublic BOWrapperI getDescribingBOWrapper(java.lang.String frmat)
frmat
- a string in CBOFormat stylepublic BOWrapperI getDescribingBOWrapper()
public AggregateFunctionI aggregate(java.lang.String s, java.lang.String pathlist)
public AggregateFunctionI aggregate(java.lang.String s, java.lang.String pathlist, java.lang.String parameters)
public AggregateFunctionI aggregate(AggregateFunctionI a, java.lang.String pathlist)
public final java.lang.String conciseDesc()
DescribableI
conciseDesc
in interface DescribableI
public final java.lang.String conciseDesc(boolean showRuntimeInfo)
DescribableI
conciseDesc
in interface DescribableI
showRuntimeInfo
- if true will also include if DescribableI is
a stub or if the DescribableI needs to be reloaded to get an instance with the
actual subclass and will include the hashCode.public final java.lang.String conciseDesc(boolean showRuntimeInfo, boolean showCreaLmod)
DescribableI
conciseDesc
in interface DescribableI
showRuntimeInfo
- if true will also include if DescribableI is
a stub or if the DescribableI needs to be reloaded to get an instance with the
actual subclass and will include the hashCode.showCreaLmod
- if false will not show Crea and Lmod
values; if true these values will be appended to the description.public final java.lang.String conciseDesc(boolean showRuntimeInfo, boolean showCreaLmod, boolean useClientSideId)
DescribableI
conciseDesc
in interface DescribableI
showRuntimeInfo
- if true will also include if DescribableI is
a stub or if the DescribableI needs to be reloaded to get an instance with the
actual subclass and will include the hashCode.showCreaLmod
- if false will not show Crea and Lmod
values; if true these values will be appended to the description.useClientSideId
- if true the Id that is known on client-side is used; on
server-side we might already have an unsaved positive Id, but for the
description e.g. in a server-side error message it might be less confusing
to use the Id that is known on the client; e.g. when used inside a
SaveVetoException it might otherwise be very confusing to report an Id that
is discarded again and never used in the database ever.public static final java.lang.String conciseDesc(BO bo)
public static final java.lang.String conciseDesc(BO bo, boolean showRuntimeInfo)
public static final java.lang.String conciseDesc(BO bo, boolean showRuntimeInfo, boolean showCreaLmod)
public static final java.lang.String conciseDesc(BO bo, boolean showRuntimeInfo, boolean showCreaLmod, boolean useClientSideId)
public java.lang.String toString()
toString
in class java.lang.Object
public java.lang.Object $(java.lang.String attrName)
public java.util.List<java.lang.Object> $$(java.lang.String attrPath)
attrPath
- the attribute path for which to fetch the value via projection from the serverpublic java.util.Iterator $$ri(java.lang.String attrPath)
attrPath
- the attribute path to fetch an iterator formapToFill
- (optional) a map to fill with the results of the iterator while iteratingpublic java.util.Iterator $$ri(java.lang.String attrPath, java.util.Map mapToFill)
public java.util.Map $$r(java.lang.String attrPath)
public BO $$bo(java.lang.String attrPath)
public java.lang.Object $$o(java.lang.String attrPath)
public java.lang.String getAsString(java.lang.String attrName)
public java.lang.Object propertyMissing(java.lang.String pn)
public java.lang.RuntimeException wrapIfGroovy(java.lang.RuntimeException re, java.lang.String pn, boolean fromGroovy)
public void $(java.lang.String attrName, java.lang.Object value)
public void $(java.util.Map attrs2values)
public void setAsString(java.lang.String attrName, java.lang.String value)
public void propertyMissing(java.lang.String s, java.lang.Object value)
public void _set(java.lang.String pn, java.lang.Object value, boolean fromGroovy)
public void add(java.lang.String attrName, BO value)
public void remove(java.lang.String attrName, BO value)
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value, int explicitVersion, java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue)
bumpVersion()
.
All values are put into a map using the name as key.
Those values are only transient regarding the persistence in the database.
Transient properties created by the client will never be available on the server.
Upon frapping / deepCloning any stored value that cannot be serialized will be dropped
and replaced by a null-value while logging a warning about that.
So keep in mind that non-serializable transient properties might get "lost" then.name
- the name of the transient propertyvalue
- the value of this propertyexplicitVersion
- the version for which the transient property shall be sethousekeeperForPreviousVersionedValue
- a Consumer that is called when an outdated value is
evicted, enabling the caller to do some housekeeping on the previous valuede.ipcon.db.core.Transaction#bumpVersion()
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value, java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue)
name
- the name of the transient propertyvalue
- the value of this propertyhousekeeperForPreviousVersionedValue
- a Consumer that is called when an outdated value is
evicted, enabling the caller to do some housekeeping on the previous valuede.ipcon.db.core.Transaction#bumpVersion()
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value)
bumpVersion()
.
All values are put into a map using the name as key.
Those values are only transient regarding the persistence in the database.
Transient properties created by the client will never be available on the server.
Upon frapping / deepCloning any stored value that cannot be serialized will be dropped
and replaced by a null-value while logging a warning about that.
So keep in mind that non-serializable transient properties might get "lost" then.setTransientProperty
in interface BOI
name
- the name of the transient propertyvalue
- the value of this propertyversioned
- if true, then this value is only valid for this BOVersion.explicitVersion
- the version for which the transient property shall be setde.ipcon.db.core.Transaction#bumpVersion()
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value, boolean versioned)
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value, boolean versioned, int explicitVersion)
public java.lang.Object setTransientProperty(java.lang.String name, java.lang.Object value, boolean versioned, int explicitVersion, java.util.function.Consumer<java.lang.Object> housekeeperForPreviousVersionedValue)
public java.lang.Object computeTransientPropertyIfAbsent(java.lang.String name, java.util.function.Supplier<java.lang.Object> computer, boolean versioned)
public java.lang.Object getTransientProperty(java.lang.String name)
getTransientProperty
in interface BOI
name
- the name of the transient property of which the value should be returnedrawversioned
- if true the raw WrappedValue is returned instead of the unwrapped real valuepublic java.lang.Object getTransientProperty(java.lang.String name, boolean rawwrapped)
public WrappedValue getWrappedTransientProperty(java.lang.String name, boolean filterExpired)
public boolean hasTransientProperty(java.lang.String name)
BOI
hasTransientProperty
in interface BOI
name
- the name of the transient property that should be checkedpublic boolean hasTransientPropertyUnfiltered(java.lang.String name)
BOI
hasTransientPropertyUnfiltered
in interface BOI
name
- the name of the transient property that should be checkedpublic void consumeAndAssureTransientPropertyExists(java.lang.String name, java.util.function.Consumer operation, java.lang.Object[] args)
BOI
If the Consumer itself throws an (unchecked) exception, the exception is rethrown.
Typically called for running default value expression and init script of scripted attributes.
consumeAndAssureTransientPropertyExists
in interface BOI
public final java.lang.Object cacheLocally(java.lang.String key, java.util.function.Supplier<java.lang.Object> func)
Curry
.key
- the key to find the value by in the local cachefunc
- a Supplier that may be called to retrieve the result to cacheversion
- a boolean specifying if the cached result shall be invalidated if the BO
version of this BO changes.IRuntimeException
- if an error is thrown during the initial calculation of the
result of the given Supplierpublic final java.lang.Object cacheLocally(java.lang.String key, java.util.function.Supplier<java.lang.Object> func, boolean versioned)
public final java.lang.Object cacheLocallyAndThrowUnwrappedCause(java.lang.String key, java.util.function.Supplier<java.lang.Object> func) throws java.lang.Throwable
#cacheLocally(String, Supplier
but throws the originally
encountered exception that was potentially thrown during the initial calculation of the
result of the given Supplier instead of an IRuntimeException that otherwise would wrap that.java.lang.Throwable
public final java.lang.Object cacheLocallyAndThrowUnwrappedCause(java.lang.String key, java.util.function.Supplier<java.lang.Object> func, boolean versioned) throws java.lang.Throwable
java.lang.Throwable
public final java.lang.Object cacheLocallyAndThrowUnwrappedUncheckedCause(java.lang.String key, java.util.function.Supplier<java.lang.Object> func)
#cacheLocally(String, Supplier
but throws the originally
encountered exception that was potentially thrown during the initial calculation of the
result of the given Supplier - if it is a unchecked one - instead of an IRuntimeException
that otherwise would wrap that. Does throw the wrapped Exception though, if a checked one
is wrapped.public final java.lang.Object cacheLocallyAndThrowUnwrappedUncheckedCause(java.lang.String key, java.util.function.Supplier<java.lang.Object> func, boolean versioned)
public java.util.Map<java.lang.Long,BP> getProcs()
public java.util.Iterator<BP> getProcsIterator()
public java.util.Map<java.lang.Long,BP> getInvolvedInProcs()
public java.util.Iterator<BP> getInvolvedInProcsIterator()
public java.lang.String getBadge()
public java.lang.String getBadge(int i)
public void setBadge(java.lang.String s)
public void setBadge(java.lang.String s, int i)
public java.lang.String getBadge2()
public void setBadge2(java.lang.String s)
public java.lang.String getBadge3()
public void setBadge3(java.lang.String s)
public java.lang.String getBadge4()
public void setBadge4(java.lang.String s)
public Benutzer getCreatedBy()
public Benutzer getLastModifiedBy()
public Benutzer getBLOBCreatedBy()
public java.util.Date getBLOBCreatedOn()
public Benutzer getBLOBDeletedBy()
public java.util.Date getBLOBDeletedOn()
public Benutzer getBLOBLastModifiedBy()
public java.util.Date getBLOBLastModifiedOn()
public java.lang.String getCreatedModifiedText()
public java.util.Map<java.lang.Long,IssueReport> getAsBOInIssueReports()
public java.util.Iterator<IssueReport> getAsBOInIssueReportsIterator()
public static java.util.Map badge(java.util.Map _m, java.lang.String _badge)
public static java.util.Map badge(java.util.Map _m, java.lang.String _badge, int _i)
public static java.util.Map toMap(BOLoaderI loader, java.lang.Long boid, java.lang.Class<? extends BOI> classTip)
Map
containing the BO for the given Id keyed by its Idloader
- BOLoaderI
to load the BO withboid
- Long
representing the Id of the BO to loadclassTip
- the class of the BO to loadunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(BOLoaderI loader, java.lang.Long boid, java.lang.Class<? extends BOI> classTip, boolean unmodifiable)
public static java.util.Map toMap(BOLoaderI loader, java.lang.Long[] ids, java.lang.Class<? extends BOI> classTip)
Map
containing the BOs for the given Ids keyed by the Ids, ordered by their Idloader
- BOLoaderI
to load the BOs withids
- Long-array
with the Ids of the BOs to loadclassTip
- the class of the BOs to loadunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(BOLoaderI loader, java.lang.Long[] ids, java.lang.Class<? extends BOI> classTip, boolean unmodifiable)
public static java.util.Map toMap(BOLoaderI loader, long[] ids, java.lang.Class<? extends BOI> classTip)
Map
containing the BOs for the given Ids keyed by the Ids, ordered by their Idloader
- BOLoaderI
to load the BOs withids
- long-array
with the Ids of the BOs to loadclassTip
- the class of the BOs to loadunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(BOLoaderI loader, long[] ids, java.lang.Class<? extends BOI> classTip, boolean unmodifiable)
public static java.util.Map toMap(BO bo)
Map
containing the given BO keyed by its Idbo
- BO to wrap into a Mapunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(BO bo, boolean unmodifiable)
public static java.util.Map toMap(BO[] bos)
Map
containing the given BOs keyed by their Ids, ordered by their Idbos
- Array of BOsunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(BO[] bos, boolean unmodifiable)
public static java.util.Map toMap(java.util.Collection col)
Map
containing the BOs in the passed Collection, keyed by their Ids, ordered by their Idcol
- Collection<BO>
of BOsunmodifiable
- whether the returned Map shall be unmodifiable or not, defaults to trueMap<Long, BO>
public static java.util.Map toMap(java.util.Collection col, boolean unmodifiable)
public static java.util.Map toRelationMapRO(BOLoaderI loader, java.lang.Long boid, java.lang.Class<? extends BOI> classTip)
Map
containing the BO for the given Id, keyed by its Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed Id is null, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(BOLoaderI loader, java.lang.Long[] ids, java.lang.Class<? extends BOI> classTip)
Map
containing the BOs for the given Ids keyed by the Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed Collection is empty, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(BOLoaderI loader, long[] ids, java.lang.Class<? extends BOI> classTip)
Map
containing the BOs for the given Ids, keyed by the Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed Collection is empty, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(BO bo)
Map
containing the passed BO, keyed by its Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed BO is null, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(BO[] bos)
Map
containing the passed BOs, keyed by their Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed Collection is empty, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(java.util.Collection col)
Map
containing the BOs in the passed Collection, keyed by their Ids, ordered by their Id,
suitable for usage as return value of a getter for a read-only virtual relation.
If the passed Collection is empty, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO()
Map
with the same entries as the passed Map,
suitable for usage as return value of a getter for a read-only virtual relation.
If no Map is passed or the passed Map is empty, the Collections.emptyMap() is returned.public static java.util.Map toRelationMapRO(java.util.Map m)
public static BO getOrCreate(java.lang.Class<? extends BOI> clazz, BOLoaderI bol, java.util.Map attrs2values)
clazz
- of what Class (or subclass thereof) the wanted object must be.bol
- the BOLoaderI to set for newly created objects; if it is a
Transaction and includeIfTx is set modified or created objects will also
be included in this Transaction.attrs2values
- a Map with attribute names as keys and Objects as the
corresponding values that wanted objects should have and that are to be
set for newly created objects.bosHave
- a BO array of existing objects that may be the wanted one;
may be null if no such objects are known.attrsPrimary
- a Set of attribute names to make the comparison by if
the wanted object must match in only a subset of the attrs2values
attributes to be a fitting candidate. If null wanted objects must match
in all the attributes/values from attrs2values.includeIfTx
- if bol is a Transaction and this is given modified or
newly created objects are included in the Transaction; defaults to true.clazzToCreate
- if newly created object should not be of clazz but a
specific subclass thereof this desired subclass may be specified with this
parameter (for example the wanted object might be allowed to be of type
"Vehicle" that is a "Car", a "Bus" or a "Bicycle"; but if a new object
needs to be created if should always be of subclass "Car" and not
"Vehicle").public static BO getOrCreate(java.lang.Class<? extends BOI> clazz, BOLoaderI bol, java.util.Map attrs2values, BO[] bosHave)
public static BO getOrCreate(java.lang.Class<? extends BOI> clazz, BOLoaderI bol, java.util.Map attrs2values, BO[] bosHave, java.util.Set attrsPrimary)
public static BO getOrCreate(java.lang.Class<? extends BOI> clazz, BOLoaderI bol, java.util.Map attrs2values, BO[] bosHave, java.util.Set attrsPrimary, boolean includeIfTx)
public static BO getOrCreate(java.lang.Class<? extends BOI> clazz, BOLoaderI bol, java.util.Map attrs2values, BO[] bosHave, java.util.Set attrsPrimary, boolean includeIfTx, java.lang.Class<? extends BOI> clazzToCreate)
public static BO getOrCreate(java.lang.Class<? extends BOI> _clazz, Transaction _tx, java.util.Map _attrs2values)
public static BO getOrCreate(java.lang.Class<? extends BOI> _clazz, Transaction _tx, java.util.Map _attrs2values, java.util.Set _attrsPrimary)
public static BO newInstance(java.lang.Class<? extends BOI> clazz, BOLoaderI loader)
clazz
- the BO subclass to create an instance ofloader
- the BOLoaderI to set in the new instanceattrs2values
- a Map with attribute value pairs to set (optional)includeIfTx
- a boolean specifying if the instance shall be included in case
the passed BOLoaderI is a Transaction (defaults to true)public static BO newInstance(java.lang.Class<? extends BOI> clazz, BOLoaderI loader, java.util.Map attrs2values)
public static BO newInstance(java.lang.Class<? extends BOI> clazz, BOLoaderI loader, java.util.Map attrs2values, boolean includeIfTx)
public static BO newInstance(EntityI ent, BOLoaderI loader)
ent
- the EntityI to create an BO instance ofloader
- the BOLoaderI to set in the new instanceattrs2values
- a Map with attribute value pairs to set (optional)includeIfTx
- a boolean specifying if the instance shall be included in case
the passed BOLoaderI is a Transaction (defaults to true)public static BO newInstance(EntityI ent, BOLoaderI loader, java.util.Map attrs2values, boolean includeIfTx)
public boolean equalsRegardingAttrs(BO _bo, java.lang.String[] _attributeNames)
public static java.util.Collection filterDeleted(java.util.Collection col)
public static java.util.Collection filterDeleted(BO[] arr)
public static java.util.Collection filterDeleted(java.util.Map map)
public DBManEventProviderI getEventProvider()
public static DBManEventProviderI getEventProvider(BOLoaderI _bol)
public static CacheI getCacheNT(BOLoaderI bol, java.lang.String title, java.lang.Class clazz)
public static CacheI getCacheNT(BOLoaderI bol, java.lang.String title, java.lang.Class clazz, java.lang.String fetchQuery)
public static CacheI getCacheNT(BOLoaderI bol, java.lang.String title, java.lang.Class clazz, java.lang.String fetchQuery, java.lang.Class mapClass)
public static CacheI getCache(BOLoaderI bol, java.lang.String title, java.lang.Class clazz)
public static CacheI getCache(BOLoaderI bol, java.lang.String title, java.lang.Class clazz, java.lang.String fetchQuery)
public static CacheI getCache(BOLoaderI bol, java.lang.String title, java.lang.Class clazz, java.lang.String fetchQuery, java.lang.Class mapClass)
public SessionScopedCacheProviderI getCacheProvider()
public static SessionScopedCacheProviderI getCacheProvider(BOLoaderI bol)
public static java.util.List<ScriptImport> getDefaultScriptImportsList(java.lang.String packageNameBOs)
public static java.util.List<ScriptImport> getDefaultScriptImportsList(SchemaI schema)
public java.util.List getDefaultScriptImportsList()
public BOT getBot()
public void setBot(BOT $133)
public java.lang.Object getLazyData()
getLazyData
in interface LazyDataProviderI
public void setLazyData(java.lang.Object $134)
setLazyData
in interface LazyDataProviderI
public boolean isIgnoreModificationConstraints()
public void setIgnoreModificationConstraints(boolean $135)
Copyright © 2000-2025 OAshi S.à r.l. All Rights Reserved.