mirror of https://github.com/waku-org/js-waku.git
fix: measure total message size (#1643)
Network message limitations are imposed on the whole message, not just the payload. Co-authored-by: Sasha <118575614+weboko@users.noreply.github.com>
This commit is contained in:
parent
b3864f8772
commit
b7dc3d7576
|
@ -11,7 +11,10 @@ import {
|
|||
SendResult
|
||||
} from "@waku/interfaces";
|
||||
import { PushResponse } from "@waku/proto";
|
||||
import { ensurePubsubTopicIsConfigured, isSizeUnderCap } from "@waku/utils";
|
||||
import {
|
||||
ensurePubsubTopicIsConfigured,
|
||||
isMessageSizeUnderCap
|
||||
} from "@waku/utils";
|
||||
import { Logger } from "@waku/utils";
|
||||
import all from "it-all";
|
||||
import * as lp from "it-length-prefixed";
|
||||
|
@ -61,7 +64,7 @@ class LightPush extends BaseProtocol implements ILightPush {
|
|||
return { query: null, error: SendError.EMPTY_PAYLOAD };
|
||||
}
|
||||
|
||||
if (!isSizeUnderCap(message.payload)) {
|
||||
if (!(await isMessageSizeUnderCap(encoder, message))) {
|
||||
log.error("Failed to send waku light push: message is bigger than 1MB");
|
||||
return { query: null, error: SendError.SIZE_TOO_BIG };
|
||||
}
|
||||
|
|
|
@ -25,7 +25,7 @@ import {
|
|||
SendError,
|
||||
SendResult
|
||||
} from "@waku/interfaces";
|
||||
import { isSizeUnderCap, toAsyncIterator } from "@waku/utils";
|
||||
import { isWireSizeUnderCap, toAsyncIterator } from "@waku/utils";
|
||||
import { pushOrInitMapSet } from "@waku/utils";
|
||||
import { Logger } from "@waku/utils";
|
||||
|
||||
|
@ -112,14 +112,6 @@ class Relay implements IRelay {
|
|||
};
|
||||
}
|
||||
|
||||
if (!isSizeUnderCap(message.payload)) {
|
||||
log.error("Failed to send waku relay: message is bigger that 1MB");
|
||||
return {
|
||||
recipients,
|
||||
errors: [SendError.SIZE_TOO_BIG]
|
||||
};
|
||||
}
|
||||
|
||||
const msg = await encoder.toWire(message);
|
||||
if (!msg) {
|
||||
log.error("Failed to encode message, aborting publish");
|
||||
|
@ -129,6 +121,14 @@ class Relay implements IRelay {
|
|||
};
|
||||
}
|
||||
|
||||
if (!isWireSizeUnderCap(msg)) {
|
||||
log.error("Failed to send waku relay: message is bigger that 1MB");
|
||||
return {
|
||||
recipients,
|
||||
errors: [SendError.SIZE_TOO_BIG]
|
||||
};
|
||||
}
|
||||
|
||||
return this.gossipSub.publish(pubsubTopic, msg);
|
||||
}
|
||||
|
||||
|
|
|
@ -204,14 +204,8 @@ describe("Waku Light Push", function () {
|
|||
});
|
||||
|
||||
it("Push message equal or less that 1MB", async function () {
|
||||
const oneMbPayload = generateRandomUint8Array(1024 ** 2);
|
||||
let pushResponse = await waku.lightPush.send(TestEncoder, {
|
||||
payload: oneMbPayload
|
||||
});
|
||||
expect(pushResponse.recipients.length).to.greaterThan(0);
|
||||
|
||||
const bigPayload = generateRandomUint8Array(65536);
|
||||
pushResponse = await waku.lightPush.send(TestEncoder, {
|
||||
const pushResponse = await waku.lightPush.send(TestEncoder, {
|
||||
payload: bigPayload
|
||||
});
|
||||
expect(pushResponse.recipients.length).to.greaterThan(0);
|
||||
|
|
|
@ -141,17 +141,6 @@ describe("Waku Relay, Publish", function () {
|
|||
expect(await messageCollector.waitForMessages(1)).to.eq(false);
|
||||
});
|
||||
|
||||
it("Publish message with size of 1 MB", async function () {
|
||||
const pushResponse = await waku1.relay.send(TestEncoder, {
|
||||
payload: generateRandomUint8Array(1024 ** 2)
|
||||
});
|
||||
expect(pushResponse.recipients.length).to.eq(1);
|
||||
expect(pushResponse.recipients[0].toString()).to.eq(
|
||||
waku2.libp2p.peerId.toString()
|
||||
);
|
||||
expect(await messageCollector.waitForMessages(1)).to.eq(true);
|
||||
});
|
||||
|
||||
[1024 ** 2 + 65536, 2 * 1024 ** 2].forEach((testItem) => {
|
||||
it("Fails to publish message with size larger than 1 MB", async function () {
|
||||
const pushResponse = await waku1.relay.send(TestEncoder, {
|
||||
|
|
|
@ -1,10 +1,23 @@
|
|||
import type { IEncoder, IMessage } from "@waku/interfaces";
|
||||
|
||||
const MB = 1024 ** 2;
|
||||
const SIZE_CAP = 1; // 1 MB
|
||||
const SIZE_CAP_IN_MB = 1;
|
||||
|
||||
export const isSizeUnderCap = (payload: Uint8Array): boolean => {
|
||||
if (payload.length / MB > SIZE_CAP) {
|
||||
return false;
|
||||
}
|
||||
/**
|
||||
* Return whether the size of the message is under the upper limit for the network.
|
||||
* This performs a protobuf encoding! If you have access to the fully encoded message,
|
||||
* use {@link isSizeUnderCapBuf} instead.
|
||||
* @param message
|
||||
* @param encoder
|
||||
*/
|
||||
export async function isMessageSizeUnderCap(
|
||||
encoder: IEncoder,
|
||||
message: IMessage
|
||||
): Promise<boolean> {
|
||||
const buf = await encoder.toWire(message);
|
||||
if (!buf) return false;
|
||||
return isWireSizeUnderCap(buf);
|
||||
}
|
||||
|
||||
return true;
|
||||
};
|
||||
export const isWireSizeUnderCap = (buf: Uint8Array): boolean =>
|
||||
buf.length / MB <= SIZE_CAP_IN_MB;
|
||||
|
|
Loading…
Reference in New Issue