@goauthentik/api 2025.12.0-rc1-1765152822 → 2025.12.0-rc1-1765191857

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (271) hide show
  1. package/.openapi-generator/FILES +4 -11
  2. package/dist/apis/CoreApi.d.ts +5 -0
  3. package/dist/apis/CoreApi.d.ts.map +1 -1
  4. package/dist/apis/CoreApi.js +15 -0
  5. package/dist/apis/CoreApi.js.map +1 -1
  6. package/dist/apis/RbacApi.d.ts +23 -263
  7. package/dist/apis/RbacApi.d.ts.map +1 -1
  8. package/dist/apis/RbacApi.js +60 -538
  9. package/dist/apis/RbacApi.js.map +1 -1
  10. package/dist/esm/apis/CoreApi.d.ts +5 -0
  11. package/dist/esm/apis/CoreApi.d.ts.map +1 -1
  12. package/dist/esm/apis/CoreApi.js +15 -0
  13. package/dist/esm/apis/CoreApi.js.map +1 -1
  14. package/dist/esm/apis/RbacApi.d.ts +23 -263
  15. package/dist/esm/apis/RbacApi.d.ts.map +1 -1
  16. package/dist/esm/apis/RbacApi.js +60 -538
  17. package/dist/esm/apis/RbacApi.js.map +1 -1
  18. package/dist/esm/models/ExtraRoleObjectPermission.d.ts +2 -2
  19. package/dist/esm/models/Group.d.ts +9 -9
  20. package/dist/esm/models/Group.d.ts.map +1 -1
  21. package/dist/esm/models/Group.js +9 -8
  22. package/dist/esm/models/Group.js.map +1 -1
  23. package/dist/esm/models/GroupRequest.d.ts +2 -8
  24. package/dist/esm/models/GroupRequest.d.ts.map +1 -1
  25. package/dist/esm/models/GroupRequest.js +2 -4
  26. package/dist/esm/models/GroupRequest.js.map +1 -1
  27. package/dist/esm/models/InitialPermissions.d.ts +0 -7
  28. package/dist/esm/models/InitialPermissions.d.ts.map +1 -1
  29. package/dist/esm/models/InitialPermissions.js +0 -5
  30. package/dist/esm/models/InitialPermissions.js.map +1 -1
  31. package/dist/esm/models/InitialPermissionsRequest.d.ts +0 -7
  32. package/dist/esm/models/InitialPermissionsRequest.d.ts.map +1 -1
  33. package/dist/esm/models/InitialPermissionsRequest.js +0 -5
  34. package/dist/esm/models/InitialPermissionsRequest.js.map +1 -1
  35. package/dist/esm/models/PartialGroup.d.ts +1 -13
  36. package/dist/esm/models/PartialGroup.d.ts.map +1 -1
  37. package/dist/esm/models/PartialGroup.js +0 -5
  38. package/dist/esm/models/PartialGroup.js.map +1 -1
  39. package/dist/esm/models/PatchedGroupRequest.d.ts +2 -8
  40. package/dist/esm/models/PatchedGroupRequest.d.ts.map +1 -1
  41. package/dist/esm/models/PatchedGroupRequest.js +2 -4
  42. package/dist/esm/models/PatchedGroupRequest.js.map +1 -1
  43. package/dist/esm/models/PatchedInitialPermissionsRequest.d.ts +0 -7
  44. package/dist/esm/models/PatchedInitialPermissionsRequest.d.ts.map +1 -1
  45. package/dist/esm/models/PatchedInitialPermissionsRequest.js +0 -3
  46. package/dist/esm/models/PatchedInitialPermissionsRequest.js.map +1 -1
  47. package/dist/esm/models/PatchedUserRequest.d.ts +6 -0
  48. package/dist/esm/models/PatchedUserRequest.d.ts.map +1 -1
  49. package/dist/esm/models/PatchedUserRequest.js +2 -0
  50. package/dist/esm/models/PatchedUserRequest.js.map +1 -1
  51. package/dist/esm/models/RelatedGroup.d.ts +59 -0
  52. package/dist/esm/models/RelatedGroup.d.ts.map +1 -0
  53. package/dist/esm/models/{GroupChild.js → RelatedGroup.js} +14 -14
  54. package/dist/esm/models/RelatedGroup.js.map +1 -0
  55. package/dist/esm/models/RoleAssignedObjectPermission.d.ts +8 -1
  56. package/dist/esm/models/RoleAssignedObjectPermission.d.ts.map +1 -1
  57. package/dist/esm/models/RoleAssignedObjectPermission.js +8 -3
  58. package/dist/esm/models/RoleAssignedObjectPermission.js.map +1 -1
  59. package/dist/esm/models/RoleModelPermission.d.ts +57 -0
  60. package/dist/esm/models/RoleModelPermission.d.ts.map +1 -0
  61. package/dist/esm/models/{UserObjectPermission.js → RoleModelPermission.js} +15 -20
  62. package/dist/esm/models/RoleModelPermission.js.map +1 -0
  63. package/dist/esm/models/User.d.ts +14 -1
  64. package/dist/esm/models/User.d.ts.map +1 -1
  65. package/dist/esm/models/User.js +6 -0
  66. package/dist/esm/models/User.js.map +1 -1
  67. package/dist/esm/models/UserAccountSerializerForRoleRequest.d.ts +33 -0
  68. package/dist/esm/models/UserAccountSerializerForRoleRequest.d.ts.map +1 -0
  69. package/dist/esm/models/UserAccountSerializerForRoleRequest.js +51 -0
  70. package/dist/esm/models/UserAccountSerializerForRoleRequest.js.map +1 -0
  71. package/dist/esm/models/UserRequest.d.ts +6 -0
  72. package/dist/esm/models/UserRequest.d.ts.map +1 -1
  73. package/dist/esm/models/UserRequest.js +2 -0
  74. package/dist/esm/models/UserRequest.js.map +1 -1
  75. package/dist/esm/models/UserSelf.d.ts +8 -1
  76. package/dist/esm/models/UserSelf.d.ts.map +1 -1
  77. package/dist/esm/models/UserSelf.js +4 -0
  78. package/dist/esm/models/UserSelf.js.map +1 -1
  79. package/dist/esm/models/UserSelfRoles.d.ts +39 -0
  80. package/dist/esm/models/UserSelfRoles.d.ts.map +1 -0
  81. package/dist/esm/models/UserSelfRoles.js +52 -0
  82. package/dist/esm/models/UserSelfRoles.js.map +1 -0
  83. package/dist/esm/models/index.d.ts +4 -11
  84. package/dist/esm/models/index.d.ts.map +1 -1
  85. package/dist/esm/models/index.js +4 -11
  86. package/dist/esm/models/index.js.map +1 -1
  87. package/dist/models/ExtraRoleObjectPermission.d.ts +2 -2
  88. package/dist/models/Group.d.ts +9 -9
  89. package/dist/models/Group.d.ts.map +1 -1
  90. package/dist/models/Group.js +9 -8
  91. package/dist/models/Group.js.map +1 -1
  92. package/dist/models/GroupRequest.d.ts +2 -8
  93. package/dist/models/GroupRequest.d.ts.map +1 -1
  94. package/dist/models/GroupRequest.js +2 -4
  95. package/dist/models/GroupRequest.js.map +1 -1
  96. package/dist/models/InitialPermissions.d.ts +0 -7
  97. package/dist/models/InitialPermissions.d.ts.map +1 -1
  98. package/dist/models/InitialPermissions.js +0 -5
  99. package/dist/models/InitialPermissions.js.map +1 -1
  100. package/dist/models/InitialPermissionsRequest.d.ts +0 -7
  101. package/dist/models/InitialPermissionsRequest.d.ts.map +1 -1
  102. package/dist/models/InitialPermissionsRequest.js +0 -5
  103. package/dist/models/InitialPermissionsRequest.js.map +1 -1
  104. package/dist/models/PartialGroup.d.ts +1 -13
  105. package/dist/models/PartialGroup.d.ts.map +1 -1
  106. package/dist/models/PartialGroup.js +0 -5
  107. package/dist/models/PartialGroup.js.map +1 -1
  108. package/dist/models/PatchedGroupRequest.d.ts +2 -8
  109. package/dist/models/PatchedGroupRequest.d.ts.map +1 -1
  110. package/dist/models/PatchedGroupRequest.js +2 -4
  111. package/dist/models/PatchedGroupRequest.js.map +1 -1
  112. package/dist/models/PatchedInitialPermissionsRequest.d.ts +0 -7
  113. package/dist/models/PatchedInitialPermissionsRequest.d.ts.map +1 -1
  114. package/dist/models/PatchedInitialPermissionsRequest.js +0 -3
  115. package/dist/models/PatchedInitialPermissionsRequest.js.map +1 -1
  116. package/dist/models/PatchedUserRequest.d.ts +6 -0
  117. package/dist/models/PatchedUserRequest.d.ts.map +1 -1
  118. package/dist/models/PatchedUserRequest.js +2 -0
  119. package/dist/models/PatchedUserRequest.js.map +1 -1
  120. package/dist/models/RelatedGroup.d.ts +59 -0
  121. package/dist/models/RelatedGroup.d.ts.map +1 -0
  122. package/dist/models/{GroupChild.js → RelatedGroup.js} +14 -14
  123. package/dist/models/RelatedGroup.js.map +1 -0
  124. package/dist/models/RoleAssignedObjectPermission.d.ts +8 -1
  125. package/dist/models/RoleAssignedObjectPermission.d.ts.map +1 -1
  126. package/dist/models/RoleAssignedObjectPermission.js +8 -3
  127. package/dist/models/RoleAssignedObjectPermission.js.map +1 -1
  128. package/dist/models/RoleModelPermission.d.ts +57 -0
  129. package/dist/models/RoleModelPermission.d.ts.map +1 -0
  130. package/dist/models/{UserObjectPermission.js → RoleModelPermission.js} +15 -20
  131. package/dist/models/RoleModelPermission.js.map +1 -0
  132. package/dist/models/User.d.ts +14 -1
  133. package/dist/models/User.d.ts.map +1 -1
  134. package/dist/models/User.js +6 -0
  135. package/dist/models/User.js.map +1 -1
  136. package/dist/models/UserAccountSerializerForRoleRequest.d.ts +33 -0
  137. package/dist/models/UserAccountSerializerForRoleRequest.d.ts.map +1 -0
  138. package/dist/models/UserAccountSerializerForRoleRequest.js +51 -0
  139. package/dist/models/UserAccountSerializerForRoleRequest.js.map +1 -0
  140. package/dist/models/UserRequest.d.ts +6 -0
  141. package/dist/models/UserRequest.d.ts.map +1 -1
  142. package/dist/models/UserRequest.js +2 -0
  143. package/dist/models/UserRequest.js.map +1 -1
  144. package/dist/models/UserSelf.d.ts +8 -1
  145. package/dist/models/UserSelf.d.ts.map +1 -1
  146. package/dist/models/UserSelf.js +4 -0
  147. package/dist/models/UserSelf.js.map +1 -1
  148. package/dist/models/UserSelfRoles.d.ts +39 -0
  149. package/dist/models/UserSelfRoles.d.ts.map +1 -0
  150. package/dist/models/UserSelfRoles.js +52 -0
  151. package/dist/models/UserSelfRoles.js.map +1 -0
  152. package/dist/models/index.d.ts +4 -11
  153. package/dist/models/index.d.ts.map +1 -1
  154. package/dist/models/index.js +4 -11
  155. package/dist/models/index.js.map +1 -1
  156. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  157. package/package.json +1 -1
  158. package/src/apis/CoreApi.ts +25 -0
  159. package/src/apis/RbacApi.ts +168 -850
  160. package/src/models/ExtraRoleObjectPermission.ts +2 -2
  161. package/src/models/Group.ts +21 -21
  162. package/src/models/GroupRequest.ts +4 -12
  163. package/src/models/InitialPermissions.ts +0 -18
  164. package/src/models/InitialPermissionsRequest.ts +0 -19
  165. package/src/models/PartialGroup.ts +1 -17
  166. package/src/models/PatchedGroupRequest.ts +4 -12
  167. package/src/models/PatchedInitialPermissionsRequest.ts +0 -18
  168. package/src/models/PatchedUserRequest.ts +8 -0
  169. package/src/models/{GroupChild.ts → RelatedGroup.ts} +16 -16
  170. package/src/models/RoleAssignedObjectPermission.ts +20 -4
  171. package/src/models/{UserObjectPermission.ts → RoleModelPermission.ts} +16 -25
  172. package/src/models/User.ts +24 -1
  173. package/src/models/UserAccountSerializerForRoleRequest.ts +66 -0
  174. package/src/models/UserRequest.ts +8 -0
  175. package/src/models/UserSelf.ts +16 -1
  176. package/src/models/UserSelfRoles.ts +73 -0
  177. package/src/models/index.ts +4 -11
  178. package/tsconfig.tsbuildinfo +1 -1
  179. package/dist/esm/models/ExtraRoleObjectPermissionRequest.d.ts +0 -33
  180. package/dist/esm/models/ExtraRoleObjectPermissionRequest.d.ts.map +0 -1
  181. package/dist/esm/models/ExtraRoleObjectPermissionRequest.js +0 -51
  182. package/dist/esm/models/ExtraRoleObjectPermissionRequest.js.map +0 -1
  183. package/dist/esm/models/ExtraUserObjectPermission.d.ts +0 -83
  184. package/dist/esm/models/ExtraUserObjectPermission.d.ts.map +0 -1
  185. package/dist/esm/models/ExtraUserObjectPermission.js +0 -75
  186. package/dist/esm/models/ExtraUserObjectPermission.js.map +0 -1
  187. package/dist/esm/models/ExtraUserObjectPermissionRequest.d.ts +0 -33
  188. package/dist/esm/models/ExtraUserObjectPermissionRequest.d.ts.map +0 -1
  189. package/dist/esm/models/ExtraUserObjectPermissionRequest.js +0 -51
  190. package/dist/esm/models/ExtraUserObjectPermissionRequest.js.map +0 -1
  191. package/dist/esm/models/GroupChild.d.ts +0 -59
  192. package/dist/esm/models/GroupChild.d.ts.map +0 -1
  193. package/dist/esm/models/GroupChild.js.map +0 -1
  194. package/dist/esm/models/InitialPermissionsModeEnum.d.ts +0 -27
  195. package/dist/esm/models/InitialPermissionsModeEnum.d.ts.map +0 -1
  196. package/dist/esm/models/InitialPermissionsModeEnum.js +0 -53
  197. package/dist/esm/models/InitialPermissionsModeEnum.js.map +0 -1
  198. package/dist/esm/models/PaginatedExtraUserObjectPermissionList.d.ts +0 -41
  199. package/dist/esm/models/PaginatedExtraUserObjectPermissionList.d.ts.map +0 -1
  200. package/dist/esm/models/PaginatedExtraUserObjectPermissionList.js +0 -57
  201. package/dist/esm/models/PaginatedExtraUserObjectPermissionList.js.map +0 -1
  202. package/dist/esm/models/PaginatedUserAssignedObjectPermissionList.d.ts +0 -49
  203. package/dist/esm/models/PaginatedUserAssignedObjectPermissionList.d.ts.map +0 -1
  204. package/dist/esm/models/PaginatedUserAssignedObjectPermissionList.js +0 -61
  205. package/dist/esm/models/PaginatedUserAssignedObjectPermissionList.js.map +0 -1
  206. package/dist/esm/models/PatchedExtraRoleObjectPermissionRequest.d.ts +0 -33
  207. package/dist/esm/models/PatchedExtraRoleObjectPermissionRequest.d.ts.map +0 -1
  208. package/dist/esm/models/PatchedExtraRoleObjectPermissionRequest.js +0 -49
  209. package/dist/esm/models/PatchedExtraRoleObjectPermissionRequest.js.map +0 -1
  210. package/dist/esm/models/PatchedExtraUserObjectPermissionRequest.d.ts +0 -33
  211. package/dist/esm/models/PatchedExtraUserObjectPermissionRequest.d.ts.map +0 -1
  212. package/dist/esm/models/PatchedExtraUserObjectPermissionRequest.js +0 -49
  213. package/dist/esm/models/PatchedExtraUserObjectPermissionRequest.js.map +0 -1
  214. package/dist/esm/models/UserAssignedObjectPermission.d.ts +0 -90
  215. package/dist/esm/models/UserAssignedObjectPermission.d.ts.map +0 -1
  216. package/dist/esm/models/UserAssignedObjectPermission.js +0 -78
  217. package/dist/esm/models/UserAssignedObjectPermission.js.map +0 -1
  218. package/dist/esm/models/UserObjectPermission.d.ts +0 -63
  219. package/dist/esm/models/UserObjectPermission.d.ts.map +0 -1
  220. package/dist/esm/models/UserObjectPermission.js.map +0 -1
  221. package/dist/models/ExtraRoleObjectPermissionRequest.d.ts +0 -33
  222. package/dist/models/ExtraRoleObjectPermissionRequest.d.ts.map +0 -1
  223. package/dist/models/ExtraRoleObjectPermissionRequest.js +0 -51
  224. package/dist/models/ExtraRoleObjectPermissionRequest.js.map +0 -1
  225. package/dist/models/ExtraUserObjectPermission.d.ts +0 -83
  226. package/dist/models/ExtraUserObjectPermission.d.ts.map +0 -1
  227. package/dist/models/ExtraUserObjectPermission.js +0 -75
  228. package/dist/models/ExtraUserObjectPermission.js.map +0 -1
  229. package/dist/models/ExtraUserObjectPermissionRequest.d.ts +0 -33
  230. package/dist/models/ExtraUserObjectPermissionRequest.d.ts.map +0 -1
  231. package/dist/models/ExtraUserObjectPermissionRequest.js +0 -51
  232. package/dist/models/ExtraUserObjectPermissionRequest.js.map +0 -1
  233. package/dist/models/GroupChild.d.ts +0 -59
  234. package/dist/models/GroupChild.d.ts.map +0 -1
  235. package/dist/models/GroupChild.js.map +0 -1
  236. package/dist/models/InitialPermissionsModeEnum.d.ts +0 -27
  237. package/dist/models/InitialPermissionsModeEnum.d.ts.map +0 -1
  238. package/dist/models/InitialPermissionsModeEnum.js +0 -53
  239. package/dist/models/InitialPermissionsModeEnum.js.map +0 -1
  240. package/dist/models/PaginatedExtraUserObjectPermissionList.d.ts +0 -41
  241. package/dist/models/PaginatedExtraUserObjectPermissionList.d.ts.map +0 -1
  242. package/dist/models/PaginatedExtraUserObjectPermissionList.js +0 -57
  243. package/dist/models/PaginatedExtraUserObjectPermissionList.js.map +0 -1
  244. package/dist/models/PaginatedUserAssignedObjectPermissionList.d.ts +0 -49
  245. package/dist/models/PaginatedUserAssignedObjectPermissionList.d.ts.map +0 -1
  246. package/dist/models/PaginatedUserAssignedObjectPermissionList.js +0 -61
  247. package/dist/models/PaginatedUserAssignedObjectPermissionList.js.map +0 -1
  248. package/dist/models/PatchedExtraRoleObjectPermissionRequest.d.ts +0 -33
  249. package/dist/models/PatchedExtraRoleObjectPermissionRequest.d.ts.map +0 -1
  250. package/dist/models/PatchedExtraRoleObjectPermissionRequest.js +0 -49
  251. package/dist/models/PatchedExtraRoleObjectPermissionRequest.js.map +0 -1
  252. package/dist/models/PatchedExtraUserObjectPermissionRequest.d.ts +0 -33
  253. package/dist/models/PatchedExtraUserObjectPermissionRequest.d.ts.map +0 -1
  254. package/dist/models/PatchedExtraUserObjectPermissionRequest.js +0 -49
  255. package/dist/models/PatchedExtraUserObjectPermissionRequest.js.map +0 -1
  256. package/dist/models/UserAssignedObjectPermission.d.ts +0 -90
  257. package/dist/models/UserAssignedObjectPermission.d.ts.map +0 -1
  258. package/dist/models/UserAssignedObjectPermission.js +0 -78
  259. package/dist/models/UserAssignedObjectPermission.js.map +0 -1
  260. package/dist/models/UserObjectPermission.d.ts +0 -63
  261. package/dist/models/UserObjectPermission.d.ts.map +0 -1
  262. package/dist/models/UserObjectPermission.js.map +0 -1
  263. package/src/models/ExtraRoleObjectPermissionRequest.ts +0 -66
  264. package/src/models/ExtraUserObjectPermission.ts +0 -132
  265. package/src/models/ExtraUserObjectPermissionRequest.ts +0 -66
  266. package/src/models/InitialPermissionsModeEnum.ts +0 -54
  267. package/src/models/PaginatedExtraUserObjectPermissionList.ts +0 -90
  268. package/src/models/PaginatedUserAssignedObjectPermissionList.ts +0 -99
  269. package/src/models/PatchedExtraRoleObjectPermissionRequest.ts +0 -65
  270. package/src/models/PatchedExtraUserObjectPermissionRequest.ts +0 -65
  271. package/src/models/UserAssignedObjectPermission.ts +0 -149
