AccessOwnerStorageAcl.php 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. Lib::loadClass('Core_AclBase');
  3. Lib::loadClass('ParseOgcFilter');
  4. class Schema_AccessOwnerStorageAcl extends Core_AclBase {
  5. public function getNamespace() { return 'default_objects/' . $this->getName(); }
  6. public function getSourceName() { return 'objects'; }
  7. public function init($force = false) {}
  8. public function isInitialized() { return true; }
  9. public function getName() { return 'AccessOwner'; }
  10. public function getRootTableName() { return 'ADMIN_USERS'; }// TODO: turn off - use getName for generating ref's
  11. public function getFieldListByIdZasob() { return $this->getRealFieldListByIdZasob(); }
  12. public function getVisibleFieldListByIdZasob() { return $this->getRealFieldListByIdZasob(); }
  13. public function getVirtualFieldListByIdZasob() { return array(); }
  14. public function getRealFieldListByIdZasob($force = false) {
  15. $cols[100000] = 'id';// ADMIN_USERS.ID
  16. $cols[100001] = 'login';// ADMIN_USERS.ADM_ACCOUNT
  17. $cols[100002] = 'name';// ADMIN_USERS.ADM_NAME
  18. return $cols;
  19. }
  20. public function getFields() { return array_values($this->getRealFieldListByIdZasob()); }
  21. public function getFieldType($fieldName) { return null; }
  22. // TODO: replace legacy functions: isAllowed, hasFieldPerm, getFieldIdByName
  23. public function canCreateField($fieldName) { return false; }
  24. public function canReadField($fieldName) { return true; }
  25. public function canReadObjectField($fieldName, $record) {return true; }
  26. public function canWriteField($fieldName) { return false; }
  27. public function canWriteObjectField($fieldName, $record) { return false; }
  28. public function getItems($params = array()) {
  29. $DBG = V::get('DBG_DS', 0, $_GET, 'int');
  30. if($DBG>2){echo 'C.'.get_class($this).' L.' . __LINE__ . " getItems \$params:";print_r($params);echo "\n";}
  31. $items = DB::getPDO()->fetchAllByKey("
  32. select u.ID as id, u.ADM_ACCOUNT as login, u.ADM_NAME as name
  33. from ADMIN_USERS u
  34. where u.A_STATUS = 'NORMAL'
  35. and u.ADM_TECH_WORKER != 'NO'
  36. ", $key = 'id');
  37. if ($pk = V::get('primaryKey', '', $params, 'int')) {// [primaryKey] => 2948
  38. if (!array_key_exists($pk, $items)) return array();
  39. $items = array($pk => $items[$pk]);
  40. }
  41. if (!empty($params['ogc:Filter'])) {
  42. $parser = new ParseOgcFilter();
  43. $parser->loadOgcFilter($params['ogc:Filter']);
  44. $queryWhereBuilder = $parser->convertToSqlQueryWhereBuilder();
  45. DBG::_('DBG_DS', '>2', "ogc:Filter \$queryWhereBuilder", $queryWhereBuilder, __CLASS__, __FUNCTION__, __LINE__);
  46. if($DBG>2){echo 'C.'.get_class($this).' L.' . __LINE__ . " getItems \$items:";print_r($items);echo "\n";}
  47. $items = array_filter($items, array($queryWhereBuilder, 'filterRawArray'));
  48. }
  49. if($DBG>2){echo 'C.'.get_class($this).' L.' . __LINE__ . " getItems \$items:";print_r($items);echo "\n";}
  50. return $items;
  51. }
  52. public function addItem($itemTodo) { throw new Exception("Insert not allowed"); }
  53. public function updateItem($itemPatch) { throw new Exception("Update not allowed"); }
  54. public function getGeomFieldType($fieldName) { return null; }
  55. public function getPrimaryKeyField() { return 'id'; }
  56. public function getID() { return 0; }
  57. public function getAttributesFromZasoby() { return array(); }
  58. public function isEnumerationField($fieldName) { return false; }
  59. public function getEnumerations($fieldName) { return null; }
  60. public function getXsdFieldType($fieldName) {
  61. if ('id' == $fieldName) return 'xsd:string';
  62. if ('login' == $fieldName) return 'xsd:string';
  63. if ('name' == $fieldName) return 'xsd:string';
  64. }
  65. public function isGeomField($fldName) { return false; }
  66. }