]>
git.immae.eu Git - perso/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front.git/blob - cmd/web/js/api.js
3 import App
from './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() {
39 {'name': 'email', 'mandatory': true, 'inquery': true},
40 {'name': 'password', 'mandatory': true, 'inquery': true}
42 'buildUrl': function() {
50 {'name': 'email', 'mandatory': true, 'inquery': true},
52 'buildUrl': function() {
53 return '/passwordreset';
60 {'name': 'token', 'mandatory': true, 'inquery': true},
61 {'name': 'password', 'mandatory': true, 'inquery': true},
63 'buildUrl': function() {
64 return '/changepassword';
71 {'name': 'name', 'mandatory': true, 'inquery': false},
73 'buildUrl': function(params
) {
74 return '/market/' + params
.name
;
77 'MARKET_TEST_CREDENTIALS': {
81 {'name': 'name', 'mandatory': true, 'inquery': false},
83 'buildUrl': function(params
) {
84 return '/market/' + params
.name
+ '/test-credentials';
87 'MARKET_GET_PORTFOLIO': {
91 {'name': 'name', 'mandatory': true, 'inquery': false},
93 'buildUrl': function(params
) {
94 return '/market/' + params
.name
+ '/portfolio';
101 {'name': 'name', 'mandatory': true, 'inquery': false},
102 {'name': 'key', 'mandatory': true, 'inquery': true},
103 {'name': 'secret', 'mandatory': true, 'inquery': true},
105 'buildUrl': function(params
) {
106 return '/market/' + params
.name
+ '/update';
113 'buildUrl': function() {
114 return '/otp/enroll';
121 {'name': 'pass', 'mandatory': true, 'inquery': true},
123 'buildUrl': function() {
124 return '/otp/validate';
129 Api
.BuildRequest = function(endpointId
, params
) {
130 var endpoint
= ApiEndpoints
[endpointId
];
134 var jwt
= App
.getUserToken();
136 if (endpoint
=== undefined) {
137 return {'err': 'cannot find endpoint ' + endpointId
};
140 if (endpoint
.auth
=== true && (jwt
=== undefined || jwt
=== null)) {
141 return {'err': 'this endpoint needs auth'};
144 if (jwt
!== undefined && jwt
!== null) {
145 headers
.Authorization
= 'Bearer ' + jwt
;
148 for (var i
= 0; i
< endpoint
.parameters
.length
; i
++) {
149 var parameter
= endpoint
.parameters
[i
];
150 if (parameter
.mandatory
=== true && params
[parameter
.name
] === undefined) {
151 return {'err': 'parameter \'' + parameter
.name
+ '\' is mandatory'};
154 if (parameter
.inquery
=== true) {
155 query
[parameter
.name
] = params
[parameter
.name
];
159 url
= endpoint
.buildUrl(params
);
161 return {'err': null, 'url': Api
.API_ROOT
+ url
, 'headers': headers
, 'params': query
, 'type': endpoint
.type
};
164 Api
.Call = function(endpointId
, params
, fn
) {
165 var request
= Api
.BuildRequest(endpointId
, params
);
167 if (request
.err
!== null) {
168 console
.error('Api BuildRequest error', request
.err
);
169 fn({'err': request
.err
}, -1, {});
173 return Api
.DoRequest(request
.type
, request
.url
, request
.params
, request
.headers
, fn
);
176 Api
.DoRequest = function(type
, url
, params
, headers
, callback
) {
182 error: function(xhr
, status
, err
) {
183 if (status
=== 'abort') {
187 var apiStatus
= null;
188 var apiResponse
= null;
190 if (xhr
.responseJSON
) {
191 apiStatus
= xhr
.responseJSON
.status
;
192 apiResponse
= xhr
.responseJSON
.response
;
193 apiCode
= xhr
.responseJSON
.code
;
196 if (xhr
.status
=== 401 || xhr
.status
=== 403) {
197 if (App
.onUserNotAuthorized(xhr
.status
, apiCode
) === false) {
202 callback({'url': url
, 'err': err
, 'status': status
, 'code': apiCode
, 'xhr': xhr
}, apiStatus
, apiResponse
);
204 success: function(data
) {
206 if (data
.status
!== 'ok') {
207 err
= {'url': url
, 'status': status
};
209 callback(err
, data
.status
, data
.response
);