@@ -14,7 +14,7 @@
14
14
 
15
15
  import { mapValues } from '../runtime';
16
16
  /**
17
- * User permission with additional object-related data
17
+ * Role permission with additional object-related data
18
18
  * @export
19
19
  * @interface ExtraRoleObjectPermission
20
20
  */
@@ -69,7 +69,7 @@ export interface ExtraRoleObjectPermission {
69
69
  readonly modelVerbose: string;
70
70
  /**
71
71
  * Get model description from attached model. This operation takes at least
72
- * one additional query, and the description is only shown if the user/role has the
72
+ * one additional query, and the description is only shown if the role has the
73
73
  * view_ permission on the object
74
74
  * @type {string}
75
75
  * @memberof ExtraRoleObjectPermission
@@ -27,13 +27,13 @@ import {
27
27
  RoleToJSON,
28
28
  RoleToJSONTyped,
29
29
  } from './Role';
30
- import type { GroupChild } from './GroupChild';
30
+ import type { RelatedGroup } from './RelatedGroup';
31
31
  import {
32
- GroupChildFromJSON,
33
- GroupChildFromJSONTyped,
34
- GroupChildToJSON,
35
- GroupChildToJSONTyped,
36
- } from './GroupChild';
32
+ RelatedGroupFromJSON,
33
+ RelatedGroupFromJSONTyped,
34
+ RelatedGroupToJSON,
35
+ RelatedGroupToJSONTyped,
36
+ } from './RelatedGroup';
37
37
 
38
38
  /**
39
39
  * Group Serializer
@@ -67,16 +67,16 @@ export interface Group {
67
67
  isSuperuser?: boolean;
68
68
  /**
69
69
  *
70
- * @type {string}
70
+ * @type {Array<string>}
71
71
  * @memberof Group
72
72
  */
73
- parent?: string | null;
73
+ parents?: Array<string>;
74
74
  /**
75
75
  *
76
- * @type {string}
76
+ * @type {Array<RelatedGroup>}
77
77
  * @memberof Group
78
78
  */
79
- readonly parentName: string | null;
79
+ readonly parentsObj: Array<RelatedGroup> | null;
80
80
  /**
81
81
  *
82
82
  * @type {Array<number>}
@@ -112,13 +112,13 @@ export interface Group {
112
112
  * @type {Array<string>}
113
113
  * @memberof Group
114
114
  */
115
- children?: Array<string>;
115
+ readonly children: Array<string>;
116
116
  /**
117
117
  *
118
- * @type {Array<GroupChild>}
118
+ * @type {Array<RelatedGroup>}
119
119
  * @memberof Group
120
120
  */
121
- readonly childrenObj: Array<GroupChild> | null;
121
+ readonly childrenObj: Array<RelatedGroup> | null;
122
122
  }
