added svcapi ui and camunda code
[it/otf.git] / otf-frontend / server / src / feathers / models / groups.model.js
diff --git a/otf-frontend/server/src/feathers/models/groups.model.js b/otf-frontend/server/src/feathers/models/groups.model.js
new file mode 100644 (file)
index 0000000..d15894e
--- /dev/null
@@ -0,0 +1,39 @@
+/*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
+#                                                                              #\r
+#   Licensed under the Apache License, Version 2.0 (the "License");            #\r
+#   you may not use this file except in compliance with the License.           #\r
+#   You may obtain a copy of the License at                                    #\r
+#                                                                              #\r
+#       http://www.apache.org/licenses/LICENSE-2.0                             #\r
+#                                                                              #\r
+#   Unless required by applicable law or agreed to in writing, software        #\r
+#   distributed under the License is distributed on an "AS IS" BASIS,          #\r
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
+#   See the License for the specific language governing permissions and        #\r
+#   limitations under the License.                                             #\r
+##############################################################################*/\r
+\r
+\r
+module.exports = function (app) {\r
+       const mongooseClient = app.get('mongooseClient');\r
+       const { Schema } = mongooseClient;\r
+       const groups = new Schema({\r
+               groupName: { type: String, required: true },\r
+               groupDescription: { type: String },\r
+               parentGroupId: { type: Schema.Types.ObjectId, ref: 'groups' },\r
+               members: [ new Schema({\r
+                       userId: { type: Schema.Types.ObjectId, ref: 'users' },\r
+                       roles: { type: Array, default: ['user'] }\r
+               },  { _id: false })],\r
+               roles: [new Schema({\r
+                       roleName: { type: String },\r
+                       permissions: { type: Array, default: ['read'] }\r
+               }, {_id: false})],\r
+               ownerId: { type: Schema.Types.ObjectId, ref: 'users', required: true },\r
+               mechanizedIds: [String]\r
+       }, {\r
+               timestamps: true\r
+       });\r
+\r
+       return mongooseClient.model('groups', groups);\r
+};\r