/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef __com_sun_star_configuration_backend_XBackend_idl__ #define __com_sun_star_configuration_backend_XBackend_idl__ #ifndef __com_sun_star_uno_XInterface_idl__ #include #endif #ifndef __com_sun_star_configuration_backend_XUpdateHandler_idl__ #include #endif #ifndef __com_sun_star_configuration_backend_XLayer_idl__ #include #endif #ifndef __com_sun_star_configuration_backend_XSchema_idl__ #include #endif #ifndef __com_sun_star_configuration_backend_BackendAccessException_idl__ #include #endif #ifndef __com_sun_star_lang_IllegalArgumentException_idl__ #include #endif #ifndef __com_sun_star_lang_NoSupportException_idl__ #include #endif //============================================================================= module com { module sun { module star { module configuration { module backend { //============================================================================= /** Handles access to layered data stored in a repository.

Data can be retrieved on behalf of one or more entities.

There is an implied owner entity associated to the object when it is created. This entity should be used for normal data access. For administrative operations data of other entities can be accessed.

@see com::sun::star::configuration::backend::XBackendEntities @see com::sun::star::configuration::backend::XSchemaSupplier @since OOo 1.1.2 */ published interface XBackend : ::com::sun::star::uno::XInterface { //------------------------------------------------------------------------- /** retrieves the layers associated to the owner entity for a component. @param aComponent component whose data will be accessed @returns a list of objects allowing access to the component data for each layer associated to the current entity @throws com::sun::star::lang::IllegalArgumentException if the component identifier is invalid @throws com::sun::star::configuration::backend::BackendAccessException if an error occurs while accessing the data. @see com::sun::star::configuration::backend::XBackendEntities::getOwnerEntity() */ sequence listOwnLayers([in] string aComponent) raises (BackendAccessException, com::sun::star::lang::IllegalArgumentException) ; //------------------------------------------------------------------------- /** creates an update handler for the owner entity layer for a component. @param aComponent component whose data will be updated @returns an object allowing manipulation of the component data for the current entity @throws com::sun::star::lang::IllegalArgumentException if the component identifier is invalid @throws com::sun::star::lang::NoSupportException if updates are not supported for this backend @throws com::sun::star::configuration::backend::BackendAccessException if an error occurs while accessing the data. @see com::sun::star::configuration::backend::XBackendEntities::getOwnerEntity() */ XUpdateHandler getOwnUpdateHandler([in] string aComponent) raises (BackendAccessException, com::sun::star::lang::NoSupportException, com::sun::star::lang::IllegalArgumentException) ; //------------------------------------------------------------------------- /** retrieves the layers associated to an entity for a component. @param aComponent component whose data will be accessed @param aEntity entity whose data will be accessed @returns a list of objects allowing access to the component data for each layer associated with the entity. @throws com::sun::star::lang::IllegalArgumentException if the component identifier is invalid or if the entity doesn't exist. @throws com::sun::star::configuration::backend::BackendAccessException if an error occurs while accessing the data. @see com::sun::star::configuration::backend::XBackendEntities::supportsEntity() */ sequence listLayers([in] string aComponent, [in] string aEntity) raises (BackendAccessException, com::sun::star::lang::IllegalArgumentException) ; //------------------------------------------------------------------------- /** creates an update handler on an entity's layer for a component. @param aComponent component whose data will be updated @param aEntity entity whose data will be updated @returns an object allowing manipulation of the component data for the entity @throws com::sun::star::lang::IllegalArgumentException if the component identifier is invalid or if the entity doesn't exist. @throws com::sun::star::lang::NoSupportException if updates are not supported for this backend @throws com::sun::star::configuration::backend::BackendAccessException if an error occurs while accessing the data. @see com::sun::star::configuration::backend::XBackendEntities::supportsEntity() */ XUpdateHandler getUpdateHandler([in] string aComponent, [in] string aEntity) raises (BackendAccessException, com::sun::star::lang::NoSupportException, com::sun::star::lang::IllegalArgumentException) ; //------------------------------------------------------------------------- } ; //============================================================================= } ; } ; } ; } ; } ; #endif