×

微信扫一扫,快捷登录!

标签: 暂无标签
本帖最后由 adminlily 于 2020-12-14 16:40 编辑

向服务器类添加新字段
本文档逐步说明了如何创建自己的iTop模块,以便向现有iTop对象添加新字段。

教程的目标
在本分步教程中,您将学习:

  • 为iTop 2.0创建自己的扩展模块
  • 向现有的对象类添加新字段

出于此教程的目的,我们将在“[  :8082/bin/view/5/5.1/5.1.3/#server]服务器[/url] 对象。



您将需要什么

  • 将iTop安装在开发机器上,您可以在其上轻松地访问编辑文件。
  • 一个文本编辑器,能够编辑PHP和XML文件并支持U-8。在Windows上,您可以使用写字板(记事本不喜欢Unix行结尾)或出色的免费开发IDE之一,例如PSPad 要么记事本++.


定制流程

定制流程如下:

  • 安装iTop的开发实例。最好不要在生产中进行试验!
  • [  :8082/bin/view/5/5.1/5.1.3/#installing_the_toolkit]安装工具包[/url] 协助您进行定制
  • 使用以下命令创建一个新的(空)模块[  :8082/bin/view/5/5.1/5.1.3/#creating_a_module]模块创建向导[/url]
  • 将此新模块复制到iTop上的扩展文件夹中,然后再次运行安装程序以安装空模块
  • 修改扩展中的模块并使用工具包检查您的自定义

重复最后一点,直到对自定义满意为止。完成后,就可以部署新模块了。将模块文件夹复制到生产iTop实例的扩展目录中,然后运行安装程序进行安装。

循序渐进教程创建您的自定义模块
使用[  :8082/bin/view/5/5.1/5.1.3/#creating_a_module]模块创建向导[/url]。用以下值填充表单:

标签价值备注
模块名称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


单击“继续»”开始重新安装。

在单击“下一步»”之前,请确保已选择“更新现有实例”。
继续执行向导的下一步……

您的自定义模块应出现在“扩展”列表中。如果不是这种情况,请检查是否在正确的位置复制了模块文件,并且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[/url]


<?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.

如果在此阶段报告了错误,请通过编辑XML文件来修复它们,然后通过单击工具包页面中的“刷新”按钮再次检查您的修改。
解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:

单击按钮将iTop代码更新为:

  • 将XML数据模型编译为PHP类
  • 更新数据库架构以添加新的文本列。

此时,如果您查看MySQL数据库的架构,则可以看到添加到“服务器”表中的其他“注释”列。但是,如果您导航到iTop中的服务器,则没有任何改变。


这是因为没有指示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[/url]


<?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.

如果在此阶段报告了任何错误,请通过编辑XML文件进行修复,然后单击工具包页面中的“刷新”按钮再次检查您的修改。
解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:
如果现在在iTop中导航到服务器的详细信息,则应看到以下内容:


为新字段添加标签

请注意,新字段的标签为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',
));
?>


再过一次,运行工具包检查您的修改。


如果在此阶段报告了错误,请通过编辑PHP文件进行修复,然后单击工具包页面上的“刷新”按钮再次检查您的修改。
解决所有错误之后,可以使用工具包的第二个选项卡将修改应用于iTop:

如果在iTop中导航到服务器的详细信息,现在应该看到以下内容:


最终定制模块

定制的最终结果可在以下zip文件中找到:

[ ttps://www.itophub.io/wiki/media?media=2_5_0%3Acustomization%3Asample-add-attribute.zip]sample-add-attribute.zip[/url]

下一步
您可以使用同一流程将更多字段添加到同一对象,或更改iTop中的其他对象。

如果希望添加的字段在修改后的对象类的默认“列表”视图或“搜索”表单中显示,则还必须重新定义相应的“表示”列表。
要将定制部署到另一个iTop服务器,只需将文件夹“ sample-add-attribute”复制到iTop的扩展文件夹,然后再次运行安装程序。






上一篇:二次开发-开发方法-自定义扩展-语法样例
下一篇:二次开发-开发方法-创建一个显示器新CI类型
我是谁

写了 312 篇文章,拥有财富 1656,被 3 人关注

您需要登录后才可以回帖 登录 | 立即注册
B Color Link Quote Code Smilies

成为第一个吐槽的人

Powered by IT 运维管理
返回顶部