You are here

public function FrxOracle::__construct in Forena Reports 7.3

Same name and namespace in other branches
  1. 6.2 plugins/FrxOracle.inc \FrxOracle::__construct()
  2. 6 plugins/FrxOracle.inc \FrxOracle::__construct()
  3. 7 plugins/FrxOracle.inc \FrxOracle::__construct()
  4. 7.2 plugins/FrxOracle.inc \FrxOracle::__construct()
  5. 7.4 plugins/FrxOracle.inc \FrxOracle::__construct()

Object constructor

Parameters

unknown_type $uri Database connection string.:

string $repos_path Path to location of data block definitions:

Overrides FrxDataSource::__construct

File

plugins/FrxOracle.inc, line 23
Oracle specific driver that takes advantage of oracles native XML support

Class

FrxOracle
@file Oracle specific driver that takes advantage of oracles native XML support

Code

public function __construct($conf, $repos_path, $name) {
  parent::__construct($conf, $repos_path, $name);
  $this->use_oracle_xml = FALSE;
  $uri = $conf['uri'];
  $this->debug = $conf['debug'];
  if (isset($conf['schema'])) {
    $this->schema = $conf['schema'];
  }
  if ($conf['oracle_xml']) {
    $this->use_oracle_xml = TRUE;
  }
  if ($uri) {

    // Test for postgres suport
    if (!is_callable('oci_connect')) {
      $this
        ->error('OCI support not installed.', 'OCI support not installed.');
      return;
    }
    try {
      $db = oci_connect($conf['user'], $conf['password'], $uri, @$conf['character_set']);
      $this->db = $db;
    } catch (Exception $e) {
      $this
        ->error('Unable to connect to database ' . $conf['title'], $e
        ->getMessage());
    }
  }
  else {
    $this
      ->error('No database connection string specified', 'No database connection: ' . print_r($conf, 1));
  }

  // Set the date format that drupal expects using the date api.
  if ($this->db) {
    $stmt = oci_parse($this->db, "ALTER SESSION SET NLS_DATE_FORMAT='yyyy-mm-dd hh24:mi:ss'");
    oci_execute($stmt);
    $stmt = oci_parse($this->db, 'ALTER SESSION SET NLS_NUMERIC_CHARACTERS = ".,"');
    oci_execute($stmt);
  }

  // Set up the stuff required to translate.
  $this->te = new FrxSyntaxEngine(FRX_SQL_TOKEN, ':', $this);
}