]>
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
;
81 {'name': 'name', 'mandatory': true, 'inquery': false},
82 {'name': 'currency', 'mandatory': true, 'inquery': true},
84 'buildUrl': function(params
) {
85 return '/market/' + params
.name
+ '/balance';
92 {'name': 'name', 'mandatory': true, 'inquery': false},
93 {'name': 'key', 'mandatory': true, 'inquery': true},
94 {'name': 'secret', 'mandatory': true, 'inquery': true},
96 'buildUrl': function(params
) {
97 return '/market/' + params
.name
+ '/update';
104 'buildUrl': function() {
105 return '/otp/enroll';
112 {'name': 'pass', 'mandatory': true, 'inquery': true},
114 'buildUrl': function() {
115 return '/otp/validate';
120 Api
.BuildRequest = function(endpointId
, params
) {
121 var endpoint
= ApiEndpoints
[endpointId
];
125 var jwt
= App
.getUserToken();
127 if (endpoint
=== undefined) {
128 return {'err': 'cannot find endpoint ' + endpointId
};
131 if (endpoint
.auth
=== true && (jwt
=== undefined || jwt
=== null)) {
132 return {'err': 'this endpoint needs auth'};
135 if (jwt
!== undefined && jwt
!== null) {
136 headers
.Authorization
= 'Bearer ' + jwt
;
139 for (var i
= 0; i
< endpoint
.parameters
.length
; i
++) {
140 var parameter
= endpoint
.parameters
[i
];
141 if (parameter
.mandatory
=== true && params
[parameter
.name
] === undefined) {
142 return {'err': 'parameter \'' + parameter
.name
+ '\' is mandatory'};
145 if (parameter
.inquery
=== true) {
146 query
[parameter
.name
] = params
[parameter
.name
];
150 url
= endpoint
.buildUrl(params
);
152 return {'err': null, 'url': Api
.API_ROOT
+ url
, 'headers': headers
, 'params': query
, 'type': endpoint
.type
};
155 Api
.Call = function(endpointId
, params
, fn
) {
156 var request
= Api
.BuildRequest(endpointId
, params
);
158 if (request
.err
!== null) {
159 console
.error('Api BuildRequest error', request
.err
);
160 fn({'err': request
.err
}, -1, {});
164 return Api
.DoRequest(request
.type
, request
.url
, request
.params
, request
.headers
, fn
);
167 Api
.DoRequest = function(type
, url
, params
, headers
, callback
) {
173 error: function(xhr
, status
, err
) {
174 if (status
=== 'abort') {
178 var apiStatus
= null;
179 var apiResponse
= null;
181 if (xhr
.responseJSON
) {
182 apiStatus
= xhr
.responseJSON
.status
;
183 apiResponse
= xhr
.responseJSON
.response
;
184 apiCode
= xhr
.responseJSON
.code
;
187 if (xhr
.status
=== 401 || xhr
.status
=== 403) {
188 if (App
.onUserNotAuthorized(xhr
.status
, apiCode
) === false) {
193 callback({'url': url
, 'err': err
, 'status': status
, 'code': apiCode
, 'xhr': xhr
}, apiStatus
, apiResponse
);
195 success: function(data
) {
197 if (data
.status
!== 'ok') {
198 err
= {'url': url
, 'status': status
};
200 callback(err
, data
.status
, data
.response
);