You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-06 02:15:48 +03:00
Add rename_commands option
This commit is contained in:
@@ -5,7 +5,7 @@ redis - a node.js redis client
|
||||
[](https://coveralls.io/r/NodeRedis/node_redis?branch=)
|
||||
[](https://ci.appveyor.com/project/bcoe/node-redis)
|
||||
|
||||
This is a complete Redis client for node.js. It supports all Redis commands and focuses on performance.
|
||||
This is a complete and feature rich Redis client for node.js. It supports all Redis commands and focuses on performance.
|
||||
|
||||
Install with:
|
||||
|
||||
@@ -204,6 +204,7 @@ limits total amount of connection tries. Setting this to 1 will prevent any reco
|
||||
* `auth_pass`: *null*; If set, client will run redis auth command on connect.
|
||||
* `family`: *IPv4*; You can force using IPv6 if you set the family to 'IPv6'. See Node.js [net](https://nodejs.org/api/net.html) or [dns](https://nodejs.org/api/dns.html) modules how to use the family type.
|
||||
* `disable_resubscribing`: *false*; If set to `true`, a client won't resubscribe after disconnecting
|
||||
* `rename_commands`: *null*; pass a object with renamed commands to use those instead of the original functions. See the [redis security topics](http://redis.io/topics/security) for more info.
|
||||
|
||||
```js
|
||||
var redis = require("redis"),
|
||||
|
@@ -6,6 +6,7 @@ Changelog
|
||||
Features
|
||||
|
||||
- Added disable_resubscribing option to prevent a client from resubscribing after reconnecting (@BridgeAR)
|
||||
- Added rename_commands options to handle renamed commands from the redis config (@digmxl & @BridgeAR)
|
||||
|
||||
Bugfixes
|
||||
|
||||
|
19
index.js
19
index.js
@@ -42,11 +42,18 @@ function RedisClient(stream, options) {
|
||||
this.connected = false;
|
||||
this.ready = false;
|
||||
this.connections = 0;
|
||||
if (this.options.socket_nodelay === undefined) {
|
||||
this.options.socket_nodelay = true;
|
||||
if (options.socket_nodelay === undefined) {
|
||||
options.socket_nodelay = true;
|
||||
}
|
||||
if (options.socket_keepalive === undefined) {
|
||||
options.socket_keepalive = true;
|
||||
}
|
||||
if (options.rename_commands) {
|
||||
for (var command in options.rename_commands) {
|
||||
if (options.rename_commands.hasOwnProperty(command)) {
|
||||
options.rename_commands[command.toLowerCase()] = options.rename_commands[command];
|
||||
}
|
||||
}
|
||||
if (this.options.socket_keepalive === undefined) {
|
||||
this.options.socket_keepalive = true;
|
||||
}
|
||||
this.should_buffer = false;
|
||||
this.command_queue_high_water = options.command_queue_high_water || 1000;
|
||||
@@ -720,6 +727,10 @@ RedisClient.prototype.send_command = function (command, args, callback) {
|
||||
|
||||
elem_count = args.length + 1;
|
||||
|
||||
if (typeof this.options.rename_commands !== 'undefined' && this.options.rename_commands[command]) {
|
||||
command = this.options.rename_commands[command];
|
||||
}
|
||||
|
||||
// Always use 'Multi bulk commands', but if passed any Buffer args, then do multiple writes, one for each arg.
|
||||
// This means that using Buffers in commands is going to be slower, so use Strings if you don't already have a Buffer.
|
||||
|
||||
|
7
test/conf/rename.conf
Normal file
7
test/conf/rename.conf
Normal file
@@ -0,0 +1,7 @@
|
||||
port 6379
|
||||
bind ::1 127.0.0.1
|
||||
unixsocket /tmp/redis.sock
|
||||
unixsocketperm 755
|
||||
rename-command SET 807081f5afa96845a02816a28b7258c3
|
||||
rename-command GET f397808a43ceca3963e22b4e13deb672
|
||||
rename-command GETRANGE 9e3102b15cf231c4e9e940f284744fe0
|
110
test/rename.spec.js
Normal file
110
test/rename.spec.js
Normal file
@@ -0,0 +1,110 @@
|
||||
'use strict';
|
||||
|
||||
var assert = require("assert");
|
||||
var config = require("./lib/config");
|
||||
var helper = require('./helper');
|
||||
var redis = config.redis;
|
||||
|
||||
describe("rename commands", function () {
|
||||
before(function (done) {
|
||||
helper.stopRedis(function () {
|
||||
helper.startRedis('./conf/rename.conf', done);
|
||||
});
|
||||
});
|
||||
|
||||
helper.allTests(function(parser, ip, args) {
|
||||
|
||||
describe("using " + parser + " and " + ip, function () {
|
||||
var client = null;
|
||||
|
||||
afterEach(function () {
|
||||
client.end();
|
||||
});
|
||||
|
||||
it("allows to use renamed functions", function (done) {
|
||||
if (helper.redisProcess().spawnFailed()) this.skip();
|
||||
|
||||
client = redis.createClient({
|
||||
rename_commands: {
|
||||
set: '807081f5afa96845a02816a28b7258c3',
|
||||
GETRANGE: '9e3102b15cf231c4e9e940f284744fe0'
|
||||
}
|
||||
});
|
||||
|
||||
client.set('key', 'value', function(err, reply) {
|
||||
assert.strictEqual(reply, 'OK');
|
||||
});
|
||||
|
||||
client.get('key', function(err, reply) {
|
||||
assert.strictEqual(err.message, "ERR unknown command 'get'");
|
||||
assert.strictEqual(err.command, 'GET');
|
||||
assert.strictEqual(reply, undefined);
|
||||
});
|
||||
|
||||
client.getrange('key', 1, -1, function(err, reply) {
|
||||
assert.strictEqual(reply, 'alue');
|
||||
assert.strictEqual(err, null);
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it("should also work with multi", function (done) {
|
||||
if (helper.redisProcess().spawnFailed()) this.skip();
|
||||
|
||||
client = redis.createClient({
|
||||
rename_commands: {
|
||||
SET: '807081f5afa96845a02816a28b7258c3',
|
||||
getrange: '9e3102b15cf231c4e9e940f284744fe0'
|
||||
}
|
||||
});
|
||||
|
||||
client.multi([['set', 'key', 'value']]).exec(function (err, res) {
|
||||
assert.strictEqual(res[0], 'OK');
|
||||
});
|
||||
|
||||
var multi = client.multi();
|
||||
multi.getrange('key', 1, -1);
|
||||
multi.exec(function (err, res) {
|
||||
assert(!err);
|
||||
assert.strictEqual(res.length, 1);
|
||||
assert.strictEqual(res[0], 'alue');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it("should also work with multi and abort transaction", function (done) {
|
||||
if (helper.redisProcess().spawnFailed()) this.skip();
|
||||
|
||||
client = redis.createClient({
|
||||
rename_commands: {
|
||||
SET: '807081f5afa96845a02816a28b7258c3',
|
||||
getrange: '9e3102b15cf231c4e9e940f284744fe0'
|
||||
}
|
||||
});
|
||||
|
||||
var multi = client.multi();
|
||||
multi.get('key');
|
||||
multi.getrange('key', 1, -1, function(err, reply) {
|
||||
assert.strictEqual(reply, 'alue');
|
||||
assert.strictEqual(err, null);
|
||||
});
|
||||
multi.exec(function (err, res) {
|
||||
assert(err);
|
||||
assert.strictEqual(err.message, 'EXECABORT Transaction discarded because of previous errors.');
|
||||
assert.strictEqual(err.errors[0].message, "ERR unknown command 'get'");
|
||||
assert.strictEqual(err.errors[0].command, 'GET');
|
||||
assert.strictEqual(err.code, 'EXECABORT');
|
||||
assert.strictEqual(err.errors[0].code, 'ERR');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
after(function (done) {
|
||||
helper.stopRedis(function () {
|
||||
helper.startRedis('./conf/redis.conf', done);
|
||||
});
|
||||
});
|
||||
});
|
Reference in New Issue
Block a user