]>
git.immae.eu Git - perso/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front.git/blob - cmd/web/js/api.js
e2acd1d31dd4b9ea3b0d5555770a32f9d87ec47a
3 var App
= require('./app.js');
7 Api
.API_HOST
= process
.env
.API_HOST
;
8 Api
.API_PORT
= process
.env
.API_PORT
;
10 if (process
.env
.API_HTTPS
=== 'true') {
11 Api
.API_ROOT
= 'https://';
13 Api
.API_ROOT
= 'http://';
16 Api
.API_ROOT
+= Api
.API_HOST
;
17 if (Api
.API_PORT
!== '80') {
18 Api
.API_ROOT
+= ':' + Api
.API_PORT
;
21 Api
.API_ROOT
+= '/api';
28 {'name': 'email', 'mandatory': true, 'inquery': true},
29 {'name': 'password', 'mandatory': true, 'inquery': true}
31 'buildUrl': function(params
) {
39 {'name': 'email', 'mandatory': true, 'inquery': true},
40 {'name': 'password', 'mandatory': true, 'inquery': true}
42 'buildUrl': function(params
) {
50 {'name': 'name', 'mandatory': true, 'inquery': false},
52 'buildUrl': function(params
) {
53 return '/market/' + params
.name
;
60 {'name': 'name', 'mandatory': true, 'inquery': false},
61 {'name': 'key', 'mandatory': true, 'inquery': true},
62 {'name': 'secret', 'mandatory': true, 'inquery': true},
64 'buildUrl': function(params
) {
65 return '/market/' + params
.name
+ '/update';
72 'buildUrl': function(params
) {
80 {'name': 'pass', 'mandatory': true, 'inquery': true},
82 'buildUrl': function(params
) {
83 return '/otp/validate';
88 Api
.BuildRequest = function(endpointId
, params
) {
89 var endpoint
= ApiEndpoints
[endpointId
];
93 var jwt
= App
.getUserToken();
95 if (endpoint
=== undefined) {
96 return {'err': 'cannot find endpoint ' + endpointId
};
99 if (endpoint
.auth
=== true && (jwt
=== undefined || jwt
=== null)) {
100 return {'err': 'this endpoint needs auth'};
103 if (jwt
!== undefined && jwt
!== null) {
104 headers
.Authorization
= 'Bearer ' + jwt
;
107 for (var i
= 0; i
< endpoint
.parameters
.length
; i
++) {
108 var parameter
= endpoint
.parameters
[i
];
109 if (parameter
.mandatory
=== true && params
[parameter
.name
] === undefined) {
110 return {'err': 'parameter \'' + parameter
.name
+ '\' is mandatory'};
113 if (parameter
.inquery
=== true) {
114 query
[parameter
.name
] = params
[parameter
.name
];
118 url
= endpoint
.buildUrl(params
);
120 return {'err': null, 'url': Api
.API_ROOT
+ url
, 'headers': headers
, 'params': query
, 'type': endpoint
.type
};
123 Api
.Call = function(endpointId
, params
, fn
) {
124 var request
= Api
.BuildRequest(endpointId
, params
);
126 if (request
.err
!== null) {
127 console
.error('Api BuildRequest error', request
.err
);
128 fn({'err': request
.err
}, -1, {});
132 return Api
.DoRequest(request
.type
, request
.url
, request
.params
, request
.headers
, fn
);
135 Api
.DoRequest = function(type
, url
, params
, headers
, callback
) {
141 error: function(xhr
, status
, err
) {
142 if (status
=== 'abort') {
146 var apiStatus
= null;
147 var apiResponse
= null;
149 if (xhr
.responseJSON
) {
150 apiStatus
= xhr
.responseJSON
.status
;
151 apiResponse
= xhr
.responseJSON
.response
;
152 apiCode
= xhr
.responseJSON
.code
;
155 if (xhr
.status
=== 401 || xhr
.status
=== 403) {
156 if (App
.onUserNotAuthorized(xhr
.status
, apiCode
) === false) {
161 callback({'url': url
, 'err': err
, 'status': status
, 'code': apiCode
, 'xhr': xhr
}, apiStatus
, apiResponse
);
163 success: function(data
) {
165 if (data
.status
!== 'ok') {
166 err
= {'url': url
, 'status': status
};
168 callback(err
, data
.status
, data
.response
);
175 module
.exports
.Api
= Api
;