DatabaseTableFieldModule.class.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?php
  2. /**
  3. * @name eolinker ams open source,eolinker开源版本
  4. * @link https://www.eolinker.com/
  5. * @package eolinker
  6. * @author www.eolinker.com 广州银云信息科技有限公司 ©2015-2018
  7. * eoLinker是目前全球领先、国内最大的在线API接口管理平台,提供自动生成API文档、API自动化测试、Mock测试、团队协作等功能,旨在解决由于前后端分离导致的开发效率低下问题。
  8. * 如在使用的过程中有任何问题,欢迎加入用户讨论群进行反馈,我们将会以最快的速度,最好的服务态度为您解决问题。
  9. *
  10. * eoLinker AMS开源版的开源协议遵循Apache License 2.0,如需获取最新的eolinker开源版以及相关资讯,请访问:https://www.eolinker.com/#/os/download
  11. *
  12. * 官方网站:https://www.eolinker.com/
  13. * 官方博客以及社区:http://blog.eolinker.com/
  14. * 使用教程以及帮助:http://help.eolinker.com/
  15. * 商务合作邮箱:market@eolinker.com
  16. * 用户讨论QQ群:284421832
  17. */
  18. class DatabaseTableFieldModule
  19. {
  20. public function __construct()
  21. {
  22. @session_start();
  23. }
  24. /**
  25. * 获取数据字典用户类型
  26. * @param $fieldID int 字段ID
  27. * @return bool|int
  28. */
  29. public function getUserType(&$fieldID)
  30. {
  31. $fieldDao = new DatabaseTableFieldDao();
  32. $dbID = $fieldDao->checkFieldPermission($fieldID, $_SESSION['userID']);
  33. if (empty($dbID)) {
  34. return -1;
  35. }
  36. $dao = new AuthorizationDao();
  37. $result = $dao->getDatabaseUserType($_SESSION['userID'], $dbID);
  38. if ($result === FALSE) {
  39. return -1;
  40. } else {
  41. return $result;
  42. }
  43. }
  44. /**
  45. * 添加字段
  46. * @param $tableID int 数据表ID
  47. * @param $fieldName string 字段名
  48. * @param $fieldType string 字段类型
  49. * @param $fieldLength int 字段长度
  50. * @param $isNotNull int 是否非空 [0/1]=>[否/是],默认为0
  51. * @param $isPrimaryKey int 是否为主键 [0/1]=>[否/是],默认为0
  52. * @param $fieldDesc string 字段描述,默认为NULL
  53. * @return bool|int
  54. */
  55. public function addField(&$tableID, &$fieldName, &$fieldType, &$fieldLength, &$isNotNull, &$isPrimaryKey, &$fieldDesc, &$fieldDefaultValue)
  56. {
  57. $databaseDao = new DatabaseDao;
  58. $databaseTableDao = new DatabaseTableDao;
  59. $databaseTableFieldDao = new DatabaseTableFieldDao;
  60. if ($dbID = $databaseTableDao->checkTablePermission($tableID, $_SESSION['userID'])) {
  61. $databaseDao->updateDatabaseUpdateTime($dbID);
  62. return $databaseTableFieldDao->addField($tableID, $fieldName, $fieldType, $fieldLength, $isNotNull, $isPrimaryKey, $fieldDesc, $fieldDefaultValue);
  63. } else
  64. return FALSE;
  65. }
  66. /**
  67. * 删除字段
  68. * @param $fieldID int 字段ID
  69. * @return bool
  70. */
  71. public function deleteField(&$fieldID)
  72. {
  73. $databaseDao = new DatabaseDao;
  74. $databaseTableFieldDao = new DatabaseTableFieldDao;
  75. if ($dbID = $databaseTableFieldDao->checkFieldPermission($fieldID, $_SESSION['userID'])) {
  76. $databaseDao->updateDatabaseUpdateTime($dbID);
  77. return $databaseTableFieldDao->deleteField($fieldID);
  78. } else
  79. return FALSE;
  80. }
  81. /**
  82. * 获取字段列表
  83. * @param $tableID int 数据表ID
  84. * @return bool|array
  85. */
  86. public function getField(&$tableID)
  87. {
  88. $databaseDao = new DatabaseDao;
  89. $databaseTableDao = new DatabaseTableDao;
  90. $databaseTableFieldDao = new DatabaseTableFieldDao;
  91. if ($dbID = $databaseTableDao->checkTablePermission($tableID, $_SESSION['userID'])) {
  92. $databaseDao->updateDatabaseUpdateTime($dbID);
  93. return $databaseTableFieldDao->getField($tableID);
  94. } else
  95. return FALSE;
  96. }
  97. /**
  98. * 修改字段
  99. * @param $fieldID int 字段ID
  100. * @param $fieldName string 字段名
  101. * @param $fieldType string 字段类型
  102. * @param $fieldLength int 字段长度
  103. * @param $isNotNull int 是否非空 [0/1]=>[否/是],默认为0
  104. * @param $isPrimaryKey int 是否为主键 [0/1]=>[否/是],默认为0
  105. * @param $fieldDesc string 字段描述,默认为NULL
  106. * @return bool
  107. */
  108. public function editField(&$fieldID, &$fieldName, &$fieldType, &$fieldLength, &$isNotNull, &$isPrimaryKey, &$fieldDesc, &$fieldDefaultValue)
  109. {
  110. $databaseDao = new DatabaseDao;
  111. $databaseTableFieldDao = new DatabaseTableFieldDao;
  112. if ($dbID = $databaseTableFieldDao->checkFieldPermission($fieldID, $_SESSION['userID'])) {
  113. $databaseDao->updateDatabaseUpdateTime($dbID);
  114. return $databaseTableFieldDao->editField($fieldID, $fieldName, $fieldType, $fieldLength, $isNotNull, $isPrimaryKey, $fieldDesc, $fieldDefaultValue);
  115. } else
  116. return FALSE;
  117. }
  118. }
  119. ?>