mysql2 0.4.8-x86-mswin32-60 → 0.4.9-x86-mswin32-60

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: cf65f10b6b4a82b9a6f89d56f20d26816f670ffb
4
- data.tar.gz: a2b8b397938f1ad962b520445a75150fc7b0259c
3
+ metadata.gz: 33f68eda5ac84c1bdb23c7db1d1576c5614321bc
4
+ data.tar.gz: 26125661554f8e6b541b4899950572203e0c81d0
5
5
  SHA512:
6
- metadata.gz: 62d622a05ae89f2ccdfc8855a3f9712b0f28a2a888c73e9af06c472cd0616e89ca307714c57e11ffcbf288ffd7c2e936a4b42d7667428534638f3b860a7704d1
7
- data.tar.gz: 136c4b2c15428ad2595657557d7125d5626d7e08e45f8f8b82de1b2594ead1aed69e4fa84d7ffd0ba316dd937cb831dbe5a859ebced2ceaab1b89a1be39cee6a
6
+ metadata.gz: 03a8109819d6a007f0409ff257fa5b345e8beadfa4a9bc30526d92695a4e20a538b5e85ffa25bcb2e2227e4ace17de6610e59beb73e8a7dc0584256aa459879e
7
+ data.tar.gz: 77b6187cd04b83a78f4185874457ce5a39d199aaf50a6033dee0cb9cc95afcfd9ce9f86b002618f484024dccabb3a55702e844cf266deb8b46736b1ac648e33f
data/README.md CHANGED
@@ -213,21 +213,18 @@ Mysql2::Client.new(
213
213
  )
