Package de.businesscode.bcdui.wrs.load
Class WrqBindingSetVirtual
java.lang.Object
de.businesscode.bcdui.wrs.load.WrqBindingSetVirtual
- All Implemented Interfaces:
BindingSet,WrqBindingSet,Serializable,Cloneable
- Direct Known Subclasses:
WrqBindingSetFromDerivedTable,WrqBindingSetFromTableReference
Represents a virtual BindingSet derived on runtime from parts of a Wrs
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface de.businesscode.bcdui.binding.BindingSet
BindingSet.SECURITY_OPS -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected Map<String,BindingItem> protected final SqlFromSubSelectprotected Stringprotected Set<StandardBindingSet>protected Stringprotected final SQLStatementWithParamsprotected StringFields inherited from interface de.businesscode.bcdui.binding.BindingSet
DEFAULT_DATABASE_SOURCENAME -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddRelation(Relation p_relation) adds a new relation into ArrayListvoidassurePermissionDefined(BindingSet.SECURITY_OPS operation) we check here if the application has set up the subjectSettings.voidassurePermitted(BindingSet.SECURITY_OPS operation) check if given operation is permitted according to permissions set on subject in scopeGets a BindingItem by its unique name and throws an Exception if it is not present.get(Collection<String> keys) Get binding items by ids.getBindingItemFromRelation(Relation pRelation, String itemName) Method getBindingItemFromRelationgetBindingItemNamesabstract StringGets the database name the table of the BindingSet is located in.Retrieves the list of key BindingItems for this binding set which may contain no entries.getName()Gets the unique name of the BindingSet.All non-virtual BindingSets that were used at the end, BindingGroups are being resolved to the actually used BindingSetsSQL alias of this BindingSet during this queryReturns a table expression and if it is a complex one (subselect with where for example) it may come with variables to be bound as host variablesabstract SQLStatementWithParamsgetSubjectFilterExpression(WrqInfo wrqInfo) Return SubjectFilters to be applied for our virtual BindingSetGets theSubjectFiltersdefinition for this BindingSet which may be null.Returns a table reference.A list of Wrq modifier classes to be applied on all requests for this BindingSet before generating the SQL This is completely transparent to the caller, the answer Wrs does show the original WrsRequestbooleanbooleantells if this binding-set contains an itembooleanTests if the BindingSet hat key BindingItems.booleanTells if the binding set has subject filters.booleanisAllowSelectAllColumnsbooleanisBackendCanBypassSubjectFilter
-
Field Details
-
tableName
-
name
-
sqlAlias
-
bindingItems
-
wrqModifiers
-
resolvedBindingSets
-
sqlStatementWithParams
-
currentSelect
-
-
Constructor Details
-
WrqBindingSetVirtual
- Throws:
Exception
-
-
Method Details
-
getResolvedBindingSets
Description copied from interface:BindingSetAll non-virtual BindingSets that were used at the end, BindingGroups are being resolved to the actually used BindingSets- Specified by:
getResolvedBindingSetsin interfaceBindingSet- Returns:
-
getSqlAlias
Description copied from interface:WrqBindingSetSQL alias of this BindingSet during this query- Specified by:
getSqlAliasin interfaceWrqBindingSet- Returns:
-
getName
Description copied from interface:BindingSetGets the unique name of the BindingSet.- Specified by:
getNamein interfaceBindingSet- Returns:
- The unique BindingSet name.
-
hasSubjectFilters
public boolean hasSubjectFilters()Description copied from interface:BindingSetTells if the binding set has subject filters.- Specified by:
hasSubjectFiltersin interfaceBindingSet- Returns:
- True, if there is at least one SubjectFilter inside this BindingSet.
-
getSubjectFilters
Description copied from interface:BindingSetGets theSubjectFiltersdefinition for this BindingSet which may be null.- Specified by:
getSubjectFiltersin interfaceBindingSet- Returns:
SubjectFiltersfor given BindingSet or null
-
getJdbcResourceName
Description copied from interface:BindingSetGets the database name the table of the BindingSet is located in.- Specified by:
getJdbcResourceNamein interfaceBindingSet- Returns:
- All tables need to be on the same database, so here we return one from a random resolved BindingSet
-
isBackendCanBypassSubjectFilter
public boolean isBackendCanBypassSubjectFilter()Description copied from interface:BindingSetisBackendCanBypassSubjectFilter- Specified by:
isBackendCanBypassSubjectFilterin interfaceBindingSet- Returns:
- true if it is allowed for the backend to bypass SubjectFilters
-
isAllowSelectAllColumns
public boolean isAllowSelectAllColumns()Description copied from interface:BindingSetisAllowSelectAllColumns- Specified by:
isAllowSelectAllColumnsin interfaceBindingSet- Returns:
- true if it is allowed to select all columns from this BindingSet.
-
get
Description copied from interface:BindingSetGets a BindingItem by its unique name and throws an Exception if it is not present.- Specified by:
getin interfaceBindingSet- Parameters:
key- The name of the BindingItem.- Returns:
- A BindingItem with the specified name.
- Throws:
BindingNotFoundException- If there is no BindingItem with the denoted name.
-
hasItem
Description copied from interface:BindingSettells if this binding-set contains an item- Specified by:
hasItemin interfaceBindingSet- Returns:
-
hasCustomItem
public boolean hasCustomItem()- Specified by:
hasCustomItemin interfaceBindingSet- Returns:
- TRUE if contains at least one custom element from
StandardNamespaceContext.CUST_NAMESPACE
-
get
Description copied from interface:BindingSetGet binding items by ids.- Specified by:
getin interfaceBindingSet- Throws:
BindingNotFoundException- See Also:
-
getBindingItemNames
Description copied from interface:BindingSetgetBindingItemNames- Specified by:
getBindingItemNamesin interfaceBindingSet- Returns:
- names of all items defined in the bindingSet
-
getBindingItemFromRelation
public BindingItem getBindingItemFromRelation(Relation pRelation, String itemName) throws BindingException Description copied from interface:BindingSetMethod getBindingItemFromRelation- Specified by:
getBindingItemFromRelationin interfaceBindingSetitemName- - requested binding item name- Returns:
- BindingItem object or null if not found
- Throws:
BindingException
-
hasKeyBindingItems
public boolean hasKeyBindingItems()Description copied from interface:BindingSetTests if the BindingSet hat key BindingItems.- Specified by:
hasKeyBindingItemsin interfaceBindingSet- Returns:
- True, if there is a BindingItem which is declared as key item.
-
getKeyBindingItems
Description copied from interface:BindingSetRetrieves the list of key BindingItems for this binding set which may contain no entries.- Specified by:
getKeyBindingItemsin interfaceBindingSet- Returns:
- An array of the BindingItems with the isKey attribute set to "true".
-
addRelation
Description copied from interface:BindingSetadds a new relation into ArrayList- Specified by:
addRelationin interfaceBindingSet
-
getRelations
- Specified by:
getRelationsin interfaceBindingSet
-
getWriteProcessing
- Specified by:
getWriteProcessingin interfaceBindingSet
-
assurePermissionDefined
public void assurePermissionDefined(BindingSet.SECURITY_OPS operation) throws SecurityMissingForBindingException Description copied from interface:BindingSetwe check here if the application has set up the subjectSettings. In case it is set up, the binding-set HAS TO define the Security context for given operation otherwise we throwSecurityMissingException- Specified by:
assurePermissionDefinedin interfaceBindingSet- Parameters:
operation- - to assure the permission is defined for- Throws:
SecurityMissingForBindingException
-
assurePermitted
Description copied from interface:BindingSetcheck if given operation is permitted according to permissions set on subject in scope- Specified by:
assurePermittedin interfaceBindingSet- Parameters:
operation- - to assure permission for- Throws:
SecurityException
-
getSecurity
- Specified by:
getSecurityin interfaceBindingSet- Returns:
- security context to this binding, may be NULL if no security configured
-
getWrqModifiers
Description copied from interface:BindingSetA list of Wrq modifier classes to be applied on all requests for this BindingSet before generating the SQL This is completely transparent to the caller, the answer Wrs does show the original WrsRequest- Specified by:
getWrqModifiersin interfaceBindingSet- Returns:
-
getTableReference
Description copied from interface:BindingSetReturns a table reference. Can be a plain table name (with alias) or a join of tables- Specified by:
getTableReferencein interfaceBindingSet- Returns:
-
getSQLStatementWithParams
Description copied from interface:BindingSetReturns a table expression and if it is a complex one (subselect with where for example) it may come with variables to be bound as host variables- Specified by:
getSQLStatementWithParamsin interfaceBindingSet- Returns:
-
getSubjectFilterExpression
public abstract SQLStatementWithParams getSubjectFilterExpression(WrqInfo wrqInfo) throws BindingException Return SubjectFilters to be applied for our virtual BindingSet- Specified by:
getSubjectFilterExpressionin interfaceWrqBindingSet- Returns:
- Throws:
BindingException
-