From 9d231b78878f3c4ba797455ef3db15b793944f2b Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Tue, 26 Mar 2019 10:08:02 -0400 Subject: [PATCH 1/5] Adding RateLimiter and useLimiter rate limiting approach to EV3. --- src/extensions/scratch3_ev3/index.js | 33 ++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index ed47ffb5c..a9e404f2e 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -6,6 +6,7 @@ const uid = require('../../util/uid'); const BT = require('../../io/bt'); const Base64Util = require('../../util/base64-util'); const MathUtil = require('../../util/math-util'); +const RateLimiter = require('../../util/rateLimiter.js'); const log = require('../../util/log'); /** @@ -15,6 +16,18 @@ const log = require('../../util/log'); // eslint-disable-next-line max-len const blockIconURI = ''; +/** + * A time interval to wait (in milliseconds) while a block that sends a BT message is running. + * @type {number} + */ +const BTSendInterval = 100; + +/** + * A maximum number of BT message sends per second, to be enforced by the rate limiter. + * @type {number} + */ +const BTSendRateMax = 20; + /** * Enum for Ev3 direct command types. * Found in the 'EV3 Communication Developer Kit', section 4, page 24, at @@ -357,7 +370,7 @@ class EV3Motor { ] ); - this._parent.send(cmd); + this._parent.send(cmd, false); } /** @@ -476,6 +489,14 @@ class EV3 { this._bt = null; this._runtime.registerPeripheralExtension(extensionId, this); + /** + * A rate limiter utility, to help limit the rate at which we send BLE messages + * over the socket to Scratch Link to a maximum number of sends per second. + * @type {RateLimiter} + * @private + */ + this._rateLimiter = new RateLimiter(BTSendRateMax); + this.disconnect = this.disconnect.bind(this); this._onConnect = this._onConnect.bind(this); this._onMessage = this._onMessage.bind(this); @@ -541,7 +562,7 @@ class EV3 { ] ); - this.send(cmd); + this.send(cmd, false); } stopAllMotors () { @@ -603,12 +624,16 @@ class EV3 { /** * Send a message to the peripheral BT socket. * @param {Uint8Array} message - the message to send. + * @param {boolean} [useLimiter=true] - if true, use the rate limiter * @return {Promise} - a promise result of the send operation. */ - send (message) { - // TODO: add rate limiting? + send (message, useLimiter = true) { if (!this.isConnected()) return Promise.resolve(); + if (useLimiter) { + if (!this._rateLimiter.okayToSend()) return Promise.resolve(); + } + return this._bt.sendMessage({ message: Base64Util.uint8ArrayToBase64(message), encoding: 'base64' From 52519ae1e023ca16d8cbe376bf310a2dc01625d6 Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Tue, 26 Mar 2019 10:11:04 -0400 Subject: [PATCH 2/5] Add comment. --- src/extensions/scratch3_ev3/index.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index a9e404f2e..d2081fb62 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -370,7 +370,7 @@ class EV3Motor { ] ); - this._parent.send(cmd, false); + this._parent.send(cmd, false); // don't use rate limiter to ensure motor stops } /** @@ -562,7 +562,7 @@ class EV3 { ] ); - this.send(cmd, false); + this.send(cmd, false); // don't use rate limiter to ensure sound stops } stopAllMotors () { From 62a8f2d0f2a93b775fe2fc29f3c88836a417389d Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Tue, 26 Mar 2019 10:13:28 -0400 Subject: [PATCH 3/5] Fix typo. --- src/extensions/scratch3_ev3/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index d2081fb62..c5926966a 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -490,7 +490,7 @@ class EV3 { this._runtime.registerPeripheralExtension(extensionId, this); /** - * A rate limiter utility, to help limit the rate at which we send BLE messages + * A rate limiter utility, to help limit the rate at which we send BT messages * over the socket to Scratch Link to a maximum number of sends per second. * @type {RateLimiter} * @private From d76756f5f68d5a3fc61bec1b43af9aabc530f33b Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Tue, 26 Mar 2019 11:26:58 -0400 Subject: [PATCH 4/5] Removing BTSendInterval, not needed. --- src/extensions/scratch3_ev3/index.js | 6 ------ 1 file changed, 6 deletions(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index c5926966a..3764ba94c 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -16,12 +16,6 @@ const log = require('../../util/log'); // eslint-disable-next-line max-len const blockIconURI = ''; -/** - * A time interval to wait (in milliseconds) while a block that sends a BT message is running. - * @type {number} - */ -const BTSendInterval = 100; - /** * A maximum number of BT message sends per second, to be enforced by the rate limiter. * @type {number} From 58908bb1a43bfc69488feb6079915f28e55d6f2c Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Fri, 17 May 2019 11:43:06 -0400 Subject: [PATCH 5/5] Changing BTSendRateMax to help with key-down scenarios. --- src/extensions/scratch3_ev3/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index 3764ba94c..208f3391f 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -20,7 +20,7 @@ const blockIconURI = ' * A maximum number of BT message sends per second, to be enforced by the rate limiter. * @type {number} */ -const BTSendRateMax = 20; +const BTSendRateMax = 40; /** * Enum for Ev3 direct command types.