]>
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': 'name', 'mandatory': true, 'inquery': false},
52 'buildUrl': function(params
) {
53 return '/market/' + params
.name
;
60 {'name': 'name', 'mandatory': true, 'inquery': false},
61 {'name': 'currency', 'mandatory': true, 'inquery': true},
63 'buildUrl': function(params
) {
64 return '/market/' + params
.name
+ '/balance';
71 {'name': 'name', 'mandatory': true, 'inquery': false},
72 {'name': 'key', 'mandatory': true, 'inquery': true},
73 {'name': 'secret', 'mandatory': true, 'inquery': true},
75 'buildUrl': function(params
) {
76 return '/market/' + params
.name
+ '/update';
83 'buildUrl': function() {
91 {'name': 'pass', 'mandatory': true, 'inquery': true},
93 'buildUrl': function() {
94 return '/otp/validate';
99 Api
.BuildRequest = function(endpointId
, params
) {
100 var endpoint
= ApiEndpoints
[endpointId
];
104 var jwt
= App
.getUserToken();
106 if (endpoint
=== undefined) {
107 return {'err': 'cannot find endpoint ' + endpointId
};
110 if (endpoint
.auth
=== true && (jwt
=== undefined || jwt
=== null)) {
111 return {'err': 'this endpoint needs auth'};
114 if (jwt
!== undefined && jwt
!== null) {
115 headers
.Authorization
= 'Bearer ' + jwt
;
118 for (var i
= 0; i
< endpoint
.parameters
.length
; i
++) {
119 var parameter
= endpoint
.parameters
[i
];
120 if (parameter
.mandatory
=== true && params
[parameter
.name
] === undefined) {
121 return {'err': 'parameter \'' + parameter
.name
+ '\' is mandatory'};
124 if (parameter
.inquery
=== true) {
125 query
[parameter
.name
] = params
[parameter
.name
];
129 url
= endpoint
.buildUrl(params
);
131 return {'err': null, 'url': Api
.API_ROOT
+ url
, 'headers': headers
, 'params': query
, 'type': endpoint
.type
};
134 Api
.Call = function(endpointId
, params
, fn
) {
135 var request
= Api
.BuildRequest(endpointId
, params
);
137 if (request
.err
!== null) {
138 console
.error('Api BuildRequest error', request
.err
);
139 fn({'err': request
.err
}, -1, {});
143 return Api
.DoRequest(request
.type
, request
.url
, request
.params
, request
.headers
, fn
);
146 Api
.DoRequest = function(type
, url
, params
, headers
, callback
) {
152 error: function(xhr
, status
, err
) {
153 if (status
=== 'abort') {
157 var apiStatus
= null;
158 var apiResponse
= null;
160 if (xhr
.responseJSON
) {
161 apiStatus
= xhr
.responseJSON
.status
;
162 apiResponse
= xhr
.responseJSON
.response
;
163 apiCode
= xhr
.responseJSON
.code
;
166 if (xhr
.status
=== 401 || xhr
.status
=== 403) {
167 if (App
.onUserNotAuthorized(xhr
.status
, apiCode
) === false) {
172 callback({'url': url
, 'err': err
, 'status': status
, 'code': apiCode
, 'xhr': xhr
}, apiStatus
, apiResponse
);
174 success: function(data
) {
176 if (data
.status
!== 'ok') {
177 err
= {'url': url
, 'status': status
};
179 callback(err
, data
.status
, data
.response
);