1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: XDocumentProperties.idl,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
30 #ifndef __com_sun_star_document_XDocumentProperties_idl__
31 #define __com_sun_star_document_XDocumentProperties_idl__
33 #ifndef __com_sun_star_beans_PropertyValue_idl__
34 #include
<com
/sun
/star
/beans
/PropertyValue.idl
>
37 #ifndef __com_sun_star_util_DateTime_idl__
38 #include
<com
/sun
/star
/util
/DateTime.idl
>
41 #ifndef __com_sun_star_lang_Locale_idl__
42 #include
<com
/sun
/star
/lang
/Locale.idl
>
45 #ifndef __com_sun_star_beans_NamedValue_idl__
46 #include
<com
/sun
/star
/beans
/NamedValue.idl
>
49 #ifndef __com_sun_star_embed_XStorage_idl__
50 #include
<com
/sun
/star
/embed
/XStorage.idl
>
53 #ifndef __com_sun_star_io_IOException_idl__
54 #include
<com
/sun
/star
/io
/IOException.idl
>
57 #ifndef __com_sun_star_io_WrongFormatException_idl__
58 #include
<com
/sun
/star
/io
/WrongFormatException.idl
>
61 #ifndef __com_sun_star_beans_XPropertySet_idl__
62 #include
<com
/sun
/star
/beans
/XPropertySet.idl
>
65 #ifndef __com_sun_star_beans_XPropertyContainer_idl__
66 #include
<com
/sun
/star
/beans
/XPropertyContainer.idl
>
70 //=============================================================================
72 module com
{ module sun
{ module star
{ module document
{
74 //=============================================================================
75 /** provides document-specific information such as the author, creation date,
76 and user-defined fields.
79 This interface manages access to document meta-data properties.
80 Such properties may be set from the outside via the setter methods
81 (e.g. when importing arbitrary document formats that support
82 document properties), or imported from an ODF package via the methods
83 <member>loadFromStorage</member> and <member>loadFromMedium</member>.
84 The properties may also be stored via the methods
85 <member>storeToStorage</member> and <member>storeToMedium</member>.
90 @see XDocumentPropertiesSupplier
91 for getting access to an instance from a loaded document
92 @see DocumentProperties for a service that implements this interface
94 interface XDocumentProperties
96 //-------------------------------------------------------------------------
97 /** contains the initial author of the document.
100 [attribute
] string Author
;
102 //-------------------------------------------------------------------------
103 /** identifies which application was used to create or last modify the
106 The generating application will set this attribute when it creates a
107 new document or it saves a document. When a document is loaded that
108 itself contains such an attribute it will be preserved until the
109 document is saved again.
113 [attribute
] string Generator
;
115 //-------------------------------------------------------------------------
116 /** contains the date and time when the document was created.
119 [attribute
] com
::sun
::star
::util
::DateTime CreationDate
;
121 //-------------------------------------------------------------------------
122 /** contains the title of the document.
125 [attribute
] string Title
;
127 //-------------------------------------------------------------------------
128 /** contains the subject of the document.
131 [attribute
] string Subject
;
133 //-------------------------------------------------------------------------
134 /** contains a multi-line comment describing the document.
136 Line delimiters can be UNIX, Macintosh or DOS style.
140 [attribute
] string Description
;
142 //-------------------------------------------------------------------------
143 /** contains a list of keywords for the document.
146 [attribute
] sequence
< string > Keywords
;
148 //-------------------------------------------------------------------------
149 /** contains the default language of the document.
152 [attribute
] com
::sun
::star
::lang
::Locale Language
;
154 //-------------------------------------------------------------------------
155 /** contains the name of the person who most recently stored the document.
158 [attribute
] string ModifiedBy
;
160 //-------------------------------------------------------------------------
161 /** contains the date and time of the last time the document was stored.
163 If the document has never been stored, contains a default value.
167 [attribute
] com
::sun
::star
::util
::DateTime ModificationDate
;
169 //-------------------------------------------------------------------------
170 /** contains the name of the person who most recently printed the document.
173 [attribute
] string PrintedBy
;
175 //-------------------------------------------------------------------------
176 /** contains the date and time when the document was last printed.
178 If the document has never been printed, contains a default value.
182 [attribute
] com
::sun
::star
::util
::DateTime PrintDate
;
184 //-------------------------------------------------------------------------
185 /** contains the name of the template from which the document was created.
187 The value is an empty <atom>string</atom> if the document was not
188 created from a template or if it was detached from the template.
192 [attribute
] string TemplateName
;
194 //-------------------------------------------------------------------------
195 /** contains the URL of the template from which the document was created.
197 The value is an empty <atom>string</atom> if the document was not
198 created from a template or if it was detached from the template.
202 [attribute
] string TemplateURL
;
204 //-------------------------------------------------------------------------
205 /** contains the date and time of when the document
206 was created or updated from the template.
209 [attribute
] com
::sun
::star
::util
::DateTime TemplateDate
;
211 //-------------------------------------------------------------------------
212 /** contains the URL to load automatically at a
213 specified time after the document is loaded into a desktop frame.
215 An empty URL is valid and describes a case where the document shall be
216 reloaded from its original loction after some time described by the
217 attribute <member>AutoloadSecs</member>.
218 An empty <atom>string</atom> together with an
219 <member>AutoloadSecs</member> value of 0
220 describes a case where no autoload is specified.
226 [attribute
] string AutoloadURL
;
228 //-------------------------------------------------------------------------
229 /** contains the number of seconds after which a specified
230 URL is to be loaded after the document is loaded into a desktop
233 A value of 0 is valid and describes a redirection.
234 A value of 0 together with an empty <atom>string</atom> as
235 <member>AutoloadURL</member>
236 describes a case where no autoload is specified.
239 @throws com::sun::star::lang::IllegalArgumentException
240 if argument is negative
245 [attribute
] long AutoloadSecs
{
246 set raises
( com
::sun
::star
::lang
::IllegalArgumentException
);
249 //-------------------------------------------------------------------------
250 /** contains the name of the default frame into which
251 links should be loaded if no target is specified.
253 This applies to the autoload feature too, but to others as well.
257 [attribute
] string DefaultTarget
;
259 //-------------------------------------------------------------------------
260 /** contains some statistics about the document.
262 The contained statistics may be specific to the type of the document.
267 sequence
< com
::sun
::star
::beans
::NamedValue
> DocumentStatistics
;
269 //-------------------------------------------------------------------------
270 /** describes how often the document was edited and saved.
274 @throws com::sun::star::lang::IllegalArgumentException
275 if argument is negative
278 [attribute
] short EditingCycles
{
279 set raises
( com
::sun
::star
::lang
::IllegalArgumentException
);
282 //-------------------------------------------------------------------------
283 /** contains the net time of editing the document (in seconds).
287 @throws com::sun::star::lang::IllegalArgumentException
288 if argument is negative
291 [attribute
] long EditingDuration
{
292 set raises
( com
::sun
::star
::lang
::IllegalArgumentException
);
295 //-------------------------------------------------------------------------
296 /** resets all attributes that could identify the user.
298 Clears the document properties, such that it apperars the document
299 has just been created.
300 This is a convenience method which resets several attributes at once,
303 <li><member>Author</member> is set to the given parameter.</li>
304 <li><member>CreationDate</member> is set to the current date and time.
306 <li><member>ModifiedBy</member> is cleared.</li>
307 <li><member>ModificationDate</member> is cleared.</li>
308 <li><member>PrintedBy</member> is cleared.</li>
309 <li><member>PrintDate</member> is cleared.</li>
310 <li><member>EditingDuration</member> is cleared.</li>
311 <li><member>EditingCycles</member> is set to 1.</li>
315 the new value of the <member>Author</member> attribute.
318 void resetUserData
( [in] string Author
);
320 //-------------------------------------------------------------------------
321 /** provides access to a container for user-defined properties.
323 The returned object also implements the interface
324 <type>com::sun::star::beans::XPropertySet</type>.
326 @returns a container that provides access to user-defined properties
329 com
::sun
::star
::beans
::XPropertyContainer getUserDefinedProperties
();
331 //-------------------------------------------------------------------------
332 /** loads document properties from an ODF package.
334 This method is used for accessing an ODF package that is owned by
335 someone else, e.g., a document.
339 the <type>com::sun::star::embed::Storage</type> representing the
343 the <type>com::sun::star::document::MediaDescriptor</type>
344 representing the source
346 This is unfortunately necessary in order to properly resolve
347 relative URLs in the meta-data.
350 @throws com::sun::star::lang::IllegalArgumentException
351 if argument is <NULL/>
352 @throws com::sun::star::io::WrongFormatException
353 if parsing the XML document fails
354 @throws com::sun::star::lang::WrappedTargetException
355 if thrown when trying to open a stream in the given storage
356 @throws com::sun::star::io::IOException
357 if thrown when trying to open a stream in the given storage
358 @throws com::sun::star::uno::Exception
359 in various unspecified circumstances
362 void loadFromStorage
( [in] com
::sun
::star
::embed
::XStorage Storage
,
363 [in] sequence
< com
::sun
::star
::beans
::PropertyValue
> Medium
)
364 raises
( com
::sun
::star
::lang
::IllegalArgumentException
,
365 com
::sun
::star
::io
::WrongFormatException
,
366 com
::sun
::star
::lang
::WrappedTargetException
,
367 com
::sun
::star
::io
::IOException
,
368 com
::sun
::star
::uno
::Exception
);
370 //-------------------------------------------------------------------------
371 /** loads document properties from an ODF package or an OLE container.
373 For compatibility reasons this method also supports the import from
374 former StarOffice binary file formats.
378 the URL of the source document
380 The URL could be part of the Medium parameter, but because often
381 no other parameters except the URL are needed, providing it
382 separately was added for convenience.
386 the <type>com::sun::star::document::MediaDescriptor</type>
387 representing the source
389 @throws com::sun::star::io::WrongFormatException
390 if parsing the XML document fails
391 @throws com::sun::star::lang::WrappedTargetException
392 if thrown when trying to open a stream in the given storage
393 @throws com::sun::star::io::IOException
394 if thrown when trying to open a stream in the given storage
395 @throws com::sun::star::uno::Exception
396 in various unspecified circumstances
399 void loadFromMedium
( [in] string URL
,
400 [in] sequence
< com
::sun
::star
::beans
::PropertyValue
> Medium
)
401 raises
( com
::sun
::star
::io
::WrongFormatException
,
402 com
::sun
::star
::lang
::WrappedTargetException
,
403 com
::sun
::star
::io
::IOException
,
404 com
::sun
::star
::uno
::Exception
);
406 //-------------------------------------------------------------------------
407 /** stores document properties to an ODF package.
409 This method is used for accessing an ODF package that is owned by
410 someone else, e.g., a document.
411 Note that the implementation may choose to store the meta-data
412 in either OOo or ODF format, depending on the MediaType property
413 of the given <type>Storage</type> argument.
417 the <type>com::sun::star::embed::Storage</type> representing the
421 the <type>com::sun::star::document::MediaDescriptor</type>
422 representing the source
424 This is unfortunately necessary in order to properly resolve
425 relative URLs in the meta-data.
428 @throws com::sun::star::lang::IllegalArgumentException
429 if argument is <NULL/>
430 @throws com::sun::star::lang::WrappedTargetException
431 if thrown when trying to open a stream in the given storage
432 @throws com::sun::star::io::IOException
433 if thrown when writing to the storage
434 @throws com::sun::star::uno::Exception
435 in various unspecified circumstances
438 void storeToStorage
( [in] com
::sun
::star
::embed
::XStorage Storage
,
439 [in] sequence
< com
::sun
::star
::beans
::PropertyValue
> Medium
)
440 raises
( com
::sun
::star
::lang
::IllegalArgumentException
,
441 com
::sun
::star
::lang
::WrappedTargetException
,
442 com
::sun
::star
::io
::IOException
,
443 com
::sun
::star
::uno
::Exception
);
445 //-------------------------------------------------------------------------
446 /** stores document properties to an ODF package or an OLE container.
448 For compatibility reasons this method also supports the export to former
449 StarOffice binary file formats.
453 the URL of the target document
455 The URL could be part of the Medium parameter, but because often
456 no other parameters except the URL are needed, providing it
457 separately was added for convenience.
461 the <type>com::sun::star::document::MediaDescriptor</type>
462 representing the target
464 @throws com::sun::star::lang::WrappedTargetException
465 if thrown when trying to open a stream in the given storage
466 @throws com::sun::star::io::IOException
467 if thrown when writing to the storage
468 @throws com::sun::star::uno::Exception
469 in various unspecified circumstances
472 void storeToMedium
( [in] string URL
,
473 [in] sequence
< com
::sun
::star
::beans
::PropertyValue
> Medium
)
474 raises
( com
::sun
::star
::lang
::WrappedTargetException
,
475 com
::sun
::star
::io
::IOException
,
476 com
::sun
::star
::uno
::Exception
);
479 //=============================================================================