Tal como a automação de plug-ins, os plug-ins de origem são definidos com três arquivos: upgrade.xml, info.xml e plugin.xml. A estrutura dos primeiros dois arquivos é idêntica para ambos os tipos de plug-in. A estrutura do arquivo plugin.xml varia dependendo do tipo de plug-in. A estrutura do arquivo plugin.xml para plug-ins de origem está descrita neste tópico. Para obter informações sobre o arquivo plugin.xml para plug-ins de automação, consulte O arquivo plugin.xml para plug-ins de automação.
A tag <server:plugin-type>Source</server:plugin-type> identifica o tipo de plug-in. Para plug-ins de origem, o tipo deve ser Source:
<?xml version="1.0" encoding="UTF-8"?>
<!-- the xmlns:server argument is necessary to parse the tags with the server prefix -->
<plugin xmlns="http://www.urbancode.com/PluginXMLSchema_v1"
xmlns:server="http://www.urbancode.com/PluginServerXMLSchema_v1"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<header>
<identifier id="com.urbancode.air.plugin.source.Name" name="Plugin Name" version="1"/>
<description>Short description</description>
<tag>SCM/Name</tag>
<server:plugin-type>Source</server:plugin-type>
</header>
Um plug-in de origem possui uma etapa, que deve ser denominada Importa Version:
<step-type name="Import Version">
<description>Creates a new component version and imports artifacts</description>
<properties>
</properties>
<post-processing><![CDATA[
if (properties.get("exitCode") != 0) {
properties.put(new java.lang.String("Status"), new java.lang.String("Failure"));
}
else {
properties.put("Status", "Success");
}
]]></post-processing>
<command program="${JAVA_HOME}/bin/java">
<arg value="${JAVA_OPTS}"/>
<arg value="-jar"/>
<arg file="FileSystemSourceConfig.jar"/>
<arg value="ImportVersion"/>
<arg file="${PLUGIN_INPUT_PROPS}"/>
<arg file="${PLUGIN_OUTPUT_PROPS}"/>
</command>
</step-type>
Conforme mostrado no fragmento de código a seguir, os plug-ins de origem possuem dois grupos de propriedades. As propriedades do tipo Component são configuradas com a janela Criar Novo Componente. As propriedades do tipo Import são configuradas com a janela Importar Componente.
<!-- ==================================== -->
<!-- Properties -->
<!-- ==================================== -->
<server:property-group type="Component" name="FileSystemComponentProperties">
<server:property name="property-name" required="true">
<server:property-ui type="textBox"
label="property-label"
description="property-description" />
</server:property>
</server:property-group>
<!-- If left empty or omitted then no dialog will appear -->
<server:property-group type="Import" name="FileSystemImportProperties">
<server:property name="property-name" required="true">
<server:property-ui type="textBox"
label="property-label"
description="property-description" />
</server:property>
</server:property-group>
</plugin>