ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
class.ilDataCollectionExporter.php
Go to the documentation of this file.
1 <?php
2 
10 {
11 
15  protected $ds;
19  protected $db;
20 
21 
22  public function init()
23  {
24  global $DIC;
25  $ilDB = $DIC['ilDB'];
26  $this->ds = new ilDataCollectionDataSet();
27  $this->ds->setDSPrefix('ds');
28  $this->db = $ilDB;
29  }
30 
31 
37  public function getValidSchemaVersions($a_entity)
38  {
39  return array(
40  '4.5.0' => array(
41  'namespace' => 'http://www.ilias.de/Modules/DataCollection/dcl/4_5',
42  'xsd_file" => "ilias_dcl_4_5.xsd',
43  'uses_dataset' => true,
44  'min' => '4.5.0',
45  'max' => ''
46  )
47  );
48  }
49 
50 
51  public function getXmlRepresentation($a_entity, $a_schema_version, $a_id)
52  {
54  $this->ds->setExportDirectories($this->dir_relative, $this->dir_absolute);
55 
56  return $this->ds->getXmlRepresentation($a_entity, $a_schema_version, $a_id, '', true, true);
57  }
58 
59 
70  public function getXmlExportHeadDependencies($a_entity, $a_target_release, $a_ids)
71  {
72  $dependencies = array(
74  'component' => 'Modules/File',
75  'entity' => 'file',
76  'ids' => array(),
77  ),
79  'component' => 'Services/MediaObjects',
80  'entity' => 'mob',
81  'ids' => array(),
82  ),
83  );
84 
85  // Direct SQL query is faster than looping over objects
86  foreach ($a_ids as $dcl_obj_id) {
87  $sql = "SELECT stloc2.value AS ext_id, f." . $this->db->quoteIdentifier('datatype_id') . " FROM il_dcl_stloc2_value AS stloc2 "
88  . "INNER JOIN il_dcl_record_field AS rf ON (rf." . $this->db->quoteIdentifier('id') . " = stloc2." . $this->db->quoteIdentifier('record_field_id') . ") "
89  . "INNER JOIN il_dcl_field AS f ON (rf." . $this->db->quoteIdentifier('field_id') . " = f." . $this->db->quoteIdentifier('id') . ") " . "INNER JOIN il_dcl_table AS t ON (t." . $this->db->quoteIdentifier('id') . " = f." . $this->db->quoteIdentifier('table_id') . ") "
90  . "WHERE t." . $this->db->quoteIdentifier('obj_id') . " = " . $this->db->quote($dcl_obj_id, 'integer') . " " . "AND f.datatype_id IN ("
91  . implode(',', array_keys($dependencies)) . ") AND stloc2." . $this->db->quoteIdentifier('value') . " IS NOT NULL";
92  $set = $this->db->query($sql);
93  while ($rec = $this->db->fetchObject($set)) {
94  $dependencies[$rec->datatype_id]['ids'][] = (int) $rec->ext_id;
95  }
96  }
97 
98  // Return external dependencies/IDs if there are any
99  $return = array();
100  if (count($dependencies[ilDclDatatype::INPUTFORMAT_FILE]['ids'])) {
101  $return[] = $dependencies[ilDclDatatype::INPUTFORMAT_FILE];
102  }
103  if (count($dependencies[ilDclDatatype::INPUTFORMAT_MOB]['ids'])) {
104  $return[] = $dependencies[ilDclDatatype::INPUTFORMAT_MOB];
105  }
106 
107  return $return;
108  }
109 
110 
118  public function getXmlExportTailDependencies($a_entity, $a_target_release, $a_ids)
119  {
120  $page_object_ids = array();
121  foreach ($a_ids as $dcl_obj_id) {
122  // If a DCL table has a detail view, we need to export the associated page objects!
123  $sql = "SELECT page_id FROM page_object "
124  . "WHERE parent_type = " . $this->db->quote('dclf', 'text') . " AND parent_id = " . $this->db->quote($dcl_obj_id, 'integer');
125  $set = $this->db->query($sql);
126  while ($rec = $this->db->fetchObject($set)) {
127  $page_object_ids[] = "dclf:" . $rec->page_id;
128  }
129  }
130  if (count($page_object_ids)) {
131  return array(
132  array(
133  'component' => 'Services/COPage',
134  'entity' => 'pg',
135  'ids' => $page_object_ids,
136  )
137  );
138  }
139 
140  return array();
141  }
142 }
static makeDirParents($a_dir)
Create a new directory and all parent directories.
getXmlExportHeadDependencies($a_entity, $a_target_release, $a_ids)
MOB/File fieldtypes objects are head dependencies They must be exported and imported first...
global $DIC
Definition: saml.php:7
Xml Exporter class.
DataCollection dataset class.
getAbsoluteExportDirectory()
Get absolute export directory.
Create styles array
The data for the language used.
Class ilDataCollectionExporter.
getXmlRepresentation($a_entity, $a_schema_version, $a_id)
global $ilDB
getXmlExportTailDependencies($a_entity, $a_target_release, $a_ids)