public class BasicDataSource extends DataSource
BasicDataSource is the right class to extend when creating a custom DataSource connector.
inInitState, OP_ADD, OP_CLIENT_EXPORT, OP_CUSTOM, OP_DOWNLOAD_FILE, OP_FETCH, OP_GET_FILE, OP_GET_FILE_VERSION, OP_HAS_FILE, OP_HAS_FILE_VERSION, OP_LIST_FILE_VERSIONS, OP_LIST_FILES, OP_LOAD_SCHEMA, OP_REMOVE, OP_REMOVE_FILE, OP_REMOVE_FILE_VERSION, OP_RENAME_FILE, OP_SAVE_FILE, OP_UPDATE, OP_VALIDATE, OP_VIEW_FILE| Modifier and Type | Method and Description |
|---|---|
DataSource | getAuditDataSource() This method returns the audit DataSource associated with this DataSource if it has the audit=true property set. |
java.util.List | getListProperty(java.lang.String key) Returns the value of the specified attribute as a List. |
java.util.Map | getMapProperty(java.lang.String key) Returns the value of the specified attribute as a Map. |
java.lang.Object | getObjectProperty(java.lang.String key) Returns the value of the specified element(s) as an Object. Custom XML is transformed to Strings or Java collections by the following rules: Elements with just text (no child elements or attributes) become Strings Elements with child elements or attributes become Maps containing data derived from their subelements Repeating elements (more than one of the same name at the same level) become Lists Sample XML: Map <DataSource> List of String <DataSource> List of Map <DataSource> |
java.lang.String | getProperty(java.lang.String key) Returns a property from the DataSource config. |
boolean | shouldAutoJoinTransaction(DSRequest dsRequest) Returns true if the parameter DSRequest should automatically join an existing transaction, taking into account the DSRequest-specific override provided by DSRequest.setJoinTransaction(java.lang.Boolean), the transaction policy of the controlling RPCManager (if there is one), and autoJoinTransactions settings at the operationBinding, DataSource, dbName and global system levels. |
boolean | shouldAutoStartTransaction(DSRequest req, boolean ignoreExistingTransaction) Returns true if the parameter DSRequest should automatically start a new transaction, taking into account the DSRequest-specific override provided by DSRequest.setJoinTransaction(java.lang.Boolean), the transaction policy of the controlling RPCManager (if there is one), and autoJoinTransactions settings at the operationBinding, DataSource, dbName and global system levels |
void | transformMultipleFields(DSRequest req) Transforms the values for fields declared multiple:true in the incoming DSRequest. |
void | transformMultipleFields(DSResponse res) Transform the values for fields declared multiple:true in a DSResponse. |
add, addDynamicDSGenerator, addDynamicDSGenerator, addDynamicDSGenerator, clearDynamicDSGenerators, convertRelativeDates, convertRelativeDates, convertRelativeDates, convertRelativeDates, execute, executeAdd, executeClientExport, executeCustom, executeFetch, executeFileSource, executeRemove, executeUpdate, fetch, fetch, fetchById, fetchById, fetchSingle, fetchSingle, filter, filter, fromXML, fromXML, fromXML, fromXML, fromXML, fromXML, fromXML, fromXML, getAuditRevisionFieldName, getAuditTimestampFieldName, getAuditTypeFieldName, getAuditUserFieldName, getDefaultDynamicDSGenerator, getDynamicDSGenerators, getEnumConstantProperty, getEnumOrdinalProperty, getEnumTranslateStrategy, getField, getFieldNames, getFile, getFileAsInputStream, getFileAsString, getFileContentsField, getFileFormatField, getFileNameField, getFileTypeField, getID, getListProperties, getListProperties, getName, getPrimaryKey, getProperties, getProperties, getProperties, getPropertyJavaClass, getRecordXPath, getRelatedDisplayRecord, getRelatedDisplayRecord, getTransactionObject, getTransactionObject, hasFile, hasRecord, hasRecord, initialized, isModificationOperation, isServerOnly, listFiles, listFiles, listFiles, listFiles, remove, removeDynamicDSGenerator, removeDynamicDSGenerator, removeDynamicDSGenerator, removeFile, renameFile, saveFile, setEnumConstantProperty, setEnumOrdinalProperty, setEnumTranslateStrategy, setOmitNullMapValuesInResponse, setProperties, transformImportValue, transformImportValue, update, validate, validate, validateRecordpublic java.lang.String getProperty(java.lang.String key)
myNewProperty="some useful value"
to the <DataSource> tag in your .ds.xml definition file, calling this method with a parameter of "myNewProperty" will return "some useful value" - the value you assigned in the DataSource definition.key - The key to look uppublic java.lang.Object getObjectProperty(java.lang.String key)
<DataSource>
<mapCustomProperty key1="value1" key2="value2" />
</DataSource> <DataSource>
<listCustomProperty>ListElement1</listCustomProperty>
<listCustomProperty>ListElement2</listCustomProperty> </DataSource> <DataSource>
<mapCustomProperty key1="value1" key2="value2" />
<mapCustomProperty key1="value1" key2="value2" />
</DataSource> key - the name of the element(s)BasicDataSource.getProperty(String), BasicDataSource.getListProperty(String), BasicDataSource.getMapProperty(String)public java.util.List getListProperty(java.lang.String key)
key - the name of the attributejava.lang.ClassCastException - if requested property is not instanceof ListBasicDataSource.getProperty(String), BasicDataSource.getObjectProperty(String), BasicDataSource.getMapProperty(String)public java.util.Map getMapProperty(java.lang.String key)
key - the name of the attributejava.lang.ClassCastException - if requested property is not instanceof MapBasicDataSource.getProperty(String), BasicDataSource.getObjectProperty(String), BasicDataSource.getListProperty(String)public boolean shouldAutoStartTransaction(DSRequest req, boolean ignoreExistingTransaction) throws java.lang.Exception
DSRequest.setJoinTransaction(java.lang.Boolean), the transaction policy of the controlling RPCManager (if there is one), and autoJoinTransactions settings at the operationBinding, DataSource, dbName and global system levels This method is part of the Automatic Transactions feature, which is effective only in Power edition and above.
req - The DSRequest to checkignoreExistingTransaction - If true, indicates that we should not take into account any existing transaction for this RPCManager when deciding if a transaction should be autoStarted. This is useful if you want to know if a request would have started a new transaction if one hadn't already been started.java.lang.Exceptionpublic boolean shouldAutoJoinTransaction(DSRequest dsRequest) throws java.lang.Exception
DSRequest.setJoinTransaction(java.lang.Boolean), the transaction policy of the controlling RPCManager (if there is one), and autoJoinTransactions settings at the operationBinding, DataSource, dbName and global system levels. This method is part of the Automatic Transactions feature, which is effective only in Power edition and above.
dsRequest - The DSRequest to check.java.lang.Exceptionpublic DataSource getAuditDataSource()
DataSource associated with this DataSource if it has the audit=true property set. The audit DataSource can only be accessed by ID if the original DataSource has been accessed first.
DataSource if audit was enabled, or null.public void transformMultipleFields(DSRequest req)
See client-side docs for DataSourceField.multipleStorage for possible behaviors. This transformation is performed in DataSource.execute(), before operationType-specific methods like executeFetch or executeUpdate() are called.
transformMultipleFields in class DataSourcereq - the request to be transformed.public void transformMultipleFields(DSResponse res)
See client-side docs for DataSourceField.multipleStorage for possible behaviors. This transformation is performed in DataSource.execute(), after operationType-specific methods like executeFetch or executeUpdate() are called.
transformMultipleFields in class DataSourceres - the DSResponse to be transformed.