1/**************************************************************
2 *
3 * Licensed to the Apache Software Foundation (ASF) under one
4 * or more contributor license agreements.  See the NOTICE file
5 * distributed with this work for additional information
6 * regarding copyright ownership.  The ASF licenses this file
7 * to you under the Apache License, Version 2.0 (the
8 * "License"); you may not use this file except in compliance
9 * with the License.  You may obtain a copy of the License at
10 *
11 *   http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing,
14 * software distributed under the License is distributed on an
15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16 * KIND, either express or implied.  See the License for the
17 * specific language governing permissions and limitations
18 * under the License.
19 *
20 *************************************************************/
21
22
23#ifndef __com_sun_star_configuration_backend_XSingleLayerStratum_idl__
24#define __com_sun_star_configuration_backend_XSingleLayerStratum_idl__
25
26#ifndef __com_sun_star_uno_XInterface_idl__
27#include <com/sun/star/uno/XInterface.idl>
28#endif
29
30#ifndef __com_sun_star_configuration_backend_XLayer_idl__
31#include <com/sun/star/configuration/backend/XLayer.idl>
32#endif
33
34#ifndef __com_sun_star_configuration_backend_XUpdatableLayer_idl__
35#include <com/sun/star/configuration/backend/XUpdatableLayer.idl>
36#endif
37
38#ifndef __com_sun_star_configuration_backend_BackendAccessException_idl__
39#include <com/sun/star/configuration/backend/BackendAccessException.idl>
40#endif
41
42#ifndef __com_sun_star_lang_IllegalArgumentException_idl__
43#include <com/sun/star/lang/IllegalArgumentException.idl>
44#endif
45
46#ifndef __com_sun_star_lang_NoSupportException_idl__
47#include <com/sun/star/lang/NoSupportException.idl>
48#endif
49
50//=============================================================================
51
52module com { module sun { module star { module configuration { module backend {
53
54//=============================================================================
55
56/**
57  Handles access to a stratum consisting of a single layer
58  in a configuration data repository
59
60  <p> The interface provides timestamp-checking capabilities
61     for efficient caching.
62  </p>
63
64  @see com::sun::star::util::XTimeStamped
65  @see com::sun::star::configuration::backend::XSchemaSupplier
66  @see com::sun::star::configuration::backend::XMultiLayerStratum
67
68  @since OOo 1.1.2
69*/
70published interface XSingleLayerStratum : ::com::sun::star::uno::XInterface
71{
72	//-------------------------------------------------------------------------
73
74    /**
75        retrieves the layer data for a component, if newer than indicated.
76
77        <p> A timestamp can be provided, which is used to indicate
78            a point in time. The layer should be returned only if is modified
79            since that time.
80        </p>
81
82        @param aComponent
83                The name of the component to access.
84
85        @param aTimestamp
86                a timestamp for the layer.
87
88                <p> An empty timestamp indicates, that the layer should be
89                    retrieved irrespective of its modification time.
90                </p>
91                <p> The format and meaning of a timestamp depends on
92                    the implementation. Timestamps can be obtained using
93                    <member scope="com::sun::star::util">XTimeStamped::getTimestamp()</member>.
94                </p>
95
96      @returns
97                a <type>Layer</type> object providing access to the layer data,
98                <NULL/> if the layer is newer than indicated by the timestamp.
99
100      @throws   com::sun::star::lang::IllegalArgumentException
101                if the component identifier is invalid or
102                if the timestamp is invalid.
103
104      @throws   com::sun::star::configuration::backend::BackendAccessException
105                if an error occurs while accessing the data.
106
107      @see com::sun::star::util::XTimeStamped
108	*/
109    XLayer getLayer([in] string aComponent,
110                    [in] string aTimestamp)
111        raises (BackendAccessException,
112                com::sun::star::lang::IllegalArgumentException) ;
113
114	//-------------------------------------------------------------------------
115
116    /**
117        retrieves a writable representation of the layer for a component.
118
119        @param aComponent
120                The name of the component to access.
121
122        @return
123                an <type>UpdatableLayer</type> object providing
124                write access to the layer
125
126        @throws   com::sun::star::lang::IllegalArgumentException
127                if the component identifier is invalid.
128
129        @throws   com::sun::star::lang::NoSupportException
130                if the implementation does not support updates.
131
132        @throws   com::sun::star::configuration::backend::BackendAccessException
133                if an error occurs while accessing the data.
134     */
135    XUpdatableLayer getUpdatableLayer([in] string aComponent)
136        raises (BackendAccessException,
137                com::sun::star::lang::NoSupportException,
138                com::sun::star::lang::IllegalArgumentException) ;
139
140	//-------------------------------------------------------------------------
141} ;
142
143//=============================================================================
144
145} ; } ; } ; } ; } ;
146
147#endif
148