hsweb-starter.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. /*
  2. * Copyright 2016 http://www.hswebframework.org
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. *
  16. */
  17. //组件信息
  18. var info = {
  19. groupId: "${project.groupId}",
  20. artifactId: "${project.artifactId}",
  21. version: "${project.version}",
  22. website: "http://github.com/hs-web/hsweb-framework",
  23. author: "zh.sqy@qq.com",
  24. comment: "权限管理"
  25. };
  26. //版本更新信息
  27. var versions = [
  28. // {
  29. // version: "3.0.0",
  30. // upgrade: function (context) {
  31. // java.lang.System.out.println("更新到3.0.2了");
  32. // }
  33. // }
  34. ];
  35. var JDBCType = java.sql.JDBCType;
  36. function install(context) {
  37. var database = context.database;
  38. database.createOrAlter("s_user")
  39. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  40. .addColumn().name("name").varchar(128).notNull().comment("姓名").commit()
  41. .addColumn().name("username").varchar(128).notNull().comment("用户名").commit()
  42. .addColumn().name("password").varchar(128).notNull().comment("密码").commit()
  43. .addColumn().name("salt").varchar(128).notNull().comment("密码盐").commit()
  44. .addColumn().name("status").number(4).notNull().comment("用户状态").commit()
  45. .addColumn().name("last_login_ip").varchar(128).comment("上一次登录的ip地址").commit()
  46. .addColumn().name("last_login_time").number(32).comment("上一次登录时间").commit()
  47. .addColumn().name("creator_id").varchar(32).comment("创建者ID").commit()
  48. .addColumn().name("create_time").number(32).notNull().comment("创建时间").commit()
  49. .comment("用户表").commit();
  50. database.createOrAlter("s_role")
  51. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  52. .addColumn().name("name").varchar(128).notNull().comment("角色名称").commit()
  53. .addColumn().name("describe").varchar(128).comment("说明").commit()
  54. .addColumn().name("status").number(4).notNull().comment("状态").commit()
  55. .comment("角色表").commit();
  56. database.createOrAlter("s_permission")
  57. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  58. .addColumn().name("name").varchar(128).notNull().comment("角色名称").commit()
  59. .addColumn().name("describe").varchar(128).comment("说明").commit()
  60. .addColumn().name("status").number(4).notNull().comment("状态").commit()
  61. .addColumn().name("actions").clob().notNull().comment("可选操作(按钮)").commit()
  62. .addColumn().name("spt_da_types").clob().comment("支持的数据权限类型").commit()
  63. .addColumn().name("optional_fields").clob().comment("可选字段").commit()
  64. .addColumn().name("parents").clob().comment("关联其他权限").commit()
  65. .comment("权限表").commit();
  66. database.createOrAlter("s_permission_role")
  67. .addColumn().name("role_id").varchar(32).notNull().comment("角色ID").commit()
  68. .addColumn().name("permission_id").varchar(32).notNull().comment("权限ID").commit()
  69. .addColumn().name("actions").clob().comment("可选操作").commit()
  70. .addColumn().name("data_access").clob().comment("数据级控制配置").commit()
  71. .comment("权限与角色关联表").commit();
  72. database.createOrAlter("s_user_role")
  73. .addColumn().name("role_id").varchar(32).notNull().comment("角色ID").commit()
  74. .addColumn().name("user_id").varchar(32).notNull().comment("用户ID").commit()
  75. .comment("用户与角色关联表").commit();
  76. //权限设置
  77. database.createOrAlter("s_autz_setting")
  78. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  79. .addColumn().name("type").varchar(32).notNull().comment("权限类型").commit()
  80. .addColumn().name("setting_for").varchar(64).notNull().comment("设置给谁").commit()
  81. .addColumn().name("describe").varchar(256).comment("备注").commit()
  82. .addColumn().name("status").number(4, 0).comment("设置给谁").commit()
  83. .comment("权限设置表").commit();
  84. database.createOrAlter("s_autz_detail")
  85. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  86. .addColumn().name("permission_id").varchar(32).notNull().comment("权限ID").commit()
  87. .addColumn().name("setting_id").varchar(64).notNull().comment("设置ID").commit()
  88. .addColumn().name("actions").clob().comment("可操作类型").commit()
  89. .addColumn().name("data_accesses").clob().comment("数据权限控制").commit()
  90. .addColumn().name("status").number(4, 0).comment("状态").commit()
  91. .addColumn().name("priority").number(32, 0).comment("优先级").commit()
  92. .addColumn().name("is_merge").number(4, 0).comment("是否合并").commit()
  93. .comment("权限设置详情表").commit();
  94. database.createOrAlter("s_autz_menu")
  95. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  96. .addColumn().name("parent_id").varchar(32).comment("父级ID").commit()
  97. .addColumn().name("menu_id").varchar(32).notNull().comment("菜单ID").commit()
  98. .addColumn().name("setting_id").varchar(64).notNull().comment("设置ID").commit()
  99. .addColumn().name("path").varchar(2048).notNull().comment("树编码").commit()
  100. .addColumn().name("sort_index").number(32).comment("树编码").commit()
  101. .addColumn().name("status").number(4, 0).comment("状态").commit()
  102. .addColumn().name("level").number(32, 0).comment("树深度").commit()
  103. .addColumn().name("config").clob().comment("其他配置").commit()
  104. .comment("权限设置菜单表").commit();
  105. // 菜单
  106. database.createOrAlter("s_menu")
  107. .addColumn().name("u_id").varchar(32).notNull().primaryKey().comment("uid").commit()
  108. .addColumn().name("name").varchar(64).notNull().comment("名称").commit()
  109. .addColumn().name("parent_id").varchar(32).comment("父级ID").commit()
  110. .addColumn().name("permission_id").varchar(2048).comment("权限ID").commit()
  111. .addColumn().name("path").varchar(2048).notNull().comment("树编码").commit()
  112. .addColumn().name("sort_index").number(32).comment("树编码").commit()
  113. .addColumn().name("describe").varchar(128).comment("备注").commit()
  114. .addColumn().name("url").varchar(2000).comment("URL").commit()
  115. .addColumn().name("icon").varchar(512).comment("图标").commit()
  116. .addColumn().name("status").alias("status").comment("状态").jdbcType(java.sql.JDBCType.DECIMAL).length(4, 0).commit()
  117. .comment("系统菜单表").commit()
  118. database.createOrAlter("s_menu_group")
  119. .addColumn().name("u_id").alias("id").comment("ID").jdbcType(java.sql.JDBCType.VARCHAR).length(32).primaryKey().commit()
  120. .addColumn().name("parent_id").varchar(32).comment("父级ID").commit()
  121. .addColumn().name("name").alias("name").comment("分组名称").jdbcType(java.sql.JDBCType.VARCHAR).length(32).commit()
  122. .addColumn().name("describe").alias("describe").comment("分组描述").jdbcType(java.sql.JDBCType.VARCHAR).length(64).commit()
  123. .addColumn().name("default_group").alias("defaultGroup").comment("是否默认").jdbcType(java.sql.JDBCType.DECIMAL).length(4, 0).commit()
  124. .addColumn().name("path").alias("path").comment("树路径").jdbcType(java.sql.JDBCType.VARCHAR).length(4000).commit()
  125. .addColumn().name("parent_id").alias("parentId").comment("父级id").jdbcType(java.sql.JDBCType.VARCHAR).length(32).commit()
  126. .addColumn().name("level").alias("level").comment("树层级").jdbcType(java.sql.JDBCType.DECIMAL).length(32, 0).commit()
  127. .addColumn().name("sort_index").alias("sortIndex").comment("排序序号").jdbcType(java.sql.JDBCType.DECIMAL).length(32, 0).commit()
  128. .addColumn().name("status").alias("status").comment("状态").jdbcType(java.sql.JDBCType.DECIMAL).length(4, 0).commit()
  129. .comment("菜单分组").commit();
  130. database.createOrAlter("s_menu_group_bind")
  131. .addColumn().name("u_id").alias("id").comment("ID").jdbcType(java.sql.JDBCType.VARCHAR).length(32).primaryKey().commit()
  132. .addColumn().name("menu_id").alias("menuId").comment("菜单id").jdbcType(java.sql.JDBCType.VARCHAR).length(32).commit()
  133. .addColumn().name("group_id").alias("groupId").comment("分组id").jdbcType(java.sql.JDBCType.VARCHAR).length(32).commit()
  134. .addColumn().name("path").alias("path").comment("树结构编码").jdbcType(java.sql.JDBCType.VARCHAR).length(4000).commit()
  135. .addColumn().name("parent_id").alias("parentId").comment("父级id").jdbcType(java.sql.JDBCType.VARCHAR).length(32).commit()
  136. .addColumn().name("level").alias("level").comment("树层级").jdbcType(java.sql.JDBCType.DECIMAL).length(32, 0).commit()
  137. .addColumn().name("sort_index").alias("sortIndex").comment("排序序号").jdbcType(java.sql.JDBCType.DECIMAL).length(32, 0).commit()
  138. .addColumn().name("status").alias("status").comment("状态").jdbcType(java.sql.JDBCType.DECIMAL).length(4, 0).commit()
  139. .comment("菜单分组关联").commit();
  140. }
  141. //设置依赖
  142. dependency.setup(info)
  143. .onInstall(install)
  144. .onUpgrade(function (context) { //更新时执行
  145. var upgrader = context.upgrader;
  146. upgrader.filter(versions)
  147. .upgrade(function (newVer) {
  148. newVer.upgrade(context);
  149. });
  150. })
  151. .onUninstall(function (context) { //卸载时执行
  152. });