Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Currently cannot support auth method mismatch! #128

Open
dong-lufei opened this issue Apr 21, 2022 · 8 comments
Open

Currently cannot support auth method mismatch! #128

dong-lufei opened this issue Apr 21, 2022 · 8 comments

Comments

@dong-lufei
Copy link

deno 1.19.2
MySQL Community Server 8.0.28
https://deno.land/x/[email protected]
https://deno.land/x/[email protected]/mod.ts
跑起来报错:
error: Uncaught (in promise) Error: Currently cannot support auth method mismatch!
throw new Error("Currently cannot support auth method mismatch!");
^
at PoolConnection._connect (https://deno.land/x/[email protected]/src/connection.ts:104:17)
at async PoolConnection.connect (https://deno.land/x/[email protected]/src/connection.ts:148:5)
at async Client.createConnection (https://deno.land/x/[email protected]/src/client.ts:47:5)
at async DeferredStack.creator (https://deno.land/x/[email protected]/src/pool.ts:61:20)
at async DeferredStack.pop (https://deno.land/x/[email protected]/src/deferred.ts:35:16)
at async ConnectionPool.pop (https://deno.land/x/[email protected]/src/pool.ts:93:14)
at async Client.useConnection (https://deno.land/x/[email protected]/src/client.ts:105:24)
at async Client.execute (https://deno.land/x/[email protected]/src/client.ts:96:12)

@sant123
Copy link

sant123 commented Jun 1, 2022

Try running in your mysql instance this query:

ALTER USER 'root'@'%' IDENTIFIED WITH caching_sha2_password BY 'your-root-password';

Basically there are two authentication strategies and this library supports the latest one.

https://dev.mysql.com/doc/refman/8.0/en/caching-sha2-pluggable-authentication.html

Perhaps while this gets fixed you could try using https://github.com/sail-sail/mysql2 that supports both.

This is the one that is throwing the exception:

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your-root-password';

@shiyuhang0
Copy link
Contributor

I search the code and get the following result

export default function auth(
  authPluginName: string,
  password: string,
  seed: Uint8Array,
) {
  switch (authPluginName) {
    case "mysql_native_password":
      return mysqlNativePassword(password, seed);

    case "caching_sha2_password":
      return cachingSha2Password(password, seed);
    default:
      throw new Error("Not supported");
  }
}

it seems the driver can support mysql_native_password? @sant123

@sant123
Copy link

sant123 commented Nov 23, 2022

Interesting, I tested again and now is working:

import { Client } from "https://deno.land/x/[email protected]/mod.ts";

const client = await new Client().connect({
  hostname: "127.0.0.1",
  username: "root",
  db: "mydb",
  password: "set-your-password",
});

const users = await client.query(`select * from users`);

console.log(users);
create schema mydb;

use mydb;

CREATE TABLE `users` (
  `id` int NOT NULL AUTO_INCREMENT,
  `nombre` varchar(45) NOT NULL,
  PRIMARY KEY (`id`)
);

INSERT INTO `mydb`.`users` (`nombre`) VALUES ('foo');
INSERT INTO `mydb`.`users` (`nombre`) VALUES ('bar');
INSERT INTO `mydb`.`users` (`nombre`) VALUES ('baz');
docker run -e "MYSQL_ROOT_PASSWORD=set-your-password" -p 3306:3306 -d mysql:8.0.28-oracle

@sant123
Copy link

sant123 commented Nov 23, 2022

deno 1.28.1 (release, x86_64-unknown-linux-gnu)
v8 10.9.194.1
typescript 4.8.3

@mrl5
Copy link

mrl5 commented Nov 30, 2022

using mysql 8, for me works with mysql_native_password and fails with caching_sha2_password.

this is actually aligned with:

steps to reproduce

  1. setup mysql 8
docker run --name mysql -d \
    -p 3306:3306  \
   -e MYSQL_ROOT_PASSWORD=change-me --restart unless-stopped \
    mysql:8
  1. log in to mysql server
docker exec -it mysql bash
mysql -u root -p
  1. set caching_sha2_password password
ALTER USER 'root'@'%' IDENTIFIED WITH caching_sha2_password BY 'change-me';
  1. use this script
import { Client } from "https://deno.land/x/[email protected]/mod.ts";


export async function main() {
    const mysql_conn = {
      host: '0.0.0.0',
      port: 3306,
      user: 'root',
      password: 'change-me',
      database: 'mysql'
    };
    mysql_conn.db = mysql_conn.database;
    mysql_conn.hostname = mysql_conn.host;
    mysql_conn.username = mysql_conn.user;

    const client = await new Client().connect(
        mysql_conn,
    );

    return (await client.execute('SHOW TABLES'));
}

console.log(await main())

actual result

INFO connecting 0.0.0.0:3306
INFO close connection
Uncaught Error: Access denied for user 'root'@'172.17.0.1' (using password: YES)
    at PoolConnection.nextPacket (https://deno.land/x/[email protected]/src/connection.ts:216:13)
    at async PoolConnection._connect (https://deno.land/x/[email protected]/src/connection.ts:145:23)
    at async PoolConnection.connect (https://deno.land/x/[email protected]/src/connection.ts:179:5)
    at async Client.createConnection (https://deno.land/x/[email protected]/src/client.ts:47:5)
    at async DeferredStack.creator (https://deno.land/x/[email protected]/src/pool.ts:67:20)
    at async DeferredStack.pop (https://deno.land/x/[email protected]/src/deferred.ts:35:16)
    at async ConnectionPool.pop (https://deno.land/x/[email protected]/src/pool.ts:99:14)
    at async Client.useConnection (https://deno.land/x/[email protected]/src/client.ts:105:24)
    at async Client.execute (https://deno.land/x/[email protected]/src/client.ts:96:12)
    at async main (<anonymous>:15:12)

expected

it runs

workaround

in mysql docker run

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'change-me';

and then re-run the script, it will not throw that error again

@mrl5
Copy link

mrl5 commented Nov 30, 2022

I actually just realized that lack of support for caching_sha2_password is mentioned in todo list in https://deno-mysql.netlify.app/

Support caching_sha2_password auth plugin (mysql8 default)

@manyuanrong are there any plans in nearest future to support it?

@lideming
Copy link
Collaborator

@mrl5 The docs site is outdated. It was supported. I guess recent changes broke it😢. Trying fixing...

@shiyuhang0
Copy link
Contributor

@mrl5 The docs site is outdated. It was supported. I guess recent changes broke it😢. Trying fixing...

It seems you have fixed it #142.
I am curious about the reason for the bug, is it because the encrypt is wrong?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants