Difference between revisions of "Extension Deployment"

From Apache OpenOffice Wiki
Jump to: navigation, search
m
 
(24 intermediate revisions by 2 users not shown)
Line 2: Line 2:
  
 
Extension deployment should not be considered as an independent task.
 
Extension deployment should not be considered as an independent task.
 +
 
Indeed, when you need to deploy extensions on a number of workstations, you'll need also to deploy templates, autotexts, gallery themes, and so on, because you'll need to preserve a relative homogeneity. In fact, you'll often need to deploy extensions in the same time you need to deploy templates, autotexts and gallery themes.
 
Indeed, when you need to deploy extensions on a number of workstations, you'll need also to deploy templates, autotexts, gallery themes, and so on, because you'll need to preserve a relative homogeneity. In fact, you'll often need to deploy extensions in the same time you need to deploy templates, autotexts and gallery themes.
  
Line 13: Line 14:
  
 
== Technical context ==
 
== Technical context ==
 +
 
Before specifying the content of the package, we must keep in mind some technical constraints induced by the implementations of the configuration objects, and the rules for specifying their location.
 
Before specifying the content of the package, we must keep in mind some technical constraints induced by the implementations of the configuration objects, and the rules for specifying their location.
  
 
=== The OOo registry ===
 
=== The OOo registry ===
OOo comes with its own registry system.
+
 
 +
{{AOo}} comes with its own registry system.
  
 
The registry is implemented in a directory named "registry", as well in the shared installation directory as in the user .openoffice.org2/user directory.
 
The registry is implemented in a directory named "registry", as well in the shared installation directory as in the user .openoffice.org2/user directory.
  
When the user modifies its OOo environment, sometimes its registry is changed, sometimes not. The installation process should not alter directly the user OOo directory if this change cause alteration in the registry. In this case, the work should be taken in charge by OOo, thus the installation process should invoke OOo API.
+
When the user modifies its {{AOo}} environment, sometimes its registry is changed, sometimes not. The installation process should not alter directly the user {{AOo}} directory if this change cause alteration in the registry. In this case, the work should be taken in charge by {{AOo}}, thus the installation process should invoke {{AOo}} API.
  
 
=== Default locations ===
 
=== Default locations ===
 +
 
Default locations of the objects seem to be specified in the file
 
Default locations of the objects seem to be specified in the file
 +
 
<code>$(insturl)/share/registry/schema/org/openoffice/Office/Common.xcs</code>
 
<code>$(insturl)/share/registry/schema/org/openoffice/Office/Common.xcs</code>
  
Line 35: Line 40:
  
 
=== Templates ===
 
=== Templates ===
 +
 
The default locations of templates are specified in the following XML part:
 
The default locations of templates are specified in the following XML part:
<code><pre>
+
 
 +
<syntaxhighlight lang="xml">
 +
 
 
<prop oor:name="Template" oor:type="oor:string-list">
 
<prop oor:name="Template" oor:type="oor:string-list">
    <info>
+
 
      <desc>Specifies the templates originate from these folders and sub-folders.</desc>
+
<info>
    </info>
+
 
    <value oor:separator=":">$(insturl)/share/template/$(vlang):$(userurl)/template</value>
+
<desc>Specifies the templates originate from these folders and sub-folders.</desc>
 +
 
 +
</info>
 +
 
 +
<value oor:separator=":">$(insturl)/share/template/$(vlang):$(userurl)/template</value>
 +
 
 
</prop>
 
</prop>
</pre></code>
+
 
 +
</syntaxhighlight>
  
 
Templates are objects very similar to other objects produced with the suite. The only differences stand in the 't' in place of 'd' in the second place of the suffix, and in the virtual tree for accessing to them, built from the set of paths declared in the configuration files.
 
Templates are objects very similar to other objects produced with the suite. The only differences stand in the 't' in place of 'd' in the second place of the suffix, and in the virtual tree for accessing to them, built from the set of paths declared in the configuration files.
  
From the time the user changes something in the paths, they are stored in the file  
+
From the time the user changes something in the paths, they are stored in the file
 +
 
 
<code>$(userurl)/registry/data/org/openoffice/Office/Common.xcu</code>
 
<code>$(userurl)/registry/data/org/openoffice/Office/Common.xcu</code>
  
 
=== Autotexts ===
 
=== Autotexts ===
  
The default location of autotexts is specified in the following XML part:
+
The default location of autotexts is specified in the following XML part:
<code><pre>
+
 
 +
<syntaxhighlight lang="xml">
 +
 
 
<prop oor:name="AutoText" oor:type="oor:string-list">
 
<prop oor:name="AutoText" oor:type="oor:string-list">
  <info>
+
 
      <desc>Contains the directory which contains the AutoText modules.</desc>
+
<info>
  </info>
+
 
  <value oor:separator=":">$(insturl)/share/autotext/$(vlang):$(userurl)/autotext</value>
+
<desc>Contains the directory which contains the AutoText modules.</desc>
 +
 
 +
</info>
 +
 
 +
<value oor:separator=":">$(insturl)/share/autotext/$(vlang):$(userurl)/autotext</value>
 +
 
 
</prop>
 
</prop>
</pre></code>
 
  
Autotexts are organized in categories. The user can create as many categories as she wants, and ask for storing them in one of the directories declared in the configuration file, provided that she has write access. Each category is implemented in a file named <category_name>.bau which is in fact a zip archive.
+
</syntaxhighlight>
  
Nevertheless, if the category name contains special characters, they are silently dropped from the file name. Thus it is more robust to search the category name in the file BlockList.xml included in the archive.
+
Autotexts are organized in categories. The user can create as many categories as she wants, and ask for storing them in one of the directories declared in the configuration file, provided that she has write access. Each category is implemented in a file named <category_name>.bau which is in fact a zip archive.
 +
 
 +
Nevertheless, if the category name contains special characters, they are silently dropped from the file name. Thus, it is more robust to search the category name in the file BlockList.xml included in the archive.
  
 
=== Databases ===
 
=== Databases ===
  
The databases are described in .odb files which may be stored anywhere. this ones are standard OOo archive. The content.xml file describe the data source and some attributes of the database.
+
The databases are described in .odb files which may be stored anywhere. this ones are standard OOo archive. The content.xml file describe the data source and some attributes of the database.
  
 
The databases are declared in the registry directory, in the file:
 
The databases are declared in the registry directory, in the file:
 +
 
<code>
 
<code>
  
Line 80: Line 104:
  
 
<source lang="xml">
 
<source lang="xml">
 +
 
<node oor:name="RegisteredNames">
 
<node oor:name="RegisteredNames">
  ...
+
 
  <node oor:name="the_database_name" oor:op="replace">
+
...
      <prop oor:name="Location" oor:type="xs:string">
+
 
      <value>file://the/location/of/the/database.odb</value>
+
<node oor:name="the_database_name" oor:op="replace">
      </prop>
+
 
      <prop oor:name="Name" oor:type="xs:string">
+
<prop oor:name="Location" oor:type="xs:string">
      <value>the_database_name</value>
+
 
      </prop>
+
<value>file://the/location/of/the/database.odb</value>
    </node>
+
 
    ...
+
</prop>
 +
 
 +
<prop oor:name="Name" oor:type="xs:string">
 +
 
 +
<value>the_database_name</value>
 +
 
 +
</prop>
 +
 
 
</node>
 
</node>
 +
 +
...
 +
 +
</node>
 +
 
</source>
 
</source>
  
Line 111: Line 148:
  
 
; using the file name? : as the file name is, in a way, randomly given during installation, the same theme may be given different names depending on the history of previous installations on different workstations. Furthermore, OOo may have given the same filename to different themes created on different workstations.
 
; using the file name? : as the file name is, in a way, randomly given during installation, the same theme may be given different names depending on the history of previous installations on different workstations. Furthermore, OOo may have given the same filename to different themes created on different workstations.
 +
 
; using the name stored in the .thm file? : if this name is too generic, as "people", "events" or "houses", the same name may be given to different themes created by different users.
 
; using the name stored in the .thm file? : if this name is too generic, as "people", "events" or "houses", the same name may be given to different themes created by different users.
  
 
Thus, at the installation time, it is pertinent to consider the following cases:
 
Thus, at the installation time, it is pertinent to consider the following cases:
 +
 
; the number and the theme name doesn't exist: to install directly the theme;
 
; the number and the theme name doesn't exist: to install directly the theme;
 +
 
; the number already exists and the theme name doesn't exist: to search another discriminatory number;
 
; the number already exists and the theme name doesn't exist: to search another discriminatory number;
; the theme name already exists: to ask the user if the existing theme must be overwritten, or the new one renamed, or its installation aborted.
+
 
 +
; the theme name already exists: to ask the user if the existing theme must be overwritten, or the new one renamed, or its installation aborted.
 +
 
 
It is important to systematically search for the theme name in all already existing themes.
 
It is important to systematically search for the theme name in all already existing themes.
  
 
=== Macros ===
 
=== Macros ===
 +
 
to be completed
 
to be completed
  
 
=== Toolbars ===
 
=== Toolbars ===
 +
 
to be completed
 
to be completed
  
 
=== The package manager ===
 
=== The package manager ===
  
At this stage, it is important to consider the package managment provided by OOo V2.
+
At this stage, it is important to consider the package management provided by OpenOffice.org V2.
  
 
The package manager can import, enable, disable and export packages.
 
The package manager can import, enable, disable and export packages.
Line 133: Line 177:
 
In the package you can store one module containing several libraries of macros.
 
In the package you can store one module containing several libraries of macros.
  
You can describe additional main menu items, tools menu items and buttons for lauching the macros. The buttons are grouped in one new toolbar.
+
You can describe additional main menu items, tools menu items and buttons for launching the macros. The buttons are grouped in one new toolbar.
  
 
At the moment, the package manager can't manage templates, autotexts nor gallery themes.
 
At the moment, the package manager can't manage templates, autotexts nor gallery themes.
Line 139: Line 183:
 
A package is a zip archive.
 
A package is a zip archive.
  
The root of this archive contains an <code>addons.xcu</code> file whose contains is described [http://api.openoffice.org/docs/DevelopersGuide/Components/Components.xhtml#1_7_3_3_Configuration here]
+
The root of this archive contains an <code>addons.xcu</code> file whose contains is described [https://wiki.openoffice.org/wiki/Documentation/DevGuide/WritingUNO/AddOns/Configuration here]
  
 
== Background ==
 
== Background ==
This project should not start from zero. Some work has already been done, and here is some non exhaustive reference to it.
 
  
* Bernard Marcelly has written a document called [http://documentation.openoffice.org/HOW_TO/index.html "How to Distribute Macros with an Addon"] containing macros making it very easy to create a package. This document is outdated. For OpenOffice 2.x see page [[Extensions_Packager]]
+
This project should not start from zero. Some work has already been done, and here is some non-exhaustive reference to it.
 +
 
 +
* Bernard Marcelly has written a document called [http://documentation.openoffice.org/HOW_TO/index.html "How to Distribute Macros with an Addon"] containing macros making it very easy to create a package. This document is outdated. For OpenOffice.org 2.x see page [[Extensions_Packager]]
  
 
* Didier Dorange-Pattoret has written a [http://www.dmaths.org/modules.php?name=Downloads&d_op=getit&lid=58 macro] allowing easy installation of galleries.
 
* Didier Dorange-Pattoret has written a [http://www.dmaths.org/modules.php?name=Downloads&d_op=getit&lid=58 macro] allowing easy installation of galleries.
  
* Laurent Godard has written DicOOo which installs dictionaries on a workstation, and which is now distributed with OOo V2.  
+
* Laurent Godard has written DicOOo which installs dictionaries on a workstation, and which is now distributed with OpenOffice.org V2.
  
* Philippe Allart has written a [http://adullact.net/frs/download.php/1176/mk_OOo_pack.zip simple bash script] which complies to the structure proposed below, and which use the tool of Didier Dorange-Pattoret
+
* Philippe Allart has written a [http://adullact.net/frs/download.php/1176/mk_OOo_pack.zip simple bash script] which complies to the structure proposed below, and which use the tool of Didier Dorange-Pattoret
  
 
== Specification of a configuration package ==
 
== Specification of a configuration package ==
 +
 
=== Layout ===
 
=== Layout ===
To be consistent with the technological choices of the developpers team of OOo, it is suggested that the package be implemented as a zip archive.
 
  
This archive should contains one directory for each type of object.
+
To be consistent with the technological choices of the developers team of {{AOo}}, it is suggested that the package be implemented as a zip archive.
  
Perhaps, it would be a good idea to add a "goodies" directory, allowing to add objects not directly concerned by the configuration process, but which would be very usefull for end users.
+
This archive should contain one directory for each type of object.
 +
 
 +
Perhaps, it would be a good idea to add a "goodies" directory, allowing to add objects not directly concerned by the configuration process, but which would be very useful for end users.
  
 
Thus, the suggested tree could be as follows:
 
Thus, the suggested tree could be as follows:
  
 
# /
 
# /
 +
 
#* tools allowing installation of the package
 
#* tools allowing installation of the package
 +
 
#* specifications for installation (location of templates, ...)
 
#* specifications for installation (location of templates, ...)
 +
 
## /autotexts/
 
## /autotexts/
 +
 
##* autotexts (.bau files) to be installed
 
##* autotexts (.bau files) to be installed
 +
 
## /packages/
 
## /packages/
 +
 
##* packages (.zip files) to be installed
 
##* packages (.zip files) to be installed
 +
 
## /databases/
 
## /databases/
 +
 
##* databases (.odb files) to be installed and possibly local data
 
##* databases (.odb files) to be installed and possibly local data
 +
 
## /templates/
 
## /templates/
 +
 
##* templates to be installed
 
##* templates to be installed
 +
 
## /autocorr/
 
## /autocorr/
 +
 
##* .dat files containing replacement rules and exceptions
 
##* .dat files containing replacement rules and exceptions
 +
 
## /wordbooks/
 
## /wordbooks/
 +
 
##* dictionaries to be installed
 
##* dictionaries to be installed
 +
 
## /fonts/
 
## /fonts/
 +
 
##* fonts to be installed
 
##* fonts to be installed
 +
 
## /gallery/
 
## /gallery/
 +
 
##* themes to be installed
 
##* themes to be installed
 +
 
## /goodies/
 
## /goodies/
  
Line 195: Line 261:
 
At this stage, it is necessary to define what will be specified, and how it will be, for the installation process.
 
At this stage, it is necessary to define what will be specified, and how it will be, for the installation process.
  
It is useless to re-invent the wheel, and it seems a good idea to reuse the [http://api.openoffice.org/docs/DevelopersGuide/Components/Components.htm#1+7+3+3+Configuration structure] of the addons.xcu file used by the package manager.
+
It is useless to re-invent the wheel, and it seems a good idea to reuse the [https://wiki.openoffice.org/wiki/Documentation/DevGuide/WritingUNO/AddOns/Configuration structure] of the addons.xcu file used by the package manager.
  
Indeed, this structure is very generic, in the sense that it doesn't contain specific tags. In fact, it's just a set of two columns tables containing properties/values pairs. Theses tables are organised in tree where each node have a name as an attribute.
+
Indeed, this structure is very generic, in the sense that it doesn't contain specific tags. In fact, it's just a set of two columns tables containing properties/values pairs. These tables are organized in a tree where each node has a name as an attribute.
  
 
Formally, the XML Schema is as follows:
 
Formally, the XML Schema is as follows:
  
<code>
+
<syntaxhighlight lang="xml">
 
XML Schema to be described
 
XML Schema to be described
</code>
+
</syntaxhighlight>
  
 
Now, the work stands in:
 
Now, the work stands in:
 +
 
* to define the structure of the tree, and to give a name to each node;
 
* to define the structure of the tree, and to give a name to each node;
 +
 
* for each node, to define the content of the table, i.e. the set of properties/values pairs.
 
* for each node, to define the content of the table, i.e. the set of properties/values pairs.
  
 
== Contributors ==
 
== Contributors ==
 +
 
--[[User:Pallart|Pallart]] 16:34, 6 April 2006 (CEST)
 
--[[User:Pallart|Pallart]] 16:34, 6 April 2006 (CEST)
 
  
 
[[category:Extensions]]
 
[[category:Extensions]]

Latest revision as of 13:54, 2 February 2021

First considerations

Extension deployment should not be considered as an independent task.

Indeed, when you need to deploy extensions on a number of workstations, you'll need also to deploy templates, autotexts, gallery themes, and so on, because you'll need to preserve a relative homogeneity. In fact, you'll often need to deploy extensions in the same time you need to deploy templates, autotexts and gallery themes.

This is the reason why it is suggested here to consider the following approach:

1 - to define the structure of a package which aims to deploy in one operation extensions, including macro and toolbars, templates, autotexts and gallery themes;

2 - to define the user interface of an administration tool whose goal is to create such a package;

3 - to define the user interface of a user tool which would enable the end user to install the package on her workstation, or the administrator to install it in the shared installation tree.

Technical context

Before specifying the content of the package, we must keep in mind some technical constraints induced by the implementations of the configuration objects, and the rules for specifying their location.

The OOo registry

Apache OpenOffice comes with its own registry system.

The registry is implemented in a directory named "registry", as well in the shared installation directory as in the user .openoffice.org2/user directory.

When the user modifies its Apache OpenOffice environment, sometimes its registry is changed, sometimes not. The installation process should not alter directly the user Apache OpenOffice directory if this change cause alteration in the registry. In this case, the work should be taken in charge by Apache OpenOffice, thus the installation process should invoke Apache OpenOffice API.

Default locations

Default locations of the objects seem to be specified in the file

$(insturl)/share/registry/schema/org/openoffice/Office/Common.xcs

In most configuration files, some frequently used locations are referenced via variables:

$(insturl) represents the installation directory, eg. /opt/openoffice.org2.0

$(userurl) represents the user configuration directory, eg. /home/smith/.openoffice.org2/user

$(work) stands for the user work directory.

Templates

The default locations of templates are specified in the following XML part:

<prop oor:name="Template" oor:type="oor:string-list">

<info>

<desc>Specifies the templates originate from these folders and sub-folders.</desc>

</info>

<value oor:separator=":">$(insturl)/share/template/$(vlang):$(userurl)/template</value>

</prop>

Templates are objects very similar to other objects produced with the suite. The only differences stand in the 't' in place of 'd' in the second place of the suffix, and in the virtual tree for accessing to them, built from the set of paths declared in the configuration files.

From the time the user changes something in the paths, they are stored in the file

$(userurl)/registry/data/org/openoffice/Office/Common.xcu

Autotexts

The default location of autotexts is specified in the following XML part:

<prop oor:name="AutoText" oor:type="oor:string-list">

<info>

<desc>Contains the directory which contains the AutoText modules.</desc>

</info>

<value oor:separator=":">$(insturl)/share/autotext/$(vlang):$(userurl)/autotext</value>

</prop>

Autotexts are organized in categories. The user can create as many categories as she wants, and ask for storing them in one of the directories declared in the configuration file, provided that she has write access. Each category is implemented in a file named <category_name>.bau which is in fact a zip archive.

Nevertheless, if the category name contains special characters, they are silently dropped from the file name. Thus, it is more robust to search the category name in the file BlockList.xml included in the archive.

Databases

The databases are described in .odb files which may be stored anywhere. this ones are standard OOo archive. The content.xml file describe the data source and some attributes of the database.

The databases are declared in the registry directory, in the file:

$(userurl)/registry/data/org/openoffice/Office/DataAccess.xcu

The database name must appear in the "RegisteredNames" node.

<node oor:name="RegisteredNames">

...

<node oor:name="the_database_name" oor:op="replace">

<prop oor:name="Location" oor:type="xs:string">

<value>file://the/location/of/the/database.odb</value>

</prop>

<prop oor:name="Name" oor:type="xs:string">

<value>the_database_name</value>

</prop>

</node>

...

</node>

Gallery's themes

At the moment, managment of themes in OOo seems a little bit twisted.

Themes are stored in three binary files, those format are inherited from StarOffice.

This files are suffixed with .sdg, .sdv and .thm.

The .thm file contains, among binary data, the name of the theme, as given by the user.

The name of each file is of the form sgNNN.xxx where NNN is a number (the same from the three files) and xxx the suffix.

Apparently, the only rule for choosing the number is to obtain unique file names in the target directory.

This implementation is adequate for a local managment of themes, but doesn't give satisfaction when exchanging themes between users. Indeed, the question is: how to detect duplicates during the installation?

using the file name?
as the file name is, in a way, randomly given during installation, the same theme may be given different names depending on the history of previous installations on different workstations. Furthermore, OOo may have given the same filename to different themes created on different workstations.
using the name stored in the .thm file?
if this name is too generic, as "people", "events" or "houses", the same name may be given to different themes created by different users.

Thus, at the installation time, it is pertinent to consider the following cases:

the number and the theme name doesn't exist
to install directly the theme;
the number already exists and the theme name doesn't exist
to search another discriminatory number;
the theme name already exists
to ask the user if the existing theme must be overwritten, or the new one renamed, or its installation aborted.

It is important to systematically search for the theme name in all already existing themes.

Macros

to be completed

Toolbars

to be completed

The package manager

At this stage, it is important to consider the package management provided by OpenOffice.org V2.

The package manager can import, enable, disable and export packages.

In the package you can store one module containing several libraries of macros.

You can describe additional main menu items, tools menu items and buttons for launching the macros. The buttons are grouped in one new toolbar.

At the moment, the package manager can't manage templates, autotexts nor gallery themes.

A package is a zip archive.

The root of this archive contains an addons.xcu file whose contains is described here

Background

This project should not start from zero. Some work has already been done, and here is some non-exhaustive reference to it.

  • Didier Dorange-Pattoret has written a macro allowing easy installation of galleries.
  • Laurent Godard has written DicOOo which installs dictionaries on a workstation, and which is now distributed with OpenOffice.org V2.
  • Philippe Allart has written a simple bash script which complies to the structure proposed below, and which use the tool of Didier Dorange-Pattoret

Specification of a configuration package

Layout

To be consistent with the technological choices of the developers team of Apache OpenOffice, it is suggested that the package be implemented as a zip archive.

This archive should contain one directory for each type of object.

Perhaps, it would be a good idea to add a "goodies" directory, allowing to add objects not directly concerned by the configuration process, but which would be very useful for end users.

Thus, the suggested tree could be as follows:

  1. /
    • tools allowing installation of the package
    • specifications for installation (location of templates, ...)
    1. /autotexts/
      • autotexts (.bau files) to be installed
    1. /packages/
      • packages (.zip files) to be installed
    1. /databases/
      • databases (.odb files) to be installed and possibly local data
    1. /templates/
      • templates to be installed
    1. /autocorr/
      • .dat files containing replacement rules and exceptions
    1. /wordbooks/
      • dictionaries to be installed
    1. /fonts/
      • fonts to be installed
    1. /gallery/
      • themes to be installed
    1. /goodies/

Dependencies

The objects in the package are not fully independent of others. For instance, a macro may refer to styles coming with a template and be called when the document is created.

Furthermore, some objects in the package may depend on the previous installation of other objects.

Thus, it will be very useful to identify all types of dependencies, and how and where to express them.

Specifications for installation

At this stage, it is necessary to define what will be specified, and how it will be, for the installation process.

It is useless to re-invent the wheel, and it seems a good idea to reuse the structure of the addons.xcu file used by the package manager.

Indeed, this structure is very generic, in the sense that it doesn't contain specific tags. In fact, it's just a set of two columns tables containing properties/values pairs. These tables are organized in a tree where each node has a name as an attribute.

Formally, the XML Schema is as follows:

XML Schema to be described

Now, the work stands in:

  • to define the structure of the tree, and to give a name to each node;
  • for each node, to define the content of the table, i.e. the set of properties/values pairs.

Contributors

--Pallart 16:34, 6 April 2006 (CEST)

Personal tools