You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
421 lines
15 KiB
421 lines
15 KiB
<Schema name="VssWriterMetadataInfo"
|
|
xmlns="urn:schemas-microsoft-com:xml-data"
|
|
xmlns:dt="urn:schemas-microsoft-com:datatypes">
|
|
|
|
|
|
<AttributeType name="filespec" dt:type="string" required="yes">
|
|
<description>
|
|
File specification. Can include wildcard characters ? and *
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="path" dt:type="string" required="yes">
|
|
<description>
|
|
Path to a file. The path can include environment variables or
|
|
values extracted from registry keys.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
|
|
<AttributeType name="recursive" dt:type="enumeration"
|
|
dt:values="yes no" default="no">
|
|
<description>
|
|
Is path specified recursive or limited to the directory that is specified.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="alternatePath" dt:type="string" required="no">
|
|
<description>
|
|
Alternate path in which to find the file. Files in a file group may
|
|
have been copied to an alternative location by the writer. Backup should
|
|
pick up the files from the alternative location instead of the original
|
|
location but should restore the files to their original location
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="logicalPath" dt:type="string" required="no">
|
|
<description>
|
|
Logical path for a database or file group. This logical name uses backslash
|
|
as separators to form a logical namespace hierarchy
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="componentName" dt:type="string" required="yes">
|
|
<description>
|
|
Name used to identify a database or file group. May be qualified by a
|
|
logical path.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
|
|
<AttributeType name="restoreMetadata" dt:type="enumeration"
|
|
dt:values="yes no" default="no">
|
|
<description>
|
|
Restore metadata exists for this database or file group. Backup
|
|
application should capture the restore metadata and pass it to the
|
|
writer on restore.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="notifyOnBackupComplete" dt:type="enumeration"
|
|
dt:values="yes no" default="no">
|
|
<description>
|
|
Writer should be notified when backup is complete whether this
|
|
database or file group was successfully backed up or not.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
|
|
<AttributeType name="caption" dt:type="string" required="no">
|
|
<description>
|
|
Textual Description of database or file group
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="icon" dt:type="string" required="no">
|
|
<description>
|
|
Icon associated with database or file group
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="selectable" dt:type="enumeration"
|
|
dt:values="yes no" default="yes">
|
|
<description>
|
|
Is this component selectable for backup or is it always backed up.
|
|
If no, then the component is always backed up if any other components of
|
|
the application/service are backed up. If yes, then the
|
|
component may be selectively backed up.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="selectableForRestore" dt:type="enumeration"
|
|
dt:values="yes no" default="no">
|
|
<description>
|
|
Is this component selectable for restore
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="version" dt:type="enumeration" dt:values="1.0 1.1 1.2 1.3" required="yes">
|
|
<description>
|
|
Version of a specific document
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="writerId" dt:type="uuid" required="yes">
|
|
<description>
|
|
Unique id to identify the writer. Note that this identifies the
|
|
writer class rather than a specific instance of the writer.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="instanceId" dt:type="uuid" required="no">
|
|
<description>
|
|
Unique id identifying the instance of a writer during backup. It
|
|
has no meaning during restore.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="componentFlags" dt:type="number" default="0">
|
|
<description>
|
|
Contains extra flags that describe the component being backed up.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="backupSchema" dt:type="number" default="0">
|
|
<description>
|
|
Describes the writer capabilities and how different types of backup are performed.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="filespecBackupType" dt:type="number" default="0">
|
|
<description>
|
|
Describes how backup should be performed on a specific filespec.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<ElementType name="WRITER_METADATA" content="eltOnly" model="open" order="one">
|
|
<description>
|
|
Information used by Backup application to backup/restore data
|
|
</description>
|
|
<attribute type="version" />
|
|
<attribute type="backupSchema" />
|
|
<element type="IDENTIFICATION" />
|
|
<element type="BACKUP_LOCATIONS" minOccurs="0" />
|
|
<element type="RESTORE_METHOD" minOccurs="0" />
|
|
</ElementType>
|
|
|
|
<ElementType name="IDENTIFICATION" content="empty" model="closed">
|
|
<description>
|
|
Identification of a service/application backing up data
|
|
</description>
|
|
|
|
<AttributeType name="friendlyName" dt:type="string" required="yes">
|
|
<description>
|
|
Friendly name used to describe the service or application.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="usage" dt:type="enumeration"
|
|
dt:values="USER_DATA BOOTABLE_SYSTEM_STATE SYSTEM_SERVICE OTHER"
|
|
default="OTHER">
|
|
<description>
|
|
How the data associated with the writer is used. For now we
|
|
distinguish user data and system state.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="dataSource" dt:type="enumeration"
|
|
dt:values="TRANSACTION_DB NONTRANSACTIONAL_DB OTHER"
|
|
default="OTHER">
|
|
<description>
|
|
Description of the nature of the data manager. Currently only
|
|
databases are identified
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<attribute type="instanceId" required="yes" />
|
|
<attribute type="writerId" />
|
|
<attribute type="friendlyName" />
|
|
<attribute type="usage" />
|
|
<attribute type="dataSource" />
|
|
</ElementType>
|
|
|
|
<ElementType name="BACKUP_LOCATIONS" content="eltOnly" model="closed" order="many">
|
|
<description>
|
|
Files to include and exclude from the backup
|
|
</description>
|
|
|
|
<element type="INCLUDE_FILES" minOccurs="0" />
|
|
<element type="EXCLUDE_FILES" minOccurs="0" />
|
|
<element type="DATABASE" minOccurs="0"/>
|
|
<element type="FILE_GROUP" minOccurs="0" />
|
|
</ElementType>
|
|
|
|
<ElementType name="INCLUDE_FILES" content="empty">
|
|
<description>
|
|
Files to include in the backup, essentially files to backup if you want
|
|
to backup this application/service
|
|
</description>
|
|
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="recursive" />
|
|
<attribute type="alternatePath" />
|
|
</ElementType>
|
|
|
|
<ElementType name="EXCLUDE_FILES" content="empty">
|
|
<description>
|
|
Files that should always be excluded from the backup
|
|
</description>
|
|
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="recursive" />
|
|
</ElementType>
|
|
|
|
<ElementType name="DATABASE" content="eltOnly" model="closed" order="many">
|
|
<description>
|
|
List of databases of interest. This is used to allow selective
|
|
backup and restore of specific databases.
|
|
</description>
|
|
|
|
|
|
<attribute type= "logicalPath" />
|
|
<attribute type="componentName" />
|
|
<attribute type="caption" />
|
|
<attribute type="icon" />
|
|
<attribute type="restoreMetadata" />
|
|
<attribute type="notifyOnBackupComplete" />
|
|
<attribute type="selectable" />
|
|
<attribute type="selectableForRestore" />
|
|
<attribute type="componentFlags" />
|
|
|
|
<element type="DATABASE_FILES" minOccurs="1" />
|
|
<element type="DATABASE_LOGFILES" />
|
|
<element type="DEPENDENCY" minOccurs="0" />
|
|
</ElementType>
|
|
|
|
<ElementType name="DATABASE_FILES" content="empty" model="closed">
|
|
<description>
|
|
Location of a set of database files. Filespec can include wildcards
|
|
</description>
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="filespecBackupType" />
|
|
</ElementType>
|
|
|
|
|
|
<ElementType name="DATABASE_LOGFILES" content="empty" model="closed">
|
|
<description>
|
|
Location of a set of database log files. Filespec can include
|
|
wildcards. Indication of whether database log files are truncated.
|
|
</description>
|
|
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="filespecBackupType" />
|
|
</ElementType>
|
|
|
|
<ElementType name="FILE_GROUP" content="eltOnly" model="closed" order="many">
|
|
<description>
|
|
A named group of files. Used to group sets of files into a group
|
|
that are backed up together
|
|
</description>
|
|
|
|
<attribute type="logicalPath" />
|
|
<attribute type="componentName" />
|
|
<attribute type="caption" />
|
|
<attribute type="icon" />
|
|
<attribute type="restoreMetadata" />
|
|
<attribute type="notifyOnBackupComplete" />
|
|
<attribute type="selectable" />
|
|
<attribute type="selectableForRestore" />
|
|
<attribute type="componentFlags" />
|
|
|
|
<element type="FILE_LIST" />
|
|
<element type="DEPENDENCY" minOccurs="0" />
|
|
</ElementType>
|
|
|
|
<ElementType name="FILE_LIST" content="empty" model="closed">
|
|
<description>
|
|
Location of a set of files in a FILE_GROUP. Filespec can include
|
|
wildcards.
|
|
</description>
|
|
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="recursive" />
|
|
<attribute type="alternatePath" />
|
|
<attribute type="filespecBackupType" />
|
|
</ElementType>
|
|
|
|
|
|
<ElementType name="DEPENDENCY" content="empty" model="closed">
|
|
<description>
|
|
A dependency from one component to another component in another writer.
|
|
</description>
|
|
|
|
<AttributeType name="onWriterId" dt:type="uuid" required="yes">
|
|
<description>
|
|
Id of writer that this component is dependent on.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="onLogicalPath" dt:type="string" required="no">
|
|
<description>
|
|
Logical path of component that this component is dependent on.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="onComponentName" dt:type="string" required="yes">
|
|
<description>
|
|
Name of component that this component is dependent on.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<attribute type="onWriterId" />
|
|
<attribute type="onLogicalPath" />
|
|
<attribute type="onComponentName" />
|
|
</ElementType>
|
|
|
|
<ElementType name="RESTORE_METHOD" content="eltOnly" model="open" order="many">
|
|
<description>
|
|
How restore should be performed. Includes specification of how files
|
|
should be restored as well as special steps that should occur in order
|
|
to complete the restore.
|
|
</description>
|
|
|
|
<AttributeType name="method" dt:type="enumeration"
|
|
required="yes"
|
|
dt:values="RESTORE_IF_NONE_THERE
|
|
RESTORE_IF_CAN_BE_REPLACED
|
|
STOP_RESTART_SERVICE
|
|
REPLACE_AT_REBOOT
|
|
REPLACE_AT_REBOOT_IF_CANNOT_REPLACE
|
|
RESTORE_TO_ALTERNATE_LOCATION
|
|
CUSTOM">
|
|
<description>
|
|
RESTORE_IF_NONE_THERE: i.e., can restore data if it is not at the
|
|
location where it was backed up from. This essentially allows
|
|
data to be restored to a clean system
|
|
RESTORE_IF_CAN_BE_REPLACED: Restore data if all of the files can
|
|
be replaced in the orgiginal backup location. Fails if any of
|
|
the files are open. If an alternate location is provided, files
|
|
will be placed there if they cannot be restored to their original
|
|
location.
|
|
STOP_RESTART_SERVICE: stop service (service attribute must be
|
|
specified). Restore files to original backup location.
|
|
Restart service. Fails if any of the files are open after the
|
|
service is stopped.
|
|
REPLACE_AT_REBOOT: Restore files to a temporary location. Use
|
|
MoveFileEx to replace the files at reboot.
|
|
REPLACE_AT_REBOOT_IF_CANNOT_REPLACE: Similiar to REPLACE_AT_REBOOT
|
|
however files may be restored in place in they are not busy. All files
|
|
within a component must be either completely replaced in place or
|
|
completely replaced at reboot, so if one component file is busy, all files
|
|
in that component must be replaced at reboot.
|
|
|
|
RESTORE_TO_ALTERNATIVE_LOCATION: Restore files to an alternate
|
|
location. Typically writerRestore will indicate that the writer
|
|
will participate in the restore process
|
|
CUSTOM: restore process cannot be expressed using this specification
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="service" dt:type="string" required="no">
|
|
<description>
|
|
Must be specified if method="STOP_RESTART_SERVICE", indicates
|
|
service to be stopped before restoring files.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="writerRestore" dt:type="enumeration"
|
|
dt:values="always never ifReplaceFails" default="never">
|
|
<description>
|
|
Whether writer should be invoked after files are restored to
|
|
disk. Options are always, never, and ifReplaceFails. The latter means
|
|
that the files will be restored to their original location. If one
|
|
or more of the files cannot be replaced, then the files will be
|
|
restored to an alternate location (must be specified via
|
|
ALTERNATE_LOCATION_MAPPING. After the files are restored, the writer
|
|
is invoked.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="userProcedure" dt:type="uri" required="no">
|
|
<description>
|
|
Description of actions that the user should perform to restore the files.
|
|
The format of this string has yet to be determined.
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<AttributeType name="rebootRequired" dt:type="enumeration"
|
|
dt:values="yes no" default="no" >
|
|
<description>
|
|
Should a reboot be performed after restoring the data for this
|
|
writer
|
|
</description>
|
|
</AttributeType>
|
|
|
|
<attribute type="method" />
|
|
<attribute type="service" />
|
|
<attribute type="writerRestore" />
|
|
<attribute type="userProcedure" />
|
|
<attribute type="rebootRequired" />
|
|
|
|
<element type="ALTERNATE_LOCATION_MAPPING" minOccurs="0" maxOccurs="*" />
|
|
</ElementType>
|
|
|
|
<ElementType name="ALTERNATE_LOCATION_MAPPING" content="empty" model="closed">
|
|
<description>
|
|
Mapping from a location that was backed up to a location to restore to.
|
|
</description>
|
|
<attribute type="path" />
|
|
<attribute type="filespec" />
|
|
<attribute type="recursive" />
|
|
<attribute type="alternatePath" />
|
|
</ElementType>
|
|
|
|
|
|
|
|
</Schema>
|