123
123
 
124
124
  /**
@@ -128,9 +128,10 @@ export function instanceOfGroup(value: object): value is Group {
128
128
  if (!('pk' in value) || value['pk'] === undefined) return false;
129
129
  if (!('numPk' in value) || value['numPk'] === undefined) return false;
130
130
  if (!('name' in value) || value['name'] === undefined) return false;
131
- if (!('parentName' in value) || value['parentName'] === undefined) return false;
131
+ if (!('parentsObj' in value) || value['parentsObj'] === undefined) return false;
132
132
  if (!('usersObj' in value) || value['usersObj'] === undefined) return false;
133
133
  if (!('rolesObj' in value) || value['rolesObj'] === undefined) return false;
134
+ if (!('children' in value) || value['children'] === undefined) return false;
134
135
  if (!('childrenObj' in value) || value['childrenObj'] === undefined) return false;
135
136
  return true;
136
137
  }
@@ -149,15 +150,15 @@ export function GroupFromJSONTyped(json: any, ignoreDiscriminator: boolean): Gro
149
150
  'numPk': json['num_pk'],
150
151
  'name': json['name'],
151
152
  'isSuperuser': json['is_superuser'] == null ? undefined : json['is_superuser'],
152
- 'parent': json['parent'] == null ? undefined : json['parent'],
153
- 'parentName': json['parent_name'],
153
+ 'parents': json['parents'] == null ? undefined : json['parents'],
154
+ 'parentsObj': (json['parents_obj'] == null ? null : (json['parents_obj'] as Array<any>).map(RelatedGroupFromJSON)),
154
155
  'users': json['users'] == null ? undefined : json['users'],
155
156
  'usersObj': (json['users_obj'] == null ? null : (json['users_obj'] as Array<any>).map(PartialUserFromJSON)),
156
157
  'attributes': json['attributes'] == null ? undefined : json['attributes'],
157
158
  'roles': json['roles'] == null ? undefined : json['roles'],
158
159
  'rolesObj': ((json['roles_obj'] as Array<any>).map(RoleFromJSON)),
159
- 'children': json['children'] == null ? undefined : json['children'],
160
- 'childrenObj': (json['children_obj'] == null ? null : (json['children_obj'] as Array<any>).map(GroupChildFromJSON)),
160
+ 'children': json['children'],
161
+ 'childrenObj': (json['children_obj'] == null ? null : (json['children_obj'] as Array<any>).map(RelatedGroupFromJSON)),
161
162
  };
162
163
  }
163
164
 
@@ -165,7 +166,7 @@ export function GroupToJSON(json: any): Group {
165
166
  return GroupToJSONTyped(json, false);
166
167
  }
167
168
 
168
- export function GroupToJSONTyped(value?: Omit<Group, 'pk'|'num_pk'|'parent_name'|'users_obj'|'roles_obj'|'children_obj'> | null, ignoreDiscriminator: boolean = false): any {
169
+ export function GroupToJSONTyped(value?: Omit<Group, 'pk'|'num_pk'|'parents_obj'|'users_obj'|'roles_obj'|'children'|'children_obj'> | null, ignoreDiscriminator: boolean = false): any {
169
170
  if (value == null) {
170
171
  return value;
171
172
  }
@@ -174,11 +175,10 @@ export function GroupToJSONTyped(value?: Omit<Group, 'pk'|'num_pk'|'parent_name'
174
175
 
175
176
  'name': value['name'],
176
177
  'is_superuser': value['isSuperuser'],
177
- 'parent': value['parent'],
178
+ 'parents': value['parents'],
178
179
  'users': value['users'],
179
180
  'attributes': value['attributes'],
180
181
  'roles': value['roles'],
181
- 'children': value['children'],
182
182
  };
183
183
  }
184
184
 
@@ -33,10 +33,10 @@ export interface GroupRequest {
33
33
  isSuperuser?: boolean;
34
34
  /**
35
35
  *
36
- * @type {string}
36
+ * @type {Array<string>}
37
37
  * @memberof GroupRequest
38
38
  */
