##master-page:HelpTemplate
##master-date:Unknown-Date
#format wiki
#language pt

= Introdução =
Alguma vez se questionou sobre o porquê de tantas páginas na distribuição principal? O motivo principal prende-se com o facto de não termos um formato para distribuir as páginas de ajuda num único ficheiro. Ou por que motivo instalar um tema não é fácil, por não saber bem onde colocar os ficheiros?

O instalador de pacotes é uma framework de scripts para o [[WikiMoinMoin|MoinMoin]], que simplifica muito a instalação e a distribuição de extensões para o [[WikiMoinMoin|MoinMoin]].

Pode utilizar este sistema juntar modelos específicos que, por exemplo, desenvolvessem o seu [[WikiMoinMoin|MoinMoin]] para ser um sistema CRM. Ou pode criar os seus plugins/temas instaláveis mais facilmente.

== Instalar um pacote ==
Um ''super utilizador'' (ou seja, um nome de utilizador que pertença à lista cfg.superuser na configuração) do wiki descarregará o seu ficheiro de pacotes de algum sítio e irá enviá-lo para o wiki e clicará em instalar na apresentação dos ficheiros anexados. Adicionalmente, ele podia instalar o pacote utilizando a linha de comando (`MoinMoin/packages.py i package.zip`).

== Criar pacotes ==
Existem várias formas de criar um pacote. Pode utilizar a acção !PackagePages para criar um pacote automaticamente.

Ou pode fazê-lo manualmente: ''cria'' um ficheiro zip que contenha os seus ficheiros e um ficheiro especial `MOIN_PACKAGE`, o script de instalação. O script contém um comando (parece complicado mas na verdade não é; veja os exemplos em baixo) por linha e é executado de cima para baixo.

Script de exemplo:{{{
MoinMoinPackage|1
ReplaceUnderlay|aminhapágina.txt|ConteúdosDeAjuda
AddRevision|aminhapágina2.txt|PáginaPrincipal
InstallPlugin|omeuparser.py|global|parser|omeuparser.py
}}}
 * A primeira linha marca o ficheiro como um ficheiro de script e define a versão do idioma utilizado. Por agora, será 1.
 * A segunda linha substitui a sub-camada da versão da página ConteúdosDeAjuda com o ficheiro `aminhapágina.txt`.
 * A terceira linha adiciona uma nova versão à página PáginaPrincipal, ou seja, altera-a.
 * A quarta linha instala um novo parser.

=== Comandos implementados ===

Tenha em consideração que os comandos não são sensíveis a maiúsculas/minúsculas.

 * `Print|texto`
  * Imprime o texto no resultado do script, o utilizador irá vê-lo depois.
 * `IgnoreExceptions|booleano`
  * Activa a configuração Ignorar Excepções. Se as excepções são ignoradas, o script não parará se uma for encontrada.
 * `SetThemeName|nome de tema`
  * Define o nome do tema a ser alterado a seguir.
 * `CopyThemeFile|nome de ficheiro|tipo|destino`
  * Copia o ficheiro relacionado a um tema (CSS, PNG, etc.) para uma directoria do tema actual.
  * Actualmente é apenas suportando em servidores do tipo standalone.
  * Exemplo: `CopyThemeFile|screen.css|css|screen.css`
 * `InstallPlugin|nome de ficheiro|visibilidade|tipo de plugin|destino`
  * Copia o ficheiro de um plugin a partir do ''nome de ficheiro'' até ao ''destino''. A ''visibilidade'' pode ser `local` que selecciona a pasta de plugins do wiki actual ou `global` que selecciona a pasta do pacote de python do !MoinMoin. O ''tipo de plugin'' pode ser um `parser`, uma `macro`, etc. 
  * Exemplo `InstallPlugin|omeuparser.py|global|parser|omeuparser.py`
 * `AddRevision|nome de ficheiro|nome de página|autor|comentário|trivial`
  * Adiciona uma versão (lida a partir do ficheiro ''nome de ficheiro'') à página ''nome de página''. O ''autor'' especifica o nome do editor e é opcional. O ''comentário'' especifica o comentário da versão e é opcional. O ''trivial'' especifica se a versão é uma edição mínima e é opcional.
  * Exemplo (instala novos ficheiros de modelos):{{{
AddRevision|cliente.tpl|ModeloDeCliente
AddRevision|contacto.tpl|ModeloDeContacto
}}}
 * `DeletePage|nome de página|comentário`
  * Elimina a página ''nome de página'', definindo um ''comentário'' opcionalmente.
  * Exemplo: `DeletePage|PáginaPrincipal`
 * `ReplaceUnderlay|nome de ficheiro|nome de página`
  * Substitui a sub-camada da versão da página. Pode ser utilizada para instalar ou actualizar páginas de sub-camadas.
 * `EnsureVersion|versão|linhas`
  * Cancela o script ou salta linhas se os critérios da versão não forem satisfeitos e se ''linhas'' for especificado.
  * Este exemplo fornece parsers diferentes e instala o correcto: {{{
EnsureVersion|1.3.3|2
InstallPlugin|omeuparser.py_3|global|parser|omeuparser.py
Exit
EnsureVersion|1.3.2
InstallPlugin|omeuparser.py_2|global|parser|omeuparser.py
}}}
 * `Exit`
  * Pára o script.
 * `InstallPackage|Nome de página|Nome de ficheiro`
  * Instala outro pacote que tem de ser um anexo chamado ''Nome de ficheiro'' da página ''Nome de página''.
  * Exemplo: `InstallPackage|PáginaPrincipal|MeuPluginFixe.zip`
 * `AddAttachment|nome de ficheiro no ficheiro zip|nome de ficheiro|nome de página|autor|comentário`
  * Exemplo: `AddAttachment|2_anexo|música.wav|PáginaPrincipal|HansMustermann|é uma música de exemplo.`
 * `DelAttachment|nome de ficheiro|nome de página|autor|comentário`
  * Exemplo: `DelAttachment|música.wav|PáginaPrincipal|HansMustermann|teste`
 * `RenamePage|nome de página|novo nome de página|autor|comentário`
  * Renomeia um nome de página com um novo nome de página