Class BasicDataSource

java.lang.Object
com.isomorphic.base.Base
com.isomorphic.datasource.DataSource
com.isomorphic.datasource.BasicDataSource
All Implemented Interfaces:
com.isomorphic.base.IAutoConfigurable, com.isomorphic.datasource.Committable, com.isomorphic.datasource.FreeResourcesHandler, com.isomorphic.datasource.IType, IToJSON, Serializable
Direct Known Subclasses:
AIDataSource, HibernateDataSource, JPADataSource, RestConnector, SQLDataSource

public class BasicDataSource extends DataSource
A BasicDataSource is a DataSource that can create itself from configuration information expressed in XML.

BasicDataSource is the right class to extend when creating a custom DataSource connector.

See Also:
  • Method Details

    • getAuditRecord

      public Map getAuditRecord(DSRequest req, Map inValues) throws Exception
      Convenience version of the three-argument version, but the third argument (oldvalues) is null, so is not suitable for "update" requests
      Parameters:
      req - DSRequest required to provide context essential to generating correct audit properties (for example, so we know the type of operation)
      inValues - The "base record" to provide an audit record for
      Returns:
      a record populated with audit values, based on the base record
      Throws:
      Exception - if an error occurs while generating the audit record
    • getAuditRecord

      public Map getAuditRecord(DSRequest req, Map inValues, Map oldValues) throws Exception
      Given a base record, a context DSRequest and optionally an "old" record, returns a record with all the audit fields populated in accordance with the rules specified in the DataSource's audit configuration. This includes dropping fields that are marked audit: never, for example. See the client-side docs for the DataSource "audit" property for a full discussion of the options.

      This method is used by SmartClient's automatic auditing facility, but it can also be called from user code (eg, from a DMI) if you wish to leverage the framework's ability to generate audit records in accordance with the configuration rules, for some manual process.

      Parameters:
      req - DSRequest required to provide context essential to generating correct audit properties (for example, so we know the type of operation)
      inValues - The "base record" to provide an audit record for
      oldValues - The record as it was prior to updating, generally available from the request's oldValues. This parameter is only applicable to "update" operations; if it is not supplied for an update operation, we are unable to generate a fully correct audit record because we cannot populate the "changedFields" value
      Returns:
      a record populated with audit values, based on the base record
      Throws:
      Exception - if an error occurs while generating the audit record
    • writeMultiAudits

      protected void writeMultiAudits(List valueSets, DSRequest originatingDSRequest) throws Exception
      Writes a collection of audit records to the audit DataSource associated with this DataSource. Is only applicable to suitable originating operations of type "add"; a "suitable" operation is one that added multiple records in a batch using the "multipleValues" strategy (scan the client-side documentation for "multiInsertStrategy"), and was for a dataSource that has no fields of type "sequence"

      Note, the framework will call this method automatically in the appropriate circumstances, as long as the "sql.multi.insert.allowAudit" flag is set to true in your server.properties file. Alternatively, you can call it manually from your own code.

      Parameters:
      valueSets - List of records to write audit records for
      originatingDSRequest - The "add" DSRequest that wrote the records we are going to audit. Required for essential context
      Throws:
      Exception - if an error occurs while writing audit records
    • shouldAutoStartTransaction

      public boolean shouldAutoStartTransaction(DSRequest req, boolean ignoreExistingTransaction) throws Exception
      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

      This method is part of the Automatic Transactions feature, which is effective only in Power edition and above.

      Parameters:
      req - The DSRequest to check
      ignoreExistingTransaction - 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.
      Returns:
      true if a transaction should be auto-started for this request
      Throws:
      Exception - if an error occurs while checking transaction settings
    • shouldAutoJoinTransaction

      public boolean shouldAutoJoinTransaction(DSRequest dsRequest) throws Exception
      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.

      This method is part of the Automatic Transactions feature, which is effective only in Power edition and above.

      Parameters:
      dsRequest - The DSRequest to check.
      Returns:
      true if the request should auto-join an existing transaction
      Throws:
      Exception - if an error occurs while checking transaction settings
    • getAuditDataSource

      public DataSource getAuditDataSource()
      This method returns the audit 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.

      Returns:
      The audit DataSource if audit was enabled, or null.
    • transformMultipleFields

      public void transformMultipleFields(DSRequest req)
      Transforms the values for fields declared multiple:true in the incoming DSRequest. This allows advanced queries to take place on fields declared as multiple:true.

      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.

      Overrides:
      transformMultipleFields in class DataSource
      Parameters:
      req - the request to be transformed.
    • transformMultipleFields

      public void transformMultipleFields(DSResponse res, DSRequest req)
      Transform the values for fields declared multiple:true in a DSResponse.

      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.

      Overrides:
      transformMultipleFields in class DataSource
      Parameters:
      res - the DSResponse to be transformed.
      req - the corresponding DSRequest, for context
    • hasCustomLogic

      public boolean hasCustomLogic()
      Returns true if this dataSource declares either a serverObject or serverScript property (see the client-side docs for details of those two properties). Note, you can also add custom logic to a DataSource by creating a custom subclass and overriding the execute(() method (for example), but this method does not take account of such customizations. If you need to know if a DataSource instance might have custom logic by virtue of being a subclass, you can use native Java approaches: either do an instanceof check, or override hasCustomLogic() in yout subclass and cause it to return true.
    • hasCustomDefaultFetchOperation

      public boolean hasCustomDefaultFetchOperation()
      Returns true if this dataSource declares a custom default fetch operation: that is, an operationBinding with operationType "fetch" and no declared operationId