Install.rdf: Difference between revisions

From MozillaZine Knowledge Base
Jump to navigationJump to search
No edit summary
Line 2: Line 2:
: ''Most of information here applies to install.rdf used in themes too. See [[#install.rdf for themes|below]] for detailed information.''
: ''Most of information here applies to install.rdf used in themes too. See [[#install.rdf for themes|below]] for detailed information.''


Firefox 0.9, Thunderbird 0.7, Nvu 0.? and all subsequent versions of these products use the Extension Manager (''"the EM"'') for managing extensions and themes. In order to have your extension supported by it you have to package your extensions as described in "[http://www.mozilla.org/projects/firefox/extensions/packaging/extensions.html Packaging Firefox/Thunderbird Extensions]" document at mozilla.org. This includes providing a valid '''install.rdf''' file.
Firefox 0.9, Thunderbird 0.7, Nvu 0.? and all subsequent versions of these products use the Extension Manager (''"the EM"'') for managing extensions and themes. In order to have your extension supported by it you have to package your extensions as described in "[http://www.mozilla.org/projects/firefox/extensions/packaging/extensions.html Packaging Firefox/Thunderbird Extensions]" document at mozilla.org (see also documentation at [http://developer.mozilla.org/en/docs/Install_Manifests Devmo]). This includes providing a valid '''install.rdf''' file.


== Creating install.rdf using tools ==
== Creating install.rdf using tools ==
Line 82: Line 82:
Initially, it was recommended to use GUIDs for extensions IDs. To generate a GUID, you can use [http://www.microsoft.com/downloads/details.aspx?FamilyId=94551F58-484F-4A8C-BB39-ADB270833AFC&displaylang=en MS guidgen] (a GUID generator for Windows NT-based systems), uuidgen (for *nix), a web-based generator such as [http://kruithof.xs4all.nl/uuid/uuidgen this] and [http://www.hoskinson.net/webservices/guidgeneratorclient.aspx this], or open your [[IRC]] client, go to ''irc://irc.mozilla.org/botbot'' and say 'botbot uuid'.
Initially, it was recommended to use GUIDs for extensions IDs. To generate a GUID, you can use [http://www.microsoft.com/downloads/details.aspx?FamilyId=94551F58-484F-4A8C-BB39-ADB270833AFC&displaylang=en MS guidgen] (a GUID generator for Windows NT-based systems), uuidgen (for *nix), a web-based generator such as [http://kruithof.xs4all.nl/uuid/uuidgen this] and [http://www.hoskinson.net/webservices/guidgeneratorclient.aspx this], or open your [[IRC]] client, go to ''irc://irc.mozilla.org/botbot'' and say 'botbot uuid'.


Extension Manager in Toolkit 1.1a-based applications '''will not install''' extensions using arbitrary strings as their IDs. Only GUIDs and IDs of ''extension@domain'' form are now accepted (in addition to GUIDs). For example, the DOM Inspector has ''inspector@mozilla.org'' ID.
Extension Manager in Toolkit 1.5-based applications '''will not install''' extensions using arbitrary strings as their IDs. Only GUIDs and IDs of ''extension@domain'' form are now accepted. For example, the DOM Inspector has ''inspector@mozilla.org'' ID.


== Versioning ==
== Versioning ==
As stated in the [http://www.mozilla.org/projects/firefox/extensions/update.html official documentation] on  mozilla.org, extension versions must be of form '''major.minor.release.build[+]'''. Old-style versions like 0.5pre are now invalid.
As stated in the [http://www.mozilla.org/projects/firefox/extensions/update.html official documentation] on  mozilla.org, extension versions must be of form '''major.minor.release.build[+]'''. Old-style versions like 0.5pre are now invalid.


Note that in the targetApplication section, the version number for minVersion and maxVersion should be in the form x.x, such as 1.0.  Requiring a specific minor version of Firefox such as 1.0.3 isn't supported.
Note that in the targetApplication section, the version number for minVersion and maxVersion should be in the form x.x, such as 1.0.  Requiring a specific minor version of Firefox such as 1.0.3 isn't supported. That is because the minimum and maximum versions specified in the targetApplication section are compared against the value of <code>app.extensions.version</code> preference, which is the same (1.0) for all 1.0.x releases.


== install.rdf for themes ==
== install.rdf for themes ==

Revision as of 14:39, 14 August 2005

This page is part of the extension development documentation project.

Ask your questions in MozillaZine Forums. Also try browsing example code.

Note: development documentation is in process of being moved to Mozilla Development Center (MDC).

Most of information here applies to install.rdf used in themes too. See below for detailed information.

Firefox 0.9, Thunderbird 0.7, Nvu 0.? and all subsequent versions of these products use the Extension Manager ("the EM") for managing extensions and themes. In order to have your extension supported by it you have to package your extensions as described in "Packaging Firefox/Thunderbird Extensions" document at mozilla.org (see also documentation at Devmo). This includes providing a valid install.rdf file.

Creating install.rdf using tools

You can use any of these tools:

Template

If you choose to manually create an "install.rdf" file, you can use the template below as a guide.

<?xml version="1.0"?>
<RDF xmlns="http://www.w3.org/1999/02/22-rdf-syntax-ns#" 
     xmlns:em="http://www.mozilla.org/2004/em-rdf#">

	<Description about="urn:mozilla:install-manifest">
	
		<em:id>{XXXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}</em:id>
		<em:name>Sample Extension</em:name>
		<em:version>1.0</em:version>
		<em:description>A sample extension with advanced features</em:description>
		<em:creator>Your Name Here</em:creator>
		<!-- optional items -->
		<em:contributor>A person who helped you</em:contributor>
		<em:contributor>Another one</em:contributor>
		<em:homepageURL>http://sampleextension.mozdev.org/</em:homepageURL>
		<em:optionsURL>chrome://sampleext/content/settings.xul</em:optionsURL>
		<em:aboutURL>chrome://sampleext/content/about.xul</em:aboutURL>
		<em:iconURL>chrome://sampleext/skin/mainicon.png</em:iconURL>
		<em:updateURL>http://sampleextension.mozdev.org/update.rdf</em:updateURL>
		<em:type>2</em:type> <!-- type=extension --> 

                <!-- Firefox -->
		<em:targetApplication>
			<Description>
				<em:id>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</em:id>
				<em:minVersion>0.9</em:minVersion>
				<em:maxVersion>1.0</em:maxVersion>
			</Description>
		</em:targetApplication>

                <!-- This is not needed for Firefox 1.1 and later. Only include this 
                     if you want to make your extension compatible with older versions -->
		<em:file>
			<Description about="urn:mozilla:extension:file:sampleext.jar">
				<em:package>content/</em:package>
				<!-- optional items -->
				<em:skin>skin/classic/</em:skin>
				<em:locale>locale/en-US/</em:locale>
				<em:locale>locale/ru-RU/</em:locale>
			</Description>
		</em:file>
	</Description>

</RDF>

Target applications' GUIDs

Firefox {ec8030f7-c20a-464f-9b0e-13a3a9e97384}
Thunderbird {3550f703-e582-4d05-9a08-453d09bdfdc6}
Nvu {136c295a-4a5a-41cf-bf24-5cee526720d5}
Mozilla Suite {86c18b42-e466-45a9-ae7a-9b95ba6f5640}
SeaMonkey {92650c4d-4b8e-4d2a-b7eb-24ecf4f6b63a}
Sunbird {718e30fb-e89b-41dd-9da7-e25a45638b28}
Netscape Browser{3db10fab-e461-4c80-8b97-957ad5f8ea47}

Notes

  • Mozilla Suite ignores install.rdf, but you ought to include corresponding targetApplication item in install.rdf if you support the Suite and are going to submit your extension to update.mozilla.org, see this thread. You still must include an install.js file if you support Mozilla Suite.
  • "SeaMonkey" is now the name of the community project, that continues working on the Mozilla Suite codebase, after Mozilla Foundation has announced it will not actively develop the Mozilla Suite any further. At the moment it doesn't read install.rdf, just as the Mozilla Suite, but it's planned to implement this in future.
  • The em:type arc was introduced in Toolkit 1.1a applications. It's used to specify the type of an item. Use the value of 2 for extensions, 4 for themes.

Items' IDs

Each extension must have an unique ID (the value of em:id arc).

Initially, it was recommended to use GUIDs for extensions IDs. To generate a GUID, you can use MS guidgen (a GUID generator for Windows NT-based systems), uuidgen (for *nix), a web-based generator such as this and this, or open your IRC client, go to irc://irc.mozilla.org/botbot and say 'botbot uuid'.

Extension Manager in Toolkit 1.5-based applications will not install extensions using arbitrary strings as their IDs. Only GUIDs and IDs of extension@domain form are now accepted. For example, the DOM Inspector has inspector@mozilla.org ID.

Versioning

As stated in the official documentation on mozilla.org, extension versions must be of form major.minor.release.build[+]. Old-style versions like 0.5pre are now invalid.

Note that in the targetApplication section, the version number for minVersion and maxVersion should be in the form x.x, such as 1.0. Requiring a specific minor version of Firefox such as 1.0.3 isn't supported. That is because the minimum and maximum versions specified in the targetApplication section are compared against the value of app.extensions.version preference, which is the same (1.0) for all 1.0.x releases.

install.rdf for themes

TBD. See [2]. The main difference is the additional "em:internalName" arc in theme's manifest.