mirror of
https://github.com/skydiver/ewelink-api.git
synced 2025-12-24 06:28:30 +01:00
Release v3.0.0 (#85)
* updated dependencies * code linting * added new app id & app secret * cleanup requests payloads * remove unused function * update test cases * enabled firmware tests * refactor getDevice to use right api endpoint * error messages improvements * error messages improvements * error messages improvements * error messages improvements * error messages improvements * payload cleanup * refactor setDevicePowerState to use right api endpoint * update test exepectation * removed deprecated class * updated tests to reflect new error codes * error messages improvements * refactoring project structure: devices methods refactoring project sturcture * refactoring project structure: firmware methods * refactoring project structure: temperature/humidity * refactoring project structure: credentials methods * refactoring project structure: power usage methods * refactoring project structure: power state methods * refactoring project structure: websocket methods * removed deprecated login method from docs * refactoring project structure: power usage methods * refactoring project structure: zeroconf classes * refactoring project structure: websocket classes * refactoring project structure: zeroconf classes * refactor and cleanup * refactoring project structure: firmware methods * moved parsers to own directory * update tests with methods renames * export missing temperature/humidity methods * removed unused package * refactor and cleanup * fix test expectation * refactoring project structure: moved data files * refactoring project structure: moved data files * refactoring project structure: moved helpers files * refactoring project structure: moved helpers files * refactoring project structure: moved payload files * refactor and cleanup * refactor getDevicePowerState * setDevicePowerState returns channel * convert error 400 to 404 for clarity * updated test cases * remove console.log * cache path for zeroconf cache files * installed nock * using nock to simulate server requests during testing * moved credentials file to config folder * update request url when using nock * refactor nock helper file * move cooldown delay to setupTests file * updating testing instructions * restored delete code block * fix wrong error code * accept phone number to login to ewelink * added test cases for initialize main class * improvements on class initialization parameters * allow login using phone number * rename test file * updated test case * fixed regression bug * Release v3.0.0 - use node-fetch (#87) * replaced deprecated request library with node-fetch * refactor: moved makeRequest to own mixin file * refactor to use node-fetch * fixes * update config * created helper method * constant rename * ignore files from final package * version bump
This commit is contained in:
49
src/mixins/getCredentials.js
Normal file
49
src/mixins/getCredentials.js
Normal file
@@ -0,0 +1,49 @@
|
||||
const fetch = require('node-fetch');
|
||||
|
||||
const { _get } = require('../helpers/utilities');
|
||||
const credentialsPayload = require('../payloads/credentialsPayload');
|
||||
const { makeAuthorizationSign } = require('../helpers/ewelink');
|
||||
const errors = require('../data/errors');
|
||||
|
||||
module.exports = {
|
||||
/**
|
||||
* Returns user credentials information
|
||||
*
|
||||
* @returns {Promise<{msg: string, error: *}>}
|
||||
*/
|
||||
async getCredentials() {
|
||||
const body = credentialsPayload({
|
||||
email: this.email,
|
||||
phoneNumber: this.phoneNumber,
|
||||
password: this.password,
|
||||
});
|
||||
|
||||
const request = await fetch(`${this.getApiUrl()}/user/login`, {
|
||||
method: 'post',
|
||||
headers: { Authorization: `Sign ${makeAuthorizationSign(body)}` },
|
||||
body: JSON.stringify(body),
|
||||
});
|
||||
|
||||
let response = await request.json();
|
||||
|
||||
const error = _get(response, 'error', false);
|
||||
const region = _get(response, 'region', false);
|
||||
|
||||
if (error && [400, 401, 404].indexOf(parseInt(error)) !== -1) {
|
||||
return { error: 406, msg: errors['406'] };
|
||||
}
|
||||
|
||||
if (error && parseInt(error) === 301 && region) {
|
||||
if (this.region !== region) {
|
||||
this.region = region;
|
||||
response = await this.getCredentials();
|
||||
return response;
|
||||
}
|
||||
return { error, msg: 'Region does not exist' };
|
||||
}
|
||||
|
||||
this.apiKey = _get(response, 'user.apikey', '');
|
||||
this.at = _get(response, 'at', '');
|
||||
return response;
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user