From 46e0e02cbc5c8ad9e48da4461482caad09a80290 Mon Sep 17 00:00:00 2001 From: Volker Mische Date: Sat, 26 May 2018 23:07:34 +0100 Subject: [PATCH] feat: add codec name to codec code helper Introduce the function `getCodeVarint()` to return a Buffer containing the Varint encoded codec code of a given codec name. It throws an error if the codec isn't found. Reason for this change was the js-cid module that is using the conversion table directly. If the codec doesn't exist it would throw error messages that didn't make much sense. --- src/index.js | 13 +++++++++++++ test/multicodec.spec.js | 13 +++++++++++++ 2 files changed, 26 insertions(+) diff --git a/src/index.js b/src/index.js index fc51399..11160f3 100644 --- a/src/index.js +++ b/src/index.js @@ -61,3 +61,16 @@ exports.getCodec = (prefixedData) => { const codecName = codeToCodecName[code.toString('hex')] return codecName } + +/** + * Get the code as varint of a codec name. + * @param {string} codecName + * @returns {Buffer} + */ +exports.getCodeVarint = (codecName) => { + const code = codecNameToCodeVarint[codecName] + if (code === undefined) { + throw new Error('Codec `' + codecName + '` not found') + } + return code +} diff --git a/test/multicodec.spec.js b/test/multicodec.spec.js index fb340a7..d34567b 100644 --- a/test/multicodec.spec.js +++ b/test/multicodec.spec.js @@ -28,4 +28,17 @@ describe('multicodec', () => { expect(multicodec.getCodec(prefixedBuf)).to.equal('eth-block') expect(buf).to.eql(multicodec.rmPrefix(prefixedBuf)) }) + + it('returns code via codec name', () => { + const code = multicodec.getCodeVarint('keccak-256') + expect(code).to.eql(Buffer.from('1b', 'hex')) + }) + + it('throws error on unknown codec name when getting the code', () => { + expect(() => { + multicodec.getCodeVarint('this-codec-doesnt-exist') + }).to.throw( + 'Codec `this-codec-doesnt-exist` not found' + ) + }) })