39
- parent?: string | null;
39
+ parents?: Array<string>;
40
40
  /**
41
41
  *
42
42
  * @type {Array<number>}
@@ -55,12 +55,6 @@ export interface GroupRequest {
55
55
  * @memberof GroupRequest
56
56
  */
57
57
  roles?: Array<string>;
58
- /**
59
- *
60
- * @type {Array<string>}
61
- * @memberof GroupRequest
62
- */
63
- children?: Array<string>;
64
58
  }
65
59
 
66
60
  /**
@@ -83,11 +77,10 @@ export function GroupRequestFromJSONTyped(json: any, ignoreDiscriminator: boolea
83
77
 
84
78
  'name': json['name'],
85
79
  'isSuperuser': json['is_superuser'] == null ? undefined : json['is_superuser'],
86
- 'parent': json['parent'] == null ? undefined : json['parent'],
80
+ 'parents': json['parents'] == null ? undefined : json['parents'],
87
81
  'users': json['users'] == null ? undefined : json['users'],
88
82
  'attributes': json['attributes'] == null ? undefined : json['attributes'],
89
83
  'roles': json['roles'] == null ? undefined : json['roles'],
90
- 'children': json['children'] == null ? undefined : json['children'],
91
84
  };
92
85
  }
93
86
 
@@ -104,11 +97,10 @@ export function GroupRequestToJSONTyped(value?: GroupRequest | null, ignoreDiscr
104
97
 
105
98
  'name': value['name'],
106
99
  'is_superuser': value['isSuperuser'],
107
- 'parent': value['parent'],
100
+ 'parents': value['parents'],
108
101
  'users': value['users'],
109
102
  'attributes': value['attributes'],
110
103
  'roles': value['roles'],
111
- 'children': value['children'],
112
104
  };
113
105
  }
114
106
 
@@ -20,13 +20,6 @@ import {
20
20
  PermissionToJSON,
21
21
  PermissionToJSONTyped,
22
22
  } from './Permission';
23
- import type { InitialPermissionsModeEnum } from './InitialPermissionsModeEnum';
24
- import {
25
- InitialPermissionsModeEnumFromJSON,
26
- InitialPermissionsModeEnumFromJSONTyped,
27
- InitialPermissionsModeEnumToJSON,
28
- InitialPermissionsModeEnumToJSONTyped,
29
- } from './InitialPermissionsModeEnum';
30
23
 
31
24
  /**
32
25
  * InitialPermissions serializer
@@ -46,12 +39,6 @@ export interface InitialPermissions {
46
39
  * @memberof InitialPermissions
47
40
  */