214
214
  ```
215
215
 
216
- ### Connecting to localhost
217
-
218
- The underlying MySQL client library has a special interpretation of the "localhost" default connection host name:
219
-
220
- 1. Attempt to connect via local socket (as specified in your distribution's my.cnf or `default_file` config file).
221
- 2. But if the socket is not available, look up "localhost" to find an IP address...
222
- * The file "/etc/hosts" is generally the source of truth for "localhost", and can override its value.
223
- * Systems with IPv4 use "127.0.0.1"
224
- * Systems with IPv6 use "::1"
225
- * Systems with both IPv4 and IPv6 can be configured to prefer one or the other.
226
- 3. If an address is found for "localhost", connect to it over TCP/IP.
227
-
228
- You can be explicit about using either a local socket or a TCP/IP connection,
229
- and whether to use IPv4 or IPv6, by specifying a value other than "localhost"
230
- for the `host` or `socket` connection options.
216
+ ### Connecting to MySQL on localhost and elsewhere
217
+
218
+ The underlying MySQL client library uses the `:host` parameter to determine the
219
+ type of connection to make, with special interpretation you should be aware of:
220
+
221
+ * An empty value or `"localhost"` will attempt a local connection:
222
+ * On Unix, connect to the default local socket path. (To set a custom socket
223
+ path, use the `:socket` parameter).
224
+ * On Windows, connect using a shared-memory connection, if enabled, or TCP.
225
+ * A value of `"."` on Windows specifies a named-pipe connection.
226
+ * An IPv4 or IPv6 address will result in a TCP connection.
227
+ * Any other value will be looked up as a hostname for a TCP connection.
231
228
 
232
229
  ### SSL options
233
230
 
@@ -903,7 +903,7 @@ static VALUE _mysql_client_options(VALUE self, int opt, VALUE value) {
903
903
  retval = charval;
904
904
  break;
905
905
 
906
- #ifdef MYSQL_ENABLE_CLEARTEXT_PLUGIN
906
+ #ifdef HAVE_CONST_MYSQL_ENABLE_CLEARTEXT_PLUGIN
907
907
  case MYSQL_ENABLE_CLEARTEXT_PLUGIN:
908
908
  boolval = (value == Qfalse ? 0 : 1);
909
909
  retval = &boolval;
@@ -1328,7 +1328,7 @@ static VALUE set_init_command(VALUE self, VALUE value) {
1328
1328
  }
1329
1329
 
1330
1330
  static VALUE set_enable_cleartext_plugin(VALUE self, VALUE value) {
1331
- #ifdef MYSQL_ENABLE_CLEARTEXT_PLUGIN
1331
+ #ifdef HAVE_CONST_MYSQL_ENABLE_CLEARTEXT_PLUGIN
1332
1332
  return _mysql_client_options(self, MYSQL_ENABLE_CLEARTEXT_PLUGIN, value);
1333
1333
  #else
1334
1334
  rb_raise(cMysql2Error, "enable-cleartext-plugin is not available, you may need a newer MySQL client library");
@@ -114,6 +114,7 @@ mysql_h = [prefix, 'mysql.h'].compact.join('/')
114
114
  add_ssl_defines(mysql_h)
115
115
  have_struct_member('MYSQL', 'net.vio', mysql_h)
116
116
  have_struct_member('MYSQL', 'net.pvio', mysql_h)
117
+ have_const('MYSQL_ENABLE_CLEARTEXT_PLUGIN', mysql_h)
117
118
 
118
119
  # This is our wishlist. We use whichever flags work on the host.
119
120
  # -Wall and -Wextra are included by default.
@@ -343,6 +343,16 @@ static VALUE execute(int argc, VALUE *argv, VALUE self) {
343
343
  #endif
344
344
  set_buffer_for_string(&bind_buffers[i], &length_buffers[i], params_enc[i]);
345
345
  break;
346
+ case T_TRUE:
347
+ bind_buffers[i].buffer_type = MYSQL_TYPE_TINY;
348
+ bind_buffers[i].buffer = xmalloc(sizeof(signed char));
349
+ *(signed char*)(bind_buffers[i].buffer) = 1;
350
+ break;
351
+ case T_FALSE:
352
+ bind_buffers[i].buffer_type = MYSQL_TYPE_TINY;
353
+ bind_buffers[i].buffer = xmalloc(sizeof(signed char));
354
+ *(signed char*)(bind_buffers[i].buffer) = 0;
355
+ break;
346
356
  default:
347
357
  // TODO: what Ruby type should support MYSQL_TYPE_TIME
348
358
  if (CLASS_OF(argv[i]) == rb_cTime || CLASS_OF(argv[i]) == cDateTime) {
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
@@ -1,3 +1,3 @@
1
1
  module Mysql2
2
- VERSION = "0.4.8"
2
+ VERSION = "0.4.9"
3
3
  end
@@ -1026,6 +1026,11 @@ RSpec.describe Mysql2::Client do
1026
1026
  expect(@client.ping).to eql(false)
1027
1027
  end
1028
1028
 
1029
+ it "should be able to connect using plaintext password" do
1030
+ client = new_client(:enable_cleartext_plugin => true)
1031
+ client.query('SELECT 1')
1032
+ end
1033
+
1029
1034
  unless RUBY_VERSION =~ /1.8/
1030
1035
  it "should respond to #encoding" do
1031
1036
  expect(@client).to respond_to(:encoding)
@@ -61,6 +61,12 @@ RSpec.describe Mysql2::Statement do
61
61
  expect(rows).to eq([{ "1" => 1 }])
62
62
  end
63
63
 
64
+ it "should handle booleans" do
65
+ stmt = @client.prepare('SELECT ? AS `true`, ? AS `false`')
66
+ result = stmt.execute(true, false)
67
+ expect(result.to_a).to eq(['true' => 1, 'false' => 0])
68
+ end
69
+
64
70
  it "should handle bignum but in int64_t" do
65
71
  stmt = @client.prepare('SELECT ? AS max, ? AS min')
66
72
  int64_max = (1 << 63) - 1
Binary file
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mysql2
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.8
4
+ version: 0.4.9
5
5
  platform: x86-mswin32-60
6
6
  authors:
7
7
  - Brian Lopez
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2017-07-10 00:00:00.000000000 Z
12
+ date: 2017-08-11 00:00:00.000000000 Z
13
13
  dependencies: []
14
14
  description:
15
15
  email:
@@ -91,11 +91,11 @@ post_install_message: |2+
91
91
  ======================================================================================================
92
92
 
93
93
  You've installed the binary version of mysql2.
94
- It was built using MySQL Connector/C version 6.1.10.
94
+ It was built using MySQL Connector/C version 6.1.11.
95
95
  It's recommended to use the exact same version to avoid potential issues.
96
96
 
97
97
  At the time of building this gem, the necessary DLL files were retrieved from:
98
- http://cdn.mysql.com/Downloads/Connector-C/mysql-connector-c-6.1.10-win32.zip
98
+ http://cdn.mysql.com/Downloads/Connector-C/mysql-connector-c-6.1.11-win32.zip
99
99
 
100
100
  This gem *includes* vendor/libmysql.dll with redistribution notice in vendor/README.
101
101