tao-test/app/generis/core/kernel/persistence/interface.ClassInterface.php

218 lines
7.3 KiB
PHP
Raw Permalink Normal View History

2022-08-29 20:14:13 +02:00
<?php
/**
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; under version 2
* of the License (non-upgradable).
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* Copyright (c) 2009-2012 (original work) Public Research Centre Henri Tudor (under the project TAO-SUSTAIN & TAO-DEV);
*
*
*/
/**
* Short description of class core_kernel_persistence_ClassInterface
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @package generis
*/
interface core_kernel_persistence_ClassInterface extends core_kernel_persistence_ResourceInterface
{
// --- OPERATIONS ---
/**
* Retrieve all subclass of the class
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param boolean recursive
* @return array
*/
public function getSubClasses(core_kernel_classes_Class $resource, $recursive = false);
/**
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param core_kernel_classes_Class $iClass
* @return boolean
*/
public function setSubClassOf(core_kernel_classes_Class $resource, core_kernel_classes_Class $iClass);
/**
* check if the resource is a subclass of given parentClass
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class resource
* @param core_kernel_classes_Class parentClass
* @return boolean
*/
public function isSubClassOf(core_kernel_classes_Class $resource, core_kernel_classes_Class $parentClass);
/**
* retrieve parent Classes
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param boolean recursive
* @return array
*/
public function getParentClasses(core_kernel_classes_Class $resource, $recursive = false);
/**
* retrieve properties
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param Resource $resource
* @param boolean recursive
* @return array
*/
public function getProperties(core_kernel_classes_Class $resource, $recursive = false);
/**
* retrieve all instances
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param Resource $resource
* @param boolean recursive
* @param array params
* @return array
*/
public function getInstances(core_kernel_classes_Class $resource, $recursive = false, $params = []);
/**
* Should not be called by application code, please use
* core_kernel_classes_ResourceFactory::create()
* or core_kernel_classes_Class::createInstanceWithProperties()
* instead
*
* Creates a new instance using the properties provided.
* May NOT contain additional types in the properties array
*
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param Resource resource
* @param string label
* @param string comment
* @param string uri
* @return core_kernel_classes_Resource
* @see core_kernel_classes_ResourceFactory
*/
public function createInstance(core_kernel_classes_Class $resource, $label = '', $comment = '', $uri = '');
/**
* Short description of method createSubClass
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param Resource resource
* @param string label
* @param string comment
* @param string uri
* @return core_kernel_classes_Class
*/
public function createSubClass(core_kernel_classes_Class $resource, $label = '', $comment = '', $uri = '');
/**
* Short description of method createProperty
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param string label
* @param string comment
* @param boolean isLgDependent
* @return core_kernel_classes_Property
*/
public function createProperty(core_kernel_classes_Class $resource, $label = '', $comment = '', $isLgDependent = false);
/**
* Short description of method searchInstances
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param array propertyFilters
* @param array options
* @return array
*/
public function searchInstances(core_kernel_classes_Class $resource, $propertyFilters = [], $options = []);
/**
* Short description of method countInstances
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param array propertyFilters
* @param array options
* @return Integer
*/
public function countInstances(core_kernel_classes_Class $resource, $propertyFilters = [], $options = []);
/**
* Short description of method getInstancesPropertyValues
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class $resource
* @param Property property
* @param array propertyFilters
* @param array options
* @return array
*/
public function getInstancesPropertyValues(core_kernel_classes_Class $resource, core_kernel_classes_Property $property, $propertyFilters = [], $options = []);
/**
* Should not be called by application code, please use
* core_kernel_classes_ResourceFactory::create()
* or core_kernel_classes_Class::createInstanceWithProperties()
* instead
*
* Creates a new instance using the properties provided.
* May NOT contain additional types in the properties array
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param core_kernel_classes_Class type
* @param array properties
* @return core_kernel_classes_Resource
* @see core_kernel_classes_ResourceFactory
*/
public function createInstanceWithProperties(core_kernel_classes_Class $type, $properties);
/**
* Delete a collection of instances of the Class.
*
* @access public
* @author Jerome Bogaerts, <jerome.bogaerts@tudor.lu>
* @param Resource $resource The resource (class) on which to apply the deletion.
* @param array resources An array containing core_kernel_classes_Resource objects or URIs.
* @param boolean deleteReference If set to true, references to instances will be deleted accross the database.
* @return boolean
*/
public function deleteInstances(core_kernel_classes_Class $resource, $resources, $deleteReference = false);
}