Error 401: Wrong account or password
besynnerlig opened this issue ยท 21 comments
I'm using the ewelink-api library to control my eWeLink devices (actually my neighbor's devices that have been shared to my account), but I'm getting an error 401 ("Wrong account or password") when trying to authenticate. I have verified that my account and password are correct, and I can log in to the eWeLink app with the same credentials. I also seem to be able to toggle the devices ON/OFF, at least there are no errors shown in the app.
Here are the steps to reproduce the issue:
Initialize the ewelink-api library with my account and password.
Create the connection, seems to work.
connection.setDevicePowerState fails with error: {"error":401,"msg":"Wrong account or password"}
The library returns an error 401, indicating that the account or password is incorrect.
I have also checked the this GitHub repository and did not find any reported issues that match my problem.
This error started to occur today without that I have changed anything regarding to my credentials.
Please let me know if there are any suggestions for troubleshooting or if there is any additional information that I can provide to help diagnose the issue.
Below is the source code that I use:
require('dotenv').config();
const ewelink = require('ewelink-api');
const Push = require('pushover-notifications');
const winston = require('winston');
const logger = winston.createLogger({
level: 'info',
format: winston.format.combine(
winston.format.timestamp(),
winston.format.printf(info => `${info.timestamp} ${info.level}: ${info.message}`)
),
transports: [
new winston.transports.Console(),
new winston.transports.File({ filename: 'logs/ewelink-api.log' })
]
});
const pushover = new Push({
user: process.env.PUSHOVER_USER_KEY,
token: process.env.PUSHOVER_API_TOKEN
});
const ewelinkCredentials = {
email: process.env.EWELINK_EMAIL,
password: process.env.EWELINK_PASSWORD,
region: 'eu',
};
const sleepDuration = 10000;
const maxTries = 3;
async function setDevicePowerState(deviceId, newState) {
try {
var connection = new ewelink(ewelinkCredentials);
await sleep(sleepDuration);
let tries = 0;
let state;
do {
state = await connection.setDevicePowerState(deviceId, newState);
var stateJson = JSON.stringify(state);
logger.info(`Set device ${deviceId} to ${newState}, returned: ${stateJson}`);
if (state.error == null && state.status == 'ok') {
// Wait for the server to update the device's state
await sleep(sleepDuration);
var status = await connection.getDevicePowerState(deviceId);
if (status.error == null && status.state === newState) {
logger.info(`Device ${deviceId} power state was confirmed`);
break;
}
}
tries++;
if (tries <= maxTries) {
logger.warn(`Failed to set device ${deviceId} to ${newState}`);
if (state.error === 401 || state.error === 406 || state.error === 503) {
connection = await reconnect(connection, ewelinkCredentials);
}
} else {
const msg = {
message: `${deviceId}, ${newState} -> ${stateJson}`,
title: "ewelink-api",
priority: 1
};
pushover.send(msg, function (err, result) {
if (err) {
logger.error(`Error sending Pushover notification: ${err}`);
return;
}
logger.info(`Pushover notification sent: ${result}`);
});
}
} while (tries <= maxTries);
} catch (error) {
logger.error(`Error setting device ${deviceId} power state to ${newState}: ${error}`);
}
}
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
async function reconnect(connection, ewelinkCredentials) {
logger.warn(`Reconnecting to ewelink server...`);
// connection.close() Not available it seems...
await sleep(sleepDuration);
connection = new ewelink(ewelinkCredentials);
return connection;
}
(async () => {
const args = require('minimist')(process.argv.slice(2));
const deviceId = args.deviceid.toString();
const newState = args.newstate;
await setDevicePowerState(deviceId, newState);
})();
Same
Me too.
anyone known what happen?
we have similar issue with 408 error
appId: YzfeftUVcZ6twZw1OoVKPRFYTrGEg01Q
API responded with error=408, msg=appid has expired
Same issue here.
Note:
Not all calls raise that error. I am able to getCredentials and getDevices without an error. All other calls fail with
{ error: 401, msg: 'Wrong account or password' }
I can list devices and everything else but toggle device and get/set power stat return 401 Wrong account or password
same
I have the same problem. It looks like an account check has been added to the request to change the device status.
same
same
same, problems again? too bad ewelink...
Same for me
const connection = new ewelink({
email: 'xxx@yyy',
password: 'zzz',
region:'eu',
});
{ error: 401, msg: 'Wrong account or password' }
I can list devices or get region but I cant run toggle
Same
[408] appid has expired
Same for me
{ error: 401, msg: 'Wrong account or password' }
I can list devices or get region but I cant run toggle
Same
[408] appid has expired
After a long research, the AppID was Expired,
I found out some APP_ID's and APP_SECRET's that was left around in GitHub,
use on your own risk..
APP_ID: oeVkj2lYFGnJu5XUtWisfW4utiN4u9Mq
APP_SECRET: 6Nz4n0xA8s8qdxQf2GqurZj2Fs55FUvM
APP_ID: R8Oq3y0eSZSYdKccHlrQzT1ACCOUT9Gv
APP_SECRET: 1ve5Qk9GXfUhKAn1svnKwpAlxXkMarru
APP_ID: Uw83EKZFxdif7XFXEsrpduz5YyjP7nTl
APP_SECRET: mXLOjea0woSMvK9gw7Fjsy7YlFO4iSu6
to use it, just add the APP_ID and APP_SECRET under the initialization of the class,
new ewelink({
email: process.env.EWE_EMAIL || `test`,
password: process.env.EWE_PASS || `test`,
region: process.env.EWE_REGION || `test`,
APP_ID: '...',
APP_SECRET: '...',
});
I also registered as a developer to generate my own appid,
I think this is the best way to fix the issue.
Uw83EKZFxdif7XFXEsrpduz5YyjP7nTl
works for me... and I also registered as a developer at https://dev.ewelink.cc to create my own app id
Same issue, using app secret above works and I guess it will work until something else, seemingly random, will break out of nowhere, gotta love ewelink-api
ewelink has been extended appid YzfeftUVcZ6twZw1OoVKPRFYTrGEg01Q
I think issue can be closed.
Uw83EKZFxdif7XFXEsrpduz5YyjP7nTl
works for me... and I also registered as a developer at https://dev.ewelink.cc to create my own app id
This is what I did and hopefully I'll get a message before my personal app id eventually expires. I close this issue now as the problem seems to be fixed.
also registered as a developer to generate my own appid,
after registering your ewelink account and creating app, did your app_id and secret_id work normally?
@LiorLindvor
I've created my own APP_ID & APP_SECRET on dev.ewelink.cc, - standard role.
However this doens't fully work. I can get list of devices and events just fine
but all other nodes just give me "wrong account or password" even though the getCredentials promise is successfull in all cases, and all nodes show the green dot.
With the APP_ID/SECRET form your message, all functionality is restored.
So perhaps the role is an issue?
Other possibility: the ewlink API has changed, ewelink-api still uses the v1.