48
41
  name: string;
49
- /**
50
- *
51
- * @type {InitialPermissionsModeEnum}
52
- * @memberof InitialPermissions
53
- */
54
- mode: InitialPermissionsModeEnum;
55
42
  /**
56
43
  *
57
44
  * @type {string}
@@ -72,15 +59,12 @@ export interface InitialPermissions {
72
59
  readonly permissionsObj: Array<Permission>;
73
60
  }
74
61
 
75
-
76
-
77
62
  /**
78
63
  * Check if a given object implements the InitialPermissions interface.
79
64
  */
80
65
  export function instanceOfInitialPermissions(value: object): value is InitialPermissions {
81
66
  if (!('pk' in value) || value['pk'] === undefined) return false;
82
67
  if (!('name' in value) || value['name'] === undefined) return false;
83
- if (!('mode' in value) || value['mode'] === undefined) return false;
84
68
  if (!('role' in value) || value['role'] === undefined) return false;
85
69
  if (!('permissionsObj' in value) || value['permissionsObj'] === undefined) return false;
86
70
  return true;
@@ -98,7 +82,6 @@ export function InitialPermissionsFromJSONTyped(json: any, ignoreDiscriminator:
98
82
 
99
83
  'pk': json['pk'],
100
84
  'name': json['name'],
101
- 'mode': InitialPermissionsModeEnumFromJSON(json['mode']),
102
85
  'role': json['role'],
103
86
  'permissions': json['permissions'] == null ? undefined : json['permissions'],
104
87
  'permissionsObj': ((json['permissions_obj'] as Array<any>).map(PermissionFromJSON)),
@@ -117,7 +100,6 @@ export function InitialPermissionsToJSONTyped(value?: Omit<InitialPermissions, '
117
100
  return {
118
101
 
119
102
  'name': value['name'],
120
- 'mode': InitialPermissionsModeEnumToJSON(value['mode']),
121
103
  'role': value['role'],
122
104
  'permissions': value['permissions'],
123
105
  };
@@ -13,14 +13,6 @@
13
13
  */
14
14
 
15
15
  import { mapValues } from '../runtime';
16
- import type { InitialPermissionsModeEnum } from './InitialPermissionsModeEnum';
17
- import {
18
- InitialPermissionsModeEnumFromJSON,
19
- InitialPermissionsModeEnumFromJSONTyped,
20
- InitialPermissionsModeEnumToJSON,
21
- InitialPermissionsModeEnumToJSONTyped,
22
- } from './InitialPermissionsModeEnum';
23
-
24
16
  /**
25
17
  * InitialPermissions serializer
26
18
  * @export
@@ -33,12 +25,6 @@ export interface InitialPermissionsRequest {
33
25
  * @memberof InitialPermissionsRequest
34
26
  */
35
27
  name: string;
36
- /**
37
- *
38
- * @type {InitialPermissionsModeEnum}
39
- * @memberof InitialPermissionsRequest
40
- */
41
- mode: InitialPermissionsModeEnum;
42
28
  /**
43
29
  *
44
30
  * @type {string}
@@ -53,14 +39,11 @@ export interface InitialPermissionsRequest {
53
39
  permissions?: Array<number>;
54
40
  }
55
41
 
56
-
57
-
58
42
  /**
59
43
  * Check if a given object implements the InitialPermissionsRequest interface.
60
44
  */
61
45
  export function instanceOfInitialPermissionsRequest(value: object): value is InitialPermissionsRequest {
62
46
  if (!('name' in value) || value['name'] === undefined) return false;
63
- if (!('mode' in value) || value['mode'] === undefined) return false;
64
47
  if (!('role' in value) || value['role'] === undefined) return false;
65
48
  return true;
66
49
  }
@@ -76,7 +59,6 @@ export function InitialPermissionsRequestFromJSONTyped(json: any, ignoreDiscrimi
76
59
  return {
77
60
 
78
61
  'name': json['name'],
79
- 'mode': InitialPermissionsModeEnumFromJSON(json['mode']),
80
62
  'role': json['role'],
81
63
  'permissions': json['permissions'] == null ? undefined : json['permissions'],
82
64
  };
@@ -94,7 +76,6 @@ export function InitialPermissionsRequestToJSONTyped(value?: InitialPermissionsR
94
76
  return {
95
77
 
96
78
  'name': value['name'],
97
- 'mode': InitialPermissionsModeEnumToJSON(value['mode']),
98
79
  'role': value['role'],
99
80
  'permissions': value['permissions'],
100
81
  };
@@ -43,18 +43,6 @@ export interface PartialGroup {
43
43
  * @memberof PartialGroup
44
44
  */
45
45
  isSuperuser?: boolean;
46
- /**
47
- *
48
- * @type {string}
49
- * @memberof PartialGroup
50
- */
51
- parent?: string | null;
52
- /**
53
- *
54
- * @type {string}
55
- * @memberof PartialGroup
56
- */
57
- readonly parentName: string | null;
58
46
  /**
59
47
  *
60
48
  * @type {{ [key: string]: any; }}
@@ -70,7 +58,6 @@ export function instanceOfPartialGroup(value: object): value is PartialGroup {
70
58
  if (!('pk' in value) || value['pk'] === undefined) return false;
71
59
  if (!('numPk' in value) || value['numPk'] === undefined) return false;
72
60
  if (!('name' in value) || value['name'] === undefined) return false;
73
- if (!('parentName' in value) || value['parentName'] === undefined) return false;
74
61
  return true;
75
62
  }
76
63
 
@@ -88,8 +75,6 @@ export function PartialGroupFromJSONTyped(json: any, ignoreDiscriminator: boolea
88
75
  'numPk': json['num_pk'],
89
76
  'name': json['name'],
90
77
  'isSuperuser': json['is_superuser'] == null ? undefined : json['is_superuser'],
91
- 'parent': json['parent'] == null ? undefined : json['parent'],
92
- 'parentName': json['parent_name'],
93
78
  'attributes': json['attributes'] == null ? undefined : json['attributes'],
94
79
  };
95
80
  }
@@ -98,7 +83,7 @@ export function PartialGroupToJSON(json: any): PartialGroup {
98
83
  return PartialGroupToJSONTyped(json, false);
99
84
  }
100
85
 
101
- export function PartialGroupToJSONTyped(value?: Omit<PartialGroup, 'pk'|'num_pk'|'parent_name'> | null, ignoreDiscriminator: boolean = false): any {
86
+ export function PartialGroupToJSONTyped(value?: Omit<PartialGroup, 'pk'|'num_pk'> | null, ignoreDiscriminator: boolean = false): any {
102
87
  if (value == null) {
103
88
  return value;
104
89
  }
@@ -107,7 +92,6 @@ export function PartialGroupToJSONTyped(value?: Omit<PartialGroup, 'pk'|'num_pk'
107
92
 
108
93
  'name': value['name'],
109
94
  'is_superuser': value['isSuperuser'],
110
- 'parent': value['parent'],
111
95
  'attributes': value['attributes'],
112
96
  };
113
97
  }
@@ -33,10 +33,10 @@ export interface PatchedGroupRequest {
33
33
  isSuperuser?: boolean;
34
34
  /**
35
35
  *
36
- * @type {string}
36
+ * @type {Array<string>}
37
37
  * @memberof PatchedGroupRequest
38
38
  */
39
- parent?: string | null;
39
+ parents?: Array<string>;
40
40
  /**
41
41
  *
42
42
  * @type {Array<number>}
@@ -55,12 +55,6 @@ export interface PatchedGroupRequest {
55
55
  * @memberof PatchedGroupRequest
56
56
  */
57
57
  roles?: Array<string>;
58
- /**
59
- *
60
- * @type {Array<string>}
61
- * @memberof PatchedGroupRequest
62
- */
63
- children?: Array<string>;
64
58
  }
65
59
 
66
60
  /**
@@ -82,11 +76,10 @@ export function PatchedGroupRequestFromJSONTyped(json: any, ignoreDiscriminator:
82
76
 
83
77
  'name': json['name'] == null ? undefined : json['name'],
84
78
  'isSuperuser': json['is_superuser'] == null ? undefined : json['is_superuser'],
85
- 'parent': json['parent'] == null ? undefined : json['parent'],
79
+ 'parents': json['parents'] == null ? undefined : json['parents'],
86
80
  'users': json['users'] == null ? undefined : json['users'],
87
81
  'attributes': json['attributes'] == null ? undefined : json['attributes'],
88
82
  'roles': json['roles'] == null ? undefined : json['roles'],
89
- 'children': json['children'] == null ? undefined : json['children'],
90
83
  };
91
84
  }
92
85
 
@@ -103,11 +96,10 @@ export function PatchedGroupRequestToJSONTyped(value?: PatchedGroupRequest | nul
103
96
 
104
97
  'name': value['name'],
105
98
  'is_superuser': value['isSuperuser'],
106
- 'parent': value['parent'],
99
+ 'parents': value['parents'],
107
100
  'users': value['users'],
108
101
  'attributes': value['attributes'],
109
102
  'roles': value['roles'],
110
- 'children': value['children'],
111
103
  };
112
104
  }
113
105
 
@@ -13,14 +13,6 @@
13
13
  */
14
14
 
15
15
  import { mapValues } from '../runtime';
16
- import type { InitialPermissionsModeEnum } from './InitialPermissionsModeEnum';
17
- import {
18
- InitialPermissionsModeEnumFromJSON,
19
- InitialPermissionsModeEnumFromJSONTyped,
20
- InitialPermissionsModeEnumToJSON,
21
- InitialPermissionsModeEnumToJSONTyped,
22
- } from './InitialPermissionsModeEnum';
23
-
24
16
  /**
25
17
  * InitialPermissions serializer
26
18
  * @export
@@ -33,12 +25,6 @@ export interface PatchedInitialPermissionsRequest {
33
25
  * @memberof PatchedInitialPermissionsRequest
34
26
  */
35
27
  name?: string;
36
- /**
37
- *
38
- * @type {InitialPermissionsModeEnum}
39
- * @memberof PatchedInitialPermissionsRequest
40
- */
41
- mode?: InitialPermissionsModeEnum;
42
28
  /**
43
29
  *
44
30
  * @type {string}
@@ -53,8 +39,6 @@ export interface PatchedInitialPermissionsRequest {
53
39
  permissions?: Array<number>;
54
40
  }
55
41
 
56
-
57
-
58
42
  /**
59
43
  * Check if a given object implements the PatchedInitialPermissionsRequest interface.
60
44
  */
@@ -73,7 +57,6 @@ export function PatchedInitialPermissionsRequestFromJSONTyped(json: any, ignoreD
73
57
  return {
74
58
 
75
59
  'name': json['name'] == null ? undefined : json['name'],
76
- 'mode': json['mode'] == null ? undefined : InitialPermissionsModeEnumFromJSON(json['mode']),
77
60
  'role': json['role'] == null ? undefined : json['role'],
78
61
  'permissions': json['permissions'] == null ? undefined : json['permissions'],
79
62
  };
@@ -91,7 +74,6 @@ export function PatchedInitialPermissionsRequestToJSONTyped(value?: PatchedIniti
91
74
  return {
92
75
 
93
76
  'name': value['name'],
94
- 'mode': InitialPermissionsModeEnumToJSON(value['mode']),
95
77
  'role': value['role'],
96
78
  'permissions': value['permissions'],
97
79
  };
@@ -57,6 +57,12 @@ export interface PatchedUserRequest {
57
57
  * @memberof PatchedUserRequest
58
58
  */
59
59
  groups?: Array<string>;
60
+ /**
61
+ *
62
+ * @type {Array<string>}
63
+ * @memberof PatchedUserRequest
64
+ */
65
+ roles?: Array<string>;
60
66
  /**
61
67
  *
62
68
  * @type {string}
@@ -107,6 +113,7 @@ export function PatchedUserRequestFromJSONTyped(json: any, ignoreDiscriminator:
107
113
  'isActive': json['is_active'] == null ? undefined : json['is_active'],
108
114
  'lastLogin': json['last_login'] == null ? undefined : (new Date(json['last_login'])),
109
115
  'groups': json['groups'] == null ? undefined : json['groups'],
116
+ 'roles': json['roles'] == null ? undefined : json['roles'],
110
117
  'email': json['email'] == null ? undefined : json['email'],
111
118
  'attributes': json['attributes'] == null ? undefined : json['attributes'],
112
119
  'path': json['path'] == null ? undefined : json['path'],
@@ -130,6 +137,7 @@ export function PatchedUserRequestToJSONTyped(value?: PatchedUserRequest | null,
130
137
  'is_active': value['isActive'],
131
138
  'last_login': value['lastLogin'] == null ? value['lastLogin'] : value['lastLogin'].toISOString(),
132
139
  'groups': value['groups'],
140
+ 'roles': value['roles'],
133
141
  'email': value['email'],
134
142
  'attributes': value['attributes'],
135
143
  'path': value['path'],
@@ -14,58 +14,58 @@
14
14
 
15
15
  import { mapValues } from '../runtime';
16
16
  /**
17
- * Stripped down group serializer to show relevant children for groups
17
+ * Stripped down group serializer to show relevant children/parents for groups
18
18
  * @export
19
- * @interface GroupChild
19
+ * @interface RelatedGroup
20
20
  */
21
- export interface GroupChild {
21
+ export interface RelatedGroup {
22
22
  /**
23
23
  *
24
24
  * @type {string}
25
- * @memberof GroupChild
25
+ * @memberof RelatedGroup
26
26
  */
27
27
  readonly pk: string;
28
28
  /**
29
29
  *
30
30
  * @type {string}
31
- * @memberof GroupChild
31
+ * @memberof RelatedGroup
32
32
  */
33
33
  name: string;
34
34
  /**
35
35
  * Users added to this group will be superusers.
36
36
  * @type {boolean}
37
- * @memberof GroupChild
37
+ * @memberof RelatedGroup
38
38
  */
39
39
  isSuperuser?: boolean;
40
40
  /**
41
41
  *
42
42
  * @type {{ [key: string]: any; }}
43
- * @memberof GroupChild
43
+ * @memberof RelatedGroup
44
44
  */
45
45
  attributes?: { [key: string]: any; };
46
46
  /**
47
47
  *
48
48
  * @type {string}
49
- * @memberof GroupChild
49
+ * @memberof RelatedGroup
50
50
  */
51
51
  readonly groupUuid: string;
52
52
  }
53
53
 
54
54
  /**
55
- * Check if a given object implements the GroupChild interface.
55
+ * Check if a given object implements the RelatedGroup interface.
56
56
  */
57
- export function instanceOfGroupChild(value: object): value is GroupChild {
57
+ export function instanceOfRelatedGroup(value: object): value is RelatedGroup {
58
58
  if (!('pk' in value) || value['pk'] === undefined) return false;
59
59
  if (!('name' in value) || value['name'] === undefined) return false;
60
60
  if (!('groupUuid' in value) || value['groupUuid'] === undefined) return false;
61
61
  return true;
62
62
  }
63
63
 
64
- export function GroupChildFromJSON(json: any): GroupChild {
65
- return GroupChildFromJSONTyped(json, false);
64
+ export function RelatedGroupFromJSON(json: any): RelatedGroup {
65
+ return RelatedGroupFromJSONTyped(json, false);
66
66
  }
67
67
 
68
- export function GroupChildFromJSONTyped(json: any, ignoreDiscriminator: boolean): GroupChild {
68
+ export function RelatedGroupFromJSONTyped(json: any, ignoreDiscriminator: boolean): RelatedGroup {
69
69
  if (json == null) {
70
70
  return json;
71
71
  }
@@ -79,11 +79,11 @@ export function GroupChildFromJSONTyped(json: any, ignoreDiscriminator: boolean)
79
79
  };
80
80
  }
81
81
 
82
- export function GroupChildToJSON(json: any): GroupChild {
83
- return GroupChildToJSONTyped(json, false);
82
+ export function RelatedGroupToJSON(json: any): RelatedGroup {
83
+ return RelatedGroupToJSONTyped(json, false);
84
84
  }
85
85
 
86
- export function GroupChildToJSONTyped(value?: Omit<GroupChild, 'pk'|'group_uuid'> | null, ignoreDiscriminator: boolean = false): any {
86
+ export function RelatedGroupToJSONTyped(value?: Omit<RelatedGroup, 'pk'|'group_uuid'> | null, ignoreDiscriminator: boolean = false): any {
87
87
  if (value == null) {
88
88
  return value;
89
89
  }
@@ -13,6 +13,13 @@
13
13
  */
14
14
 
15
15
  import { mapValues } from '../runtime';
16
+ import type { RoleModelPermission } from './RoleModelPermission';
17
+ import {
18
+ RoleModelPermissionFromJSON,
19
+ RoleModelPermissionFromJSONTyped,
20
+ RoleModelPermissionToJSON,
21
+ RoleModelPermissionToJSONTyped,
22
+ } from './RoleModelPermission';
16
23
  import type { RoleObjectPermission } from './RoleObjectPermission';
17
24
  import {
18
25
  RoleObjectPermissionFromJSON,
@@ -44,7 +51,13 @@ export interface RoleAssignedObjectPermission {
44
51
  * @type {Array<RoleObjectPermission>}
45
52
  * @memberof RoleAssignedObjectPermission
46
53
  */
47
- permissions: Array<RoleObjectPermission>;
54
+ objectPermissions: Array<RoleObjectPermission>;
55
+ /**
56
+ *
57
+ * @type {Array<RoleModelPermission>}
58
+ * @memberof RoleAssignedObjectPermission
59
+ */
60
+ modelPermissions: Array<RoleModelPermission>;
48
61
  }
49
62
 
50
63
  /**
@@ -53,7 +66,8 @@ export interface RoleAssignedObjectPermission {
53
66
  export function instanceOfRoleAssignedObjectPermission(value: object): value is RoleAssignedObjectPermission {
54
67
  if (!('rolePk' in value) || value['rolePk'] === undefined) return false;
55
68
  if (!('name' in value) || value['name'] === undefined) return false;
56
- if (!('permissions' in value) || value['permissions'] === undefined) return false;
69
+ if (!('objectPermissions' in value) || value['objectPermissions'] === undefined) return false;
70
+ if (!('modelPermissions' in value) || value['modelPermissions'] === undefined) return false;
57
71
  return true;
58
72
  }
59
73
 
@@ -69,7 +83,8 @@ export function RoleAssignedObjectPermissionFromJSONTyped(json: any, ignoreDiscr
69
83
 
70
84
  'rolePk': json['role_pk'],
71
85
  'name': json['name'],
72
- 'permissions': ((json['permissions'] as Array<any>).map(RoleObjectPermissionFromJSON)),
86
+ 'objectPermissions': ((json['object_permissions'] as Array<any>).map(RoleObjectPermissionFromJSON)),
87
+ 'modelPermissions': ((json['model_permissions'] as Array<any>).map(RoleModelPermissionFromJSON)),
73
88
  };
74
89
  }
75
90
 
@@ -84,7 +99,8 @@ export function RoleAssignedObjectPermissionToJSONTyped(value?: Omit<RoleAssigne
84
99
 
85
100
  return {
86
101
 
87
- 'permissions': ((value['permissions'] as Array<any>).map(RoleObjectPermissionToJSON)),
102
+ 'object_permissions': ((value['objectPermissions'] as Array<any>).map(RoleObjectPermissionToJSON)),
103
+ 'model_permissions': ((value['modelPermissions'] as Array<any>).map(RoleModelPermissionToJSON)),
88
104
  };
89
105
  }
90
106