aboutsummaryrefslogtreecommitdiff
path: root/node_modules/mysql2/lib/pool_connection.js
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/mysql2/lib/pool_connection.js
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/mysql2/lib/pool_connection.js')
-rw-r--r--node_modules/mysql2/lib/pool_connection.js65
1 files changed, 65 insertions, 0 deletions
diff --git a/node_modules/mysql2/lib/pool_connection.js b/node_modules/mysql2/lib/pool_connection.js
new file mode 100644
index 0000000..be49a73
--- /dev/null
+++ b/node_modules/mysql2/lib/pool_connection.js
@@ -0,0 +1,65 @@
+'use strict';
+
+const Connection = require('../index.js').Connection;
+
+class PoolConnection extends Connection {
+ constructor(pool, options) {
+ super(options);
+ this._pool = pool;
+ // When a fatal error occurs the connection's protocol ends, which will cause
+ // the connection to end as well, thus we only need to watch for the end event
+ // and we will be notified of disconnects.
+ // REVIEW: Moved to `once`
+ this.once('end', () => {
+ this._removeFromPool();
+ });
+ this.once('error', () => {
+ this._removeFromPool();
+ });
+ }
+
+ release() {
+ if (!this._pool || this._pool._closed) {
+ return;
+ }
+ this._pool.releaseConnection(this);
+ }
+
+ promise(promiseImpl) {
+ const PromisePoolConnection = require('../promise').PromisePoolConnection;
+ return new PromisePoolConnection(this, promiseImpl);
+ }
+
+ end() {
+ const err = new Error(
+ 'Calling conn.end() to release a pooled connection is ' +
+ 'deprecated. In next version calling conn.end() will be ' +
+ 'restored to default conn.end() behavior. Use ' +
+ 'conn.release() instead.'
+ );
+ this.emit('warn', err);
+ // eslint-disable-next-line no-console
+ console.warn(err.message);
+ this.release();
+ }
+
+ destroy() {
+ this._removeFromPool();
+ super.destroy();
+ }
+
+ _removeFromPool() {
+ if (!this._pool || this._pool._closed) {
+ return;
+ }
+ const pool = this._pool;
+ this._pool = null;
+ pool._removeConnection(this);
+ }
+}
+
+PoolConnection.statementKey = Connection.statementKey;
+module.exports = PoolConnection;
+
+// TODO: Remove this when we are removing PoolConnection#end
+PoolConnection.prototype._realEnd = Connection.prototype.end;