New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@penumbra-zone/constants

Package Overview
Dependencies
Maintainers
3
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@penumbra-zone/constants - npm Package Compare versions

Comparing version 1.1.0 to 2.0.0

10

CHANGELOG.md
# @penumbra-zone/constants
## 2.0.0
### Major Changes
- 929d278: barrel imports to facilitate better tree shaking
### Patch Changes
- 8933117: Account for changes to core
## 1.1.0

@@ -4,0 +14,0 @@

28

dist/assets.d.ts
import { Metadata as Metadata_2 } from '@buf/penumbra-zone_penumbra.bufbuild_es/penumbra/core/asset/v1/asset_pb';
export declare interface AssetPatterns {
lpNft: RegExp;
delegationToken: RegExp;
proposalNft: RegExp;
unbondingToken: RegExp;
votingReceipt: RegExp;
lpNft: RegexMatcher;
delegationToken: RegexMatcher<DelegationCaptureGroups>;
proposalNft: RegexMatcher;
unbondingToken: RegexMatcher<UnbondingCaptureGroups>;
votingReceipt: RegexMatcher;
ibc: RegexMatcher<IbcCaptureGroups>;
}
/**
* Call `.test()` on these RegExp patterns to test whether a token is of a given type.
* Call `.matches()` on these RegExp patterns to test whether a token is of a given type.
* Call `.capture()` to grab the content by its capture groups (if present)
*

@@ -34,4 +36,16 @@ * NOTE - SECURITY IMPLICATIONS: These RegExps each assert that the given prefix

export declare interface IbcCaptureGroups {
channel: string;
denom: string;
}
export declare const localAssets: Metadata_2[];
export declare class RegexMatcher<T = never> {
private readonly regex;
constructor(regex: RegExp);
matches(str: string): boolean;
capture(str: string): T | undefined;
}
export declare const STAKING_TOKEN = "penumbra";

@@ -42,3 +56,3 @@

export declare interface UnbondingCaptureGroups {
epoch: string;
startAt: string;
id: string;

@@ -45,0 +59,0 @@ bech32IdentityKey: string;

@@ -6,2 +6,3 @@ export declare interface Chain {

iconUrl: string;
addressPrefix: string;
}

@@ -8,0 +9,0 @@

@@ -6,3 +6,11 @@ const s = [

ibcChannel: "channel-0",
iconUrl: "https://raw.githubusercontent.com/cosmos/chain-registry/f1348793beb994c6cc0256ed7ebdb48c7aa70003/osmosis/images/osmo.svg"
iconUrl: "https://raw.githubusercontent.com/cosmos/chain-registry/f1348793beb994c6cc0256ed7ebdb48c7aa70003/osmosis/images/osmo.svg",
addressPrefix: "osmo"
},
{
displayName: "Noble",
chainId: "grand-1",
ibcChannel: "channel-3",
iconUrl: "https://raw.githubusercontent.com/cosmos/chain-registry/2ca39d0e4eaf3431cca13991948e099801f02e46/noble/images/stake.svg",
addressPrefix: "noble"
}

@@ -9,0 +17,0 @@ ];

{
"name": "@penumbra-zone/constants",
"version": "1.1.0",
"version": "2.0.0",
"license": "MIT",

@@ -14,3 +14,4 @@ "type": "module",

"clean": "rm -rfv dist",
"lint": "eslint \"**/*.ts*\""
"lint": "eslint \"**/*.ts*\"",
"test": "vitest run"
},

@@ -17,0 +18,0 @@ "exports": {

import { describe, expect, it } from 'vitest';
import { assetPatterns } from './assets';
import { assetPatterns, RegexMatcher } from './assets';

@@ -7,7 +7,7 @@ describe('assetPatterns', () => {

it('matches when a string begins with `lpnft_`', () => {
expect(assetPatterns.lpNft.test('lpnft_abc123')).toBe(true);
expect(assetPatterns.lpNft.matches('lpnft_abc123')).toBe(true);
});
it('does not match when a string contains, but does not begin with, `lpnft_`', () => {
expect(assetPatterns.lpNft.test('ibc-transfer/channel-1234/lpnft_abc123')).toBe(false);
expect(assetPatterns.lpNft.matches('ibc-transfer/channel-1234/lpnft_abc123')).toBe(false);
});

@@ -18,3 +18,3 @@ });

it('matches when a string is a valid delegation token name', () => {
expect(assetPatterns.delegationToken.test('delegation_penumbravalid1abc123')).toBe(true);
expect(assetPatterns.delegationToken.matches('delegation_penumbravalid1abc123')).toBe(true);
});

@@ -24,3 +24,3 @@

expect(
assetPatterns.delegationToken.test(
assetPatterns.delegationToken.matches(
'ibc-transfer/channel-1234/delegation_penumbravalid1abc123',

@@ -34,7 +34,7 @@ ),

it('matches when a string begins with `proposal_`', () => {
expect(assetPatterns.proposalNft.test('proposal_abc123')).toBe(true);
expect(assetPatterns.proposalNft.matches('proposal_abc123')).toBe(true);
});
it('does not match when a string contains, but does not begin with, `proposal_`', () => {
expect(assetPatterns.proposalNft.test('ibc-transfer/channel-1234/proposal_abc123')).toBe(
expect(assetPatterns.proposalNft.matches('ibc-transfer/channel-1234/proposal_abc123')).toBe(
false,

@@ -47,5 +47,12 @@ );

it('matches when a string is a valid unbonding token name', () => {
expect(assetPatterns.unbondingToken.test('uunbonding_epoch_1_penumbravalid1abc123')).toBe(
true,
expect(
assetPatterns.unbondingToken.matches('unbonding_start_at_1_penumbravalid1abc123'),
).toBe(true);
});
it('captures the unbonding start height', () => {
const match = assetPatterns.unbondingToken.capture(
'unbonding_start_at_1_penumbravalid1abc123',
);
expect(match?.startAt).toBe('1');
});

@@ -55,4 +62,4 @@

expect(
assetPatterns.unbondingToken.test(
'ibc-transfer/channel-1234/uunbonding_epoch_1_penumbravalid1abc123',
assetPatterns.unbondingToken.matches(
'ibc-transfer/channel-1234/unbonding_start_at_1_penumbravalid1abc123',
),

@@ -65,7 +72,7 @@ ).toBe(false);

it('matches when a string begins with `voted_on_`', () => {
expect(assetPatterns.votingReceipt.test('voted_on_abc123')).toBe(true);
expect(assetPatterns.votingReceipt.matches('voted_on_abc123')).toBe(true);
});
it('does not match when a string contains, but does not begin with, `voted_on_`', () => {
expect(assetPatterns.votingReceipt.test('ibc-transfer/channel-1234/voted_on_abc123')).toBe(
expect(assetPatterns.votingReceipt.matches('ibc-transfer/channel-1234/voted_on_abc123')).toBe(
false,

@@ -75,2 +82,68 @@ );

});
describe('ibc', () => {
it('matches when a string follows the pattern transfer/<channel>/<denom>', () => {
expect(assetPatterns.ibc.matches('transfer/channel-141/uosmo')).toBeTruthy();
expect(assetPatterns.ibc.matches('transfer/channel-0/upenumbra')).toBeTruthy();
expect(assetPatterns.ibc.matches('transfer/channel-0/upenumbra/moo/test')).toBeTruthy();
expect(assetPatterns.ibc.matches('x/channel-0/upenumbra')).toBeFalsy();
});
it('captures channel and denom correctly', () => {
const match = assetPatterns.ibc.capture('transfer/channel-141/uosmo');
expect(match?.channel).toBe('channel-141');
expect(match?.denom).toBe('uosmo');
});
it('captures multi-hops', () => {
const match = assetPatterns.ibc.capture('transfer/channel-141/transfer/channel-42/uosmo');
expect(match?.channel).toBe('channel-141');
expect(match?.denom).toBe('transfer/channel-42/uosmo');
});
});
});
describe('RegexMatcher', () => {
describe('RegexMatcher.matches', () => {
it('should return true when the string matches the regex', () => {
const regex = /^[a-z]+$/;
const matcher = new RegexMatcher(regex);
expect(matcher.matches('abc')).toBe(true);
});
it('should return false when the string does not match the regex', () => {
const regex = /^[a-z]+$/;
const matcher = new RegexMatcher(regex);
expect(matcher.matches('123')).toBe(false);
});
});
it('should return undefined if no groups are present', () => {
const regex = /hello/;
const matcher = new RegexMatcher(regex);
// eslint-disable-next-line @typescript-eslint/no-confusing-void-expression
expect(matcher.capture('hello')).toBeUndefined();
});
it('should return undefined if the string does not match', () => {
const regex = /hello/;
const matcher = new RegexMatcher(regex);
// eslint-disable-next-line @typescript-eslint/no-confusing-void-expression
expect(matcher.capture('world')).toBeUndefined();
});
it('should return typed capture groups object if present', () => {
interface GreetingSubjectGroups {
greeting: string;
subject: string;
}
const regex = /(?<greeting>hello) (?<subject>world)/;
const matcher = new RegexMatcher<GreetingSubjectGroups>(regex);
const expected: GreetingSubjectGroups = {
greeting: 'hello',
subject: 'world',
};
expect(matcher.capture('hello world')).toEqual(expected);
});
});

@@ -14,8 +14,5 @@ import { Metadata } from '@buf/penumbra-zone_penumbra.bufbuild_es/penumbra/core/asset/v1/asset_pb';

export interface AssetPatterns {
lpNft: RegExp;
delegationToken: RegExp;
proposalNft: RegExp;
unbondingToken: RegExp;
votingReceipt: RegExp;
export interface IbcCaptureGroups {
channel: string;
denom: string;
}

@@ -29,3 +26,3 @@

export interface UnbondingCaptureGroups {
epoch: string;
startAt: string;
id: string;

@@ -35,4 +32,28 @@ bech32IdentityKey: string;

export interface AssetPatterns {
lpNft: RegexMatcher;
delegationToken: RegexMatcher<DelegationCaptureGroups>;
proposalNft: RegexMatcher;
unbondingToken: RegexMatcher<UnbondingCaptureGroups>;
votingReceipt: RegexMatcher;
ibc: RegexMatcher<IbcCaptureGroups>;
}
export class RegexMatcher<T = never> {
constructor(private readonly regex: RegExp) {}
matches(str: string): boolean {
return this.regex.exec(str) !== null;
}
capture(str: string): T | undefined {
const match = this.regex.exec(str);
if (!match) return undefined;
return match.groups as unknown as T;
}
}
/**
* Call `.test()` on these RegExp patterns to test whether a token is of a given type.
* Call `.matches()` on these RegExp patterns to test whether a token is of a given type.
* Call `.capture()` to grab the content by its capture groups (if present)
*

@@ -53,15 +74,12 @@ * NOTE - SECURITY IMPLICATIONS: These RegExps each assert that the given prefix

export const assetPatterns: AssetPatterns = {
lpNft: new RegExp(/^lpnft_/),
delegationToken: new RegExp(
lpNft: new RegexMatcher(/^lpnft_/),
delegationToken: new RegexMatcher(
/^delegation_(?<bech32IdentityKey>penumbravalid1(?<id>[a-zA-HJ-NP-Z0-9]+))$/,
),
proposalNft: new RegExp(/^proposal_/),
/**
* Unbonding tokens have only one denom unit, which is the base denom. Hence
* the extra `u` at the beginning.
*/
unbondingToken: new RegExp(
/^uunbonding_epoch_(?<epoch>[0-9]+)_(?<bech32IdentityKey>penumbravalid1(?<id>[a-zA-HJ-NP-Z0-9]+))$/,
proposalNft: new RegexMatcher(/^proposal_/),
unbondingToken: new RegexMatcher(
/^unbonding_start_at_(?<startAt>[0-9]+)_(?<bech32IdentityKey>penumbravalid1(?<id>[a-zA-HJ-NP-Z0-9]+))$/,
),
votingReceipt: new RegExp(/^voted_on_/),
votingReceipt: new RegexMatcher(/^voted_on_/),
ibc: new RegexMatcher(/^transfer\/(?<channel>channel-\d+)\/(?<denom>.*)/),
};

@@ -1,2 +0,1 @@

// Canonical data source: https://github.com/cosmos/chain-registry/tree/master
export interface Chain {

@@ -7,4 +6,6 @@ displayName: string;

iconUrl: string;
addressPrefix: string;
}
// Canonical data source: https://github.com/cosmos/chain-registry/tree/master
export const testnetIbcChains: Chain[] = [

@@ -17,3 +18,12 @@ {

'https://raw.githubusercontent.com/cosmos/chain-registry/f1348793beb994c6cc0256ed7ebdb48c7aa70003/osmosis/images/osmo.svg',
addressPrefix: 'osmo',
},
{
displayName: 'Noble',
chainId: 'grand-1',
ibcChannel: 'channel-3',
iconUrl:
'https://raw.githubusercontent.com/cosmos/chain-registry/2ca39d0e4eaf3431cca13991948e099801f02e46/noble/images/stake.svg',
addressPrefix: 'noble',
},
];

@@ -24,3 +24,3 @@ [

{
"svg": "https://raw.githubusercontent.com/penumbra-zone/web/main/apps/extension/public/um-token.svg"
"svg": ""
}

@@ -89,3 +89,3 @@ ]

{
"svg": "https://raw.githubusercontent.com/cosmos/chain-registry/master/axelar/images/usdc.svg"
"svg": ""
}

@@ -121,3 +121,3 @@ ]

{
"svg": "https://raw.githubusercontent.com/giuspen/cherrytree/356649a8f84cd5068d676185937d61fc8e0450d1/icons/ct_pizza.svg"
"svg": ""
}

@@ -148,3 +148,3 @@ ]

{
"png": "https://raw.githubusercontent.com/penumbra-zone/web/main/apps/minifront/public/favicon.png"
"png": ""
}

@@ -175,3 +175,3 @@ ]

{
"png": "https://raw.githubusercontent.com/penumbra-zone/web/main/apps/minifront/public/favicon.png"
"png": ""
}

@@ -187,18 +187,41 @@ ]

{
"denom": "transfer/channel-3/uosmo",
"denom": "transfer/channel-0/uosmo",
"exponent": 0
}
],
"base": "transfer/channel-3/uosmo",
"base": "transfer/channel-0/uosmo",
"display": "osmo",
"symbol": "OSMO",
"penumbraAssetId": {
"inner": "fLgjA/jT2EN7SFFeKUgZkL8UePmcz5qvNO/CyDBSwQE="
"inner": "jIowYEpoMr+LQYqjDVEnQO6hyzb9raVxbO1GLyDxlhI="
},
"images": [
{
"svg": "https://raw.githubusercontent.com/cosmos/chain-registry/master/osmosis/images/osmo.svg"
"svg": ""
}
]
},
{
"denomUnits": [
{
"denom": "usdc",
"exponent": 6
},
{
"denom": "transfer/channel-3/uusdc",
"exponent": 0
}
],
"base": "transfer/channel-3/uusdc",
"display": "usdc",
"symbol": "USDC",
"penumbraAssetId": {
"inner": "CKBQapu+DkQpsKyTfKESLTV19/NPWR5sNZtvQsd3Hw8="
},
"images": [
{
"svg": ""
}
]
}
]

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc