<!DOCTYPE node PUBLIC
'-//freedesktop//DTD D-BUS Object Introspection 1.0//EN'
'http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd'>
<node>

  <!--
      org.gnome.Shell.Extensions:
      @short_description: Extensions interface

      The interface used to query and manage extensions.
  -->
  <interface name="org.gnome.Shell.Extensions">

    <!--
        ListExtensions:
        @extensions: A dictionary of extension infos

        Get a list of installed extensions. The returned @extensions
        dictionary maps extension UUIDs to info vardicts. See
        GetExtensionInfo() for documentation on possible keys.
    -->
    <method name="ListExtensions">
      <arg type="a{sa{sv}}" direction="out" name="extensions"/>
    </method>

    <!--
        GetExtensionInfo:
        @uuid: The UUID of the extension
        @info: The returned extension info

        The information returned in the @info vardict depends on the
        metadata the extension provides, however it is guaranteed to
        contain the following keys:

        <variablelist>
          <varlistentry>
            <term>uuid s</term>
            <listitem><para>The UUID of the extension</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>name s</term>
            <listitem><para>The name of the extension</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>description s</term>
            <listitem><para>
              A short summary that describes what the extension does
            </para></listitem>
          </varlistentry>

          <varlistentry>
            <term>shell-version as</term>
            <listitem><para>An array of support shell versions</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>type d</term>
            <listitem><para>
              The type of extension:
              <simplelist>
                <member>1: SYSTEM</member>
                <member>2: PER_USER</member>
              </simplelist>
            </para></listitem>
          </varlistentry>

          <varlistentry>
            <term>state d</term>
            <listitem><para>
              The state the extension is in:
              <simplelist>
                <member>1: ENABLED</member>
                <member>2: DISABLED</member>
                <member>3: ERROR</member>
                <member>4: OUT_OF_DATE</member>
                <member>5: DOWNLOADING</member>
                <member>6: INITIALIZED</member>
                <member>7: DISABLING</member>
                <member>8: ENABLING</member>
                <member>99: UNINSTALLED</member>
              </simplelist>
            </para></listitem>
          </varlistentry>

          <varlistentry>
            <term>path s</term>
            <listitem><para>The extension directory</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>error s</term>
            <listitem><para>The most recent error caught in init(), enable() or disable()</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>hasPrefs b</term>
            <listitem><para>Whether the extension includes preference UI</para></listitem>
          </varlistentry>
        </variablelist>

        By convention, many extensions will also include the following keys:
        <variablelist>
          <varlistentry>
            <term>version d</term>
            <listitem><para>The extension version</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>url s</term>
            <listitem><para>The URL to the extension homepage or repository</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>settings-schema s</term>
            <listitem><para>The ID of a bundled GSettings schema</para></listitem>
          </varlistentry>

          <varlistentry>
            <term>gettext-domain s</term>
            <listitem><para>The domain used for translations</para></listitem>
          </varlistentry>
        </variablelist>
    -->
    <method name="GetExtensionInfo">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="a{sv}" direction="out" name="info"/>
    </method>

    <!--
        GetExtensionErrors:
        @uuid: The UUID of the extension
        @errors: The returned errors

        Get the list of errors that caused the extension
        to be in ERROR state.
    -->
    <method name="GetExtensionErrors">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="as" direction="out" name="errors"/>
    </method>

    <!--
        InstallRemoteExtension:
        @uuid: The UUID of the extension
        @result: The result of the operation

        Download and install an extension.
    -->
    <method name="InstallRemoteExtension">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="s" direction="out" name="result"/>
    </method>

    <!--
        UninstallExtension:
        @uuid: The UUID of the extension
        @success: Whether the operation was successful

        Uninstall an extension.
    -->
    <method name="UninstallExtension">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="b" direction="out" name="success"/>
    </method>

    <!--
        ReloadExtension:
        @uuid: The UUID of the extension

        Reload an extension.
    -->
    <method name="ReloadExtension">
      <arg type="s" direction="in" name="uuid"/>
    </method>

    <!--
        EnableExtension:
        @uuid: The UUID of the extension
        @success: Whether the operation was successful

        Enable an extension.
    -->
    <method name="EnableExtension">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="b" direction="out" name="success"/>
    </method>

    <!--
        DisableExtension:
        @uuid: The UUID of the extension
        @success: Whether the operation was successful

        Disable an extension.
    -->
    <method name="DisableExtension">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="b" direction="out" name="success"/>
    </method>

    <!--
        LaunchExtensionPrefs:
        Deprecated for OpenExtensionPrefs
    -->
    <method name="LaunchExtensionPrefs">
      <arg type="s" direction="in" name="uuid"/>
    </method>

    <!--
        OpenExtensionPrefs:
        @uuid: The UUID of the extension
        @parent_window: Identifier for the application window
        @options: Vardict with further options

        Opens the prefs dialog of extension @uuid.

        The following @options are recognized:

        <variablelist>
          <varlistentry>
            <term>modal b</term>
            <listitem>
              <para>Whether the prefs window should be modal, default: false</para>
            </listitem>
          </varlistentry>
        </variablelist>
    -->
    <method name="OpenExtensionPrefs">
      <arg type="s" direction="in" name="uuid"/>
      <arg type="s" direction="in" name="parent_window"/>
      <arg type="a{sv}" direction="in" name="options"/>
    </method>

    <!--
        CheckForUpdates:
        Update all extensions for which updates are available
    -->
    <method name="CheckForUpdates"/>

    <signal name="ExtensionStateChanged">
      <arg type="s" name="uuid"/>
      <arg type="a{sv}" name="state"/>
    </signal>

    <!--
        ExtensionStatusChanged:
        Deprecated for ExtensionStateChanged
    -->
    <signal name="ExtensionStatusChanged">
      <arg type="s" name="uuid"/>
      <arg type="i" name="state"/>
      <arg type="s" name="error"/>
    </signal>

    <!--
        ShellVersion:
        The GNOME Shell version
    -->
    <property name="ShellVersion" type="s" access="read"/>

    <!--
        UserExtensionsEnabled:
        Whether user extensions are enabled
    -->
    <property name="UserExtensionsEnabled" type="b" access="readwrite"/>

  </interface>
</node>