二次开发-开发方法-为服务器类创建一个新字段
本帖最后由 adminlily 于 2020-12-14 16:40 编辑向服务器类添加新字段本文档逐步说明了如何创建自己的iTop模块,以便向现有iTop对象添加新字段。
教程的目标
在本分步教程中,您将学习:
[*]为iTop 2.0创建自己的扩展模块
[*]向现有的对象类添加新字段
出于此教程的目的,我们将在“[:8082/bin/view/5/5.1/5.1.3/#server]服务器 对象。
https://www.itophub.io/wiki/media?w=600&tok=4e38d8&media=2_5_0%3Acustomization%3Aextension-server-ok.png
您将需要什么
[*]将iTop安装在开发机器上,您可以在其上轻松地访问编辑文件。
[*]一个文本编辑器,能够编辑PHP和XML文件并支持U-8。在Windows上,您可以使用写字板(记事本不喜欢Unix行结尾)或出色的免费开发IDE之一,例如PSPad 要么记事本++.
定制流程
定制流程如下:
[*]安装iTop的开发实例。最好不要在生产中进行试验!
[*][:8082/bin/view/5/5.1/5.1.3/#installing_the_toolkit]安装工具包 协助您进行定制
[*]使用以下命令创建一个新的(空)模块[:8082/bin/view/5/5.1/5.1.3/#creating_a_module]模块创建向导
[*]将此新模块复制到iTop上的扩展文件夹中,然后再次运行安装程序以安装空模块
[*]修改扩展中的模块并使用工具包检查您的自定义
重复最后一点,直到对自定义满意为止。完成后,就可以部署新模块了。将模块文件夹复制到生产iTop实例的扩展目录中,然后运行安装程序进行安装。
循序渐进教程创建您的自定义模块
使用[:8082/bin/view/5/5.1/5.1.3/#creating_a_module]模块创建向导。用以下值填充表单:
标签价值备注
模块名称sample-add-attribute以itop-和combodo-开头的名称保留供Combodo使用。建议不要在模块名称中添加空格或强调字符。具有相同名称的两个模块不能在同一iTop实例中共存。
模块标签Add Attribute Sample该标签将显示在设置向导中。允许使用本地化的字符和空格
模块版本1.0.0惯例是使用3位数编号方案:X.Y.Z
类别business对数据模型进行修改的模块应位于类别'业务'中
依存关系itop-configmgmt-2.0.0我们的定制模块依赖于定义了服务器类的模块iTop配置管理版本2.0.0。
单击生成!将空模块下载为zip文件。
当模块修改现有类时,必须在声明要修改该类的模块之后加载它。为此,请确保新模块的依赖项中列出了第一个模块。
例如,如果要更改VirtualMachine类的定义,则自定义模块必须依赖于itop-virtualization-mgmtt2.0.0
安装空模块
将zip的内容扩展到开发iTop实例的扩展文件夹中。现在,您应该在扩展文件夹中有一个名为sample-add-attribute的文件夹。此文件夹包含以下文件:
[*]datamodel.sample-add-attribute.xml
[*]module.sample-add-attribute.php
[*]en.dict.sample-add-attribute.php
[*]model.sample-add-attribute.php
确保Web服务器的文件conf/production/config-itop.php是可写的(在Windows上:右键单击以显示文件属性,并取消选中只读标志;在Linux变更上为文件的权利),然后通过以下方式启动iTop安装:将您的浏览器指向http ::: your_itop/setupp
https://www.itophub.io/wiki/media?w=300&tok=4a0310&media=2_5_0%3Acustomization%3Aextension-installation1.png
单击“继续»”开始重新安装。
https://www.itophub.io/wiki/media?w=300&tok=da0485&media=2_5_0%3Acustomization%3Ainstall-extension-2.png在单击“下一步»”之前,请确保已选择“更新现有实例”。https://www.itophub.io/wiki/media?w=300&tok=d0b59e&media=2_5_0%3Acustomization%3Aupgrade-screenshot2.png继续执行向导的下一步……https://www.itophub.io/wiki/media?w=300&tok=726511&media=2_5_0%3Acustomization%3Aextension-installation7.png
您的自定义模块应出现在“扩展”列表中。如果不是这种情况,请检查是否在正确的位置复制了模块文件,并且Web服务器具有足够的权利可以读取它们。
在单击“下一步»”之前,请选择您的自定义模块并完成安装。
向服务器类添加新字段
使用常用文本编辑器,打开文件datamodel.sample-add-attribute.xml.
删除标签<menus> << menus>,因为该模块将不包含任何菜单定义。
在标签类中,添加以下代码:
<class id="Server">
<fields>
<field id="notes" xsi:type="AttributeText" _delta="define">
<sql>notes</sql>
<default_value/>
<is_null_allowed>true</is_null_allowed>
</field>
</fields>
</class>
这指示iTop通过添加类型为AttributeText的新字段(请注意标签字段上的_delta =“ define”)来修改现有类“服务器”。这个新字段被命名为notes(因为它是使用id =“ notes”定义的)。相应的值将存储在数据库的注释栏中(由于定义<sql> notes << sql>)。
有关标签字段各种参数含义的更多信息(以及所有可能类型的字段的列表),请参考XML引用文档.
现在,您应该具有以下XML文件:
[ ttps://www.itophub.io/wiki/page?do=export_code&id=2_5_0%3Acustomization%3Aadd-attribute-sample&codeblock=1]datamodel.sample-add-attribute.xml
<?xml version="1.0" encoding="UTF-8"?>
<itop_design xmlns:xsi="2001/XMLSchema-instance" version="1.0">
<classes>
<class id="Server">
<fields>
<field id="notes" xsi:type="AttributeText" _delta="define">
<sql>notes</sql>
<default_value/>
<is_null_allowed>true</is_null_allowed>
</field>
</fields>
</class>
</classes>
</itop_design>
通过运行工具包检查您的修改。将浏览器指向toolkit.
https://www.itophub.io/wiki/media?w=600&tok=fd9e6b&media=2_5_0%3Acustomization%3Atoolkit1.png如果在此阶段报告了错误,请通过编辑XML文件来修复它们,然后通过单击工具包页面中的“刷新”按钮再次检查您的修改。解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:https://www.itophub.io/wiki/media?w=600&tok=d9626b&media=2_5_0%3Acustomization%3Atoolkit2.png
单击按钮将iTop代码更新为:
[*]将XML数据模型编译为PHP类
[*]更新数据库架构以添加新的文本列。
此时,如果您查看MySQL数据库的架构,则可以看到添加到“服务器”表中的其他“注释”列。但是,如果您导航到iTop中的服务器,则没有任何改变。
https://www.itophub.io/wiki/media?w=500&tok=be7914&media=2_5_0%3Acustomization%3Aextension-dbschema.png
这是因为没有指示iTop如何显示添加的字段。因此,该字段存在,但未在iTop中显示。
使新字段可见
让我们将新字段添加到服务器对象的“详细信息”中,就在“说明”下方。这可以通过重新定义服务器的“详细信息”的显示方式来实现。
使用文本编辑器打开文件datamodels/2.xxitop-config-mgmt/datamodel.itop-config-mgmt.xml。
搜索用于字符串<class id =“Server”,以定位服务器类的定义。
向下滚动到<presentation>标签,然后复制<details>…</ details>标签的全部内容。
将整个定义粘贴在结束</ field>标签之后的datamodel.sample-add-属性。xml中,并将其包含在<presentation>…</ presentation>标记中。
变更将标签的<details>打开为<details _delta =“ redefine”>,以指示iTop重新定义表示形式的“详细信息”。
插入3行:
<item id="notes">
<rank>40</rank>
</item>在行之后: <item id="description">
<rank>30</rank>
</item>
现在,您应该获取以下XML文件:
[ ttps://www.itophub.io/wiki/page?do=export_code&id=2_5_0%3Acustomization%3Aadd-attribute-sample&codeblock=4]datamodel.sample-add-attribute.xml
<?xml version="1.0" encoding="UTF-8"?>
<itop_design xmlns:xsi="2001/XMLSchema-instance" version="1.0">
<classes>
<class id="Server">
<fields>
<field id="notes" xsi:type="AttributeText" _delta="define">
<sql>notes</sql>
<default_value/>
<is_null_allowed>true</is_null_allowed>
</field>
</fields>
<presentation>
<details _delta="redefine">
<items>
<item id="softwares_list">
<rank>10</rank>
</item>
<item id="contacts_list">
<rank>20</rank>
</item>
<item id="documents_list">
<rank>30</rank>
</item>
<item id="tickets_list">
<rank>40</rank>
</item>
<item id="physicalinterface_list">
<rank>50</rank>
</item>
<item id="fiberinterfacelist_list">
<rank>60</rank>
</item>
<item id="networkdevice_list">
<rank>70</rank>
</item>
<item id="san_list">
<rank>80</rank>
</item>
<item id="logicalvolumes_list">
<rank>90</rank>
</item>
<item id="providercontracts_list">
<rank>100</rank>
</item>
<item id="services_list">
<rank>110</rank>
</item>
<item id="col:col1">
<rank>120</rank>
<items>
<item id="fieldset:Server:baseinfo">
<rank>10</rank>
<items>
<item id="name">
<rank>10</rank>
</item>
<item id="org_id">
<rank>20</rank>
</item>
<item id="status">
<rank>30</rank>
</item>
<item id="business_criticity">
<rank>40</rank>
</item>
<item id="location_id">
<rank>50</rank>
</item>
<item id="rack_id">
<rank>60</rank>
</item>
<item id="enclosure_id">
<rank>70</rank>
</item>
</items>
</item>
<item id="fieldset:Server:moreinfo">
<rank>20</rank>
<items>
<item id="brand_id">
<rank>10</rank>
</item>
<item id="model_id">
<rank>20</rank>
</item>
<item id="osfamily_id">
<rank>30</rank>
</item>
<item id="osversion_id">
<rank>40</rank>
</item>
<item id="oslicence_id">
<rank>50</rank>
</item>
<item id="cpu">
<rank>60</rank>
</item>
<item id="ram">
<rank>70</rank>
</item>
<item id="nb_u">
<rank>80</rank>
</item>
<item id="serialnumber">
<rank>90</rank>
</item>
<item id="asset_number">
<rank>100</rank>
</item>
</items>
</item>
</items>
</item>
<item id="col:col2">
<rank>130</rank>
<items>
<item id="fieldset:Server:Date">
<rank>10</rank>
<items>
<item id="move2production">
<rank>10</rank>
</item>
<item id="purchase_date">
<rank>20</rank>
</item>
<item id="end_of_warranty">
<rank>30</rank>
</item>
</items>
</item>
<item id="fieldset:Server:otherinfo">
<rank>20</rank>
<items>
<item id="powerA_id">
<rank>10</rank>
</item>
<item id="powerB_id">
<rank>20</rank>
</item>
<item id="description">
<rank>30</rank>
</item>
<item id="notes">
<rank>40</rank>
</item>
</items>
</item>
</items>
</item>
</items>
</details>
</presentation>
</class>
</classes>
</itop_design>
通过运行工具包检查您的修改。将浏览器指向toolkit.
https://www.itophub.io/wiki/media?w=600&tok=fd9e6b&media=2_5_0%3Acustomization%3Atoolkit1.png如果在此阶段报告了任何错误,请通过编辑XML文件进行修复,然后单击工具包页面中的“刷新”按钮再次检查您的修改。解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:https://www.itophub.io/wiki/media?w=600&tok=d9626b&media=2_5_0%3Acustomization%3Atoolkit2.png如果现在在iTop中导航到服务器的详细信息,则应看到以下内容:https://www.itophub.io/wiki/media?w=600&tok=555816&media=2_5_0%3Acustomization%3Aextension-nodict.png
为新字段添加标签
请注意,新字段的标签为iTop is notes(默认情况下,它等于字段名称)。为了变更到附加注释,我们必须在字典中添加一个条目。使用文本编辑器打开文件en.dict.sample-add-attribute.php。
插入行:
'Class:Server/Attribute:notes' => 'Additional Notes',
在评论下方:
字典条目去这里
您应该获取以下文件:
<?php/** * Localized data * * @copyright Copyright (C) 2013 Your Company * @license licenses/AGPL-3.0 */ Dict::Add('EN US', 'English', 'English', ( // Dictionary entries go here 'Class:Server/Attribute:notes' => 'Additional Notes',));?>
再过一次,运行工具包检查您的修改。
https://www.itophub.io/wiki/media?w=600&tok=fd9e6b&media=2_5_0%3Acustomization%3Atoolkit1.png
如果在此阶段报告了错误,请通过编辑PHP文件进行修复,然后单击工具包页面上的“刷新”按钮再次检查您的修改。解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:
https://www.itophub.io/wiki/media?w=600&tok=d9626b&media=2_5_0%3Acustomization%3Atoolkit2.png如果在iTop中导航到服务器的详细信息,现在应该看到以下内容:https://www.itophub.io/wiki/media?w=600&tok=4e38d8&media=2_5_0%3Acustomization%3Aextension-server-ok.png
最终定制模块
定制的最终结果可在以下zip文件中找到:
[ ttps://www.itophub.io/wiki/media?media=2_5_0%3Acustomization%3Asample-add-attribute.zip]sample-add-attribute.zip
下一步
您可以使用同一流程将更多字段添加到同一对象,或更改iTop中的其他对象。
如果希望添加的字段在修改后的对象类的默认“列表”视图或“搜索”表单中显示,则还必须重新定义相应的“表示”列表。要将定制部署到另一个iTop服务器,只需将文件夹“ sample-add-attribute”复制到iTop的扩展文件夹,然后再次运行安装程序。
页:
[1]