added azure related code
[it/otf.git] / otf-frontend / server / src / feathers / hooks / delete-definition.js
1 /*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
2 #                                                                              #\r
3 #   Licensed under the Apache License, Version 2.0 (the "License");            #\r
4 #   you may not use this file except in compliance with the License.           #\r
5 #   You may obtain a copy of the License at                                    #\r
6 #                                                                              #\r
7 #       http://www.apache.org/licenses/LICENSE-2.0                             #\r
8 #                                                                              #\r
9 #   Unless required by applicable law or agreed to in writing, software        #\r
10 #   distributed under the License is distributed on an "AS IS" BASIS,          #\r
11 #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
12 #   See the License for the specific language governing permissions and        #\r
13 #   limitations under the License.                                             #\r
14 ##############################################################################*/\r
15 \r
16 \r
17 const util = require('../../lib/otf-util');\r
18 const request = require('request');\r
19 const errors = require('@feathersjs/errors');\r
20 module.exports = function (options = {}) { // eslint-disable-line no-unused-vars\r
21     return async context => {\r
22         let options = {\r
23             url: context.app.get('serviceApi').url + 'testStrategy/delete/v1/testDefinitionId/' + context.id,\r
24             headers: {\r
25                 'Authorization': 'Basic ' + util.base64Encode(context.app.get('serviceApi').aafId + ':' + context.app.get('serviceApi').aafPassword)\r
26             },\r
27             rejectUnauthorized: false,\r
28         }\r
29         \r
30         await new Promise((resolve, reject) => {\r
31             request.delete(options, (err, res, body) => {\r
32                 if(err){\r
33                     reject(err);\r
34                 }\r
35                 if(res && res.statusCode == 200){\r
36                     resolve(body);\r
37                 }else{\r
38                     reject(res);\r
39                 }\r
40             });\r
41         }).then(result => {\r
42             \r
43         }).catch(err => {\r
44             throw new errors.GeneralError(err.body.message);\r
45         });\r
46     };\r
47 };\r