Manual:Developing extensions/pt-br



A cada extensão consta de três partes:


 * 1) Configuração
 * 2) Execução
 * 3) Localização

Uma mera extensão consiste de três arquivos, um para cada parte:


 * MyExtension/extension.json: Armazena as instruções de configuração. O nome do arquivo deve ser “extension.json” (Nas versões anteriores ao MediaWiki 1.25, as instruções de configuração ficavam num arquivo MyExtension/MyExtension.php, nomeado de acordo com a extensão. Várias extensões ainda são compatíveis com aquelas versões neste arquivo PHP).
 * MyExtension/MyExtension_body.php: Armazena o código para a execução da extensão. O nome de arquivo “MyExtension_body.php” é convencional, porém não obrigatório. Caso sua extensão seja complexa, envolvendo vários arquivos PHP, siga a convenção para colocar seu código de implantação num subdiretório MyExtension/includes (embora as extensões Example e BoilerPlate não sigam essa convenção). Por exemplo, veja a extensão.
 * MyExtension/i18n/*.json: Armazena as informações de localização da extensão.

Originalmente, extensões eram feitas num só arquivo, e ainda é possível encontrar alguns exemplo deste estilo depreciado.

Ao desenvolver uma extensão, substitua “MyExtension” (como encontrado acima) pelo nome da sua extensão. Use nomes em UpperCamelCase no diretório e no(s) arquivo(s) PHP; essa é a convenção geral para nomes de arquivos (A é um bom ponto de partida para a sua extensão. Não deixe de conferir também a predefinição cookiecutter para extensões do MediaWiki no GitHub).

As três partes de uma extensão, configuração, execução e localização, bem como os tipos de extensões, licenciamento, e publicação estão todos descritos nas seguintes seções desta página.

Enquanto estiver programando, recomendamos que você desative o cache com as configurações = CACHE_NONE e  = false, ou você poderá não obter mensagens do sistema ou outras mudanças.

Configuração
O seu objetivo em desenvolver a configuração é consolidá-la para que os usuários que instalarem sua extensão não precisem fazer nada além de incluir o arquivo de configuração no arquivo, desta maneira:

Se você deseja fazer com que sua extensão seja configurável pelo usuário, defina e documente alguns parâmetros de configuração. A configuração deve estar desta maneira:

Para alcançar essa simplicidade, seu arquivo de configuração deve efetuar várias tarefas (descritas detalhadamente nas seguintes seções):


 * registrar qualquer manipulador de mídia, função ao analisador sintático, página especial, marcação personalizada de XML e/ou viariável que sua extensão usar;
 * definir e/ou validar quaisquer variáveis de configuração definidos por você para a sua extensão;
 * preparar as classes usadas pela sua extensão para carregamento automático;
 * determinar quais partes da sua configuração devem ser feitas imediatamente e quais precisam estar em modo de espera até o núcleo do MediaWiki ter sido inicializado e configurado;
 * definir hooks adicionais necessários pela sua extensão;
 * criar ou verificar tabelas de banco de dados requeridas pela sua extensão; e
 * configurar a localização para a sua extensão.

Registrando recursos com o MediaWiki
O MediaWiki lista todas as extensões instaladas na página. Por exemplo, é possível ver todas as extensões instaladas nesta wiki na página Special:Version. É bom certificar-se de que a sua extensão também esteja listada naquela página. Para isso, será necessário adicionar um registro em para cada manipulador de mídia, função ao analisador sintático, página especial, marcação personalizada de XML e viariável que sua extensão usar. O registro parecerá assim:

Veja para mais detalhes sobre o quê esses campos fazem. Muitos deles são opcionais, mas preenchê-los por completo é uma boa prática. refere-se à versão do esquema usado pelo arquivo. Como escrito (1.26alpha), a única versão compatível é 1.

Além do registro acima, você também deve fazer um “hook” do seu recurso com o MediaWiki. O texto acima apenas configura a página Special:Version. A maneira com a qual você fará isso depende do tipo da sua extensão. Para mais detalhes, veja a documentação para cada tipo de extensão:

Tornando a extensão configurável pelos usuários
Caso queira que os usuários possam configurar sua extensão, será necessário fornecer uma ou mais variáveis de configuração. É uma boa ideia dar um nome único para cada variável. Também devem ser seguidas as convenções para nomes do MediaWiki (ex.: variáveis globais devem começar com $wg).

Por exemplo, se sua extensão se chamar “Extensãozinha que não faz nada de mais”, tente nomear todas as suas variáveis de configuração para começarem com $Eqnfndm ou $EQNFNDM. As suas escolhas não importam desde que nenhuma extensão do núcleo do MediaWiki comece as variáveis dessa maneira e que você tenha feito um bom trabalho em verificar se nenhuma das extensões publicadas começam as variáveis dessa maneira. Os usuários não ficarão tão felizes em ter de escolher entre a sua e outras extensões pelo fato de você ter usado os mesmos nomes que as outras.

Uma outra boa ideia é incluir uma documentação completa de quaisquer variáveis de configuração nas suas notas de instalação.

Aqui há um exemplo da extensão BoilerPlate que pode ser usado como ponto de partida:

Preparando classes para carregamento automático
Caso escolha ter de usar classes para implementar sua extensão, o MediaWiki fornece um mecanismo simplificado para auxiliar o PHP em encontrar o arquivo-fonte onde sua classe está localizada. Na maioria dos casos, isso deverá eliminar a necessidade de escrever seu próprio método.

Para usar o mecanismo de carregamento automático do MediaWiki, adicione algo ao campo. A chave para cada adição é o nome da classe; o valor é o arquivo armazenador da definição da classe. Para uma extensão de uma só classe, a classe tem geralmente o mesmo nome que a extensão. Dessa maneira, sua seção de carregamento automático deve parecer assim (nesse exemplo, a extensão se chama “MyExtension”):

O nome do arquivo é relativo ao diretório onde se encontra o arquivo extension.json.

Definindo hooks adicionais
Veja (em inglês).

Adicionando tabelas de bancos de dados
Se sua extensão precisar adicionar suas próprias tabelas de bancos de dados, use o hook. Veja a página do manual para mais informações de uso.

Configurando a localização
Veja:
 * Localização (resumo)
 * Localização (em detalhe)

Adicionando registros
No MediaWiki, todas as ações dos usuários numa wiki são rastreadas para transparência e colaboração. Veja (em inglês) para adicionar registros.

Execução
A técnica para desenvolver a implementação depende de qual a parte do sistema do MediaWiki você deseja ampliar:
 * Marcação wiki: Extensões que ampliam as marcações wiki tipicamente contêm um código que define e implementa marcações personalizadas de XML, funções ao analisador sintático e variáveis.
 * Denúncias e administração: Extensões que adicionam capacidades administrativas e de denúncia geralmente as fazem adicionando páginas especiais. Para mais informações, veja (em inglês).
 * Automação de artigos e integridade: Extensões que aumentam a integração entre o MediaWiki e sua base de dados de suporte ou verificam artigos por recursos de integridade tipicamente adicionam funções a um dos vários hooks que afetam o processo de criação, edição, renomeação e apagamento de artigos. Para mais informações sobre estes hooks e como anexar seu código a eles, veja  (em inglês).
 * Aparência e experiência: Extensões que fornecem uma nova aparência e experiência ao MediaWiki são agrupadas em temas. Para mais informações sobre como desenvolver seus próprios temas, veja e  (esse último em inglês).
 * Segurança: Extensões que limitam seus usos a certos usuários devem ser integradas com o sistema de permissões próprio do MediaWiki. Para saber mais sobre este sistema, veja (em inglês). Algumas extensões também permitem que o MediaWiki use de mecanismos de autenticação externos. Para mais informações, veja . Ademais, se sua extensão tentar limitar leitores em certos artigos, por favor, confira os truques discutidos em  (em inglês).

Veja também a página  e a.

Localização
Enquanto estiver desenvolvendo, experimente desativar o cache com as configurações  e , caso contrário suas mudanças nas mensagens do sistema poderão não ser exibidas.

Se você deseja que sua extensão seja usada em wikis com leitores multilíngues, será necessário adicionar compatibilidade a localizações na sua extensão.

Armazenamento de mensagens em .json
Armazene as definições de mensagens em arquivos de localização JSON, um para cada chave de idioma em que sua extensão será traduzida. As mensagens serão salvas com uma chave de mensagem e a mensagem, usando o formato padrão JSON. Todo id de mensagem deve estar em letras minúsculas e sem espaços. Um exemplo pode ser encontrado na extensão MobileFrontend. A seguir, outro exemplo de um pequeno arquivo JSON (neste caso, “en.json”):

en.json

Store message documentation in qqq.json
The documentation for message keys can be stored in the JSON file for the pseudo language with code qqq. A documentation of the example above can be:

qqq.json:

Define messages

 * Assign each message a unique, lowercase, no space message id; e.g.uploadwizard-desc
 * For any text string displayed to the user, define a message.
 * MediaWiki supports parameterized messages and that feature should be used when a message is dependent on information generated at runtime. Parameter placeholders are specified with $n, where n represents the index of the placeholder; e.g.

Define message documentation
Each message you define needs to have an associated message documentation entry Message documentation; in qqq.json e.g.

Load the localisation file
In your setup routine, define the location of your messages files (e.g. in directory i18n/):

Use wfMessage in PHP
In your setup and implementation code, replace each literal use of the message with a call to. In classes that implement (as well as some others such as subclasses of SpecialPage), you can use   instead. Exemplo:

Use mw.message in JavaScript
It's possible to use i18n functions in JavaScript too. Olhar para para obter detalhes.

Tipos de extensões
Extensions can be categorized based on the programming techniques used to achieve their effect. Most complex extensions will use more than one of these techniques:
 * Subclassing: MediaWiki expects certain kinds of extensions to be implemented as subclasses of a MediaWiki-provided base class:
 *  – Subclasses of the class are used to build pages whose content is dynamically generated using a combination of the current system state, user input parameters, and database queries. Both reports and data entry forms can be generated. They are used for both reporting and administration purposes.
 *  – Skins change the look and feel of MediaWiki by altering the code that outputs pages by subclassing the MediaWiki class.
 *  – A technique for injecting custom php code at key points within MediaWiki processing. They are widely used by MediaWiki's parser, its localization engine, its extension management system, and its page maintenance system.
 *  – XML style tags that are associated with a php function that outputs HTML code. You do not need to limit yourself to formatting the text inside the tags. You don't even need to display it. Many tag extensions use the text as parameters that guide the generation of HTML that embeds google objects, data entry forms, RSS feeds, excerpts from selected wiki articles.
 *  – A technique for mapping a variety of wiki text string to a single id that is associated with a function. Both variables and parser functions use this technique. All text mapped to that id will be replaced with the return value of the function. The mapping between the text strings and the id is stored in the array $magicWords. The interpretation of the id is a somewhat complex process – see  for more information.
 *  – Variables are something of a misnomer. They are bits of wikitext that look like templates but have no parameters and have been assigned hard-coded values. Standard wiki markup such as or  are examples of variables. They get their name from the source of their value: a php variable or something that could be assigned to a variable, e.g. a string, a number, an expression, or a function return value.
 *  – .  Similar to tag extensions, parser functions process arguments and returns a value. Unlike tag extensions, the result of parser functions is wikitext.
 *  – you can add custom modules to MediaWiki's "action" web API, that can be invoked by JavaScript, bots or third-party clients.

Support other core versions
You can visit the extension support portal to keep on top of changes in future versions of MediaWiki and also add support for older versions that are still popular.

Publicando
To autocategorize and standardize the documentation of your existing extension, please see. To add your new extension to this Wiki:

Deploying and registering
Consultar. If your extension adds namespaces, you may wish to register its default namespaces; likewise, if it adds database tables or fields, you may want to register those at.

Documentação do ajuda
You should provide public-domain help documentation for features provided by your extension. é um buem exemplo. You should give users a link to the documentation via the function.

Providing support / collaboration
Extension developers should open an account on Wikimedia's, and request a new project for the extension. This provides a public venue where users can submit issues and suggestions, and you can collaborate with users and other developers to triage bugs and plan features of your extension.

Ver também

 * – implements some example features with extensive inline documentation
 * – uma extensão clichê funcionando, útil como um ponto de partida para o seu próprio ramal
 * Read the Example extension, base your own code on the BoilerPlate extension.
 * cookiecutter-mediawiki-extension – a template for the python tool cookiecutter to generate a boilerplate extension (with variables etc.)
 * Allow you to get going quickly with your own extension. Can also generate the BoilerPlate extension.
 * - copy specific code from them
 * – explains how your extension can provide an API to clients
 * – explains how your extension can provide an API to clients