Skip to content

Commit

Permalink
fix: add starkid improvements (#1301)
Browse files Browse the repository at this point in the history
* fix: add starkid improvements

* fix: test
  • Loading branch information
fricoben authored Jan 29, 2025
1 parent 8fb2193 commit 51702db
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 1 deletion.
6 changes: 6 additions & 0 deletions __tests__/account.starknetId.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,12 @@ describe('deploy and test Wallet', () => {
expect(hexToDecimalString(address)).toEqual(hexToDecimalString(account.address));
});

test('Should throw error when invalid stark domain is provided', async () => {
await expect(account.getAddressFromStarkName('invalid_domain', namingAddress)).rejects.toThrow(
'Invalid domain, must be a valid .stark domain'
);
});

test('Get the account from a stark name of the account (using starknet.id)', async () => {
const name = await account.getStarkName(undefined, namingAddress);
expect(name).toEqual('fricoben.stark');
Expand Down
9 changes: 8 additions & 1 deletion src/provider/extensions/starknetId.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import {
getStarknetIdPfpContract,
getStarknetIdPopContract,
getStarknetIdVerifierContract,
isStarkDomain,
useDecoded,
useEncoded,
} from '../../utils/starknetId';
Expand Down Expand Up @@ -97,11 +98,17 @@ export class StarknetId {
name: string,
StarknetIdContract?: string
): Promise<string> {
const starkName = name.endsWith('.stark') ? name : `${name}.stark`;

if (!isStarkDomain(starkName)) {
throw new Error('Invalid domain, must be a valid .stark domain');
}

const chainId = await provider.getChainId();
const contract = StarknetIdContract ?? getStarknetIdContract(chainId);

try {
const encodedDomain = name
const encodedDomain = starkName
.replace('.stark', '')
.split('.')
.map((part) => useEncoded(part).toString(10));
Expand Down
18 changes: 18 additions & 0 deletions src/utils/starknetId.ts
Original file line number Diff line number Diff line change
Expand Up @@ -393,3 +393,21 @@ export function dynamicCallData(
ArrayReference: arrayReference ? tuple(arrayReference[0], arrayReference[1]) : undefined,
});
}

/**
* Check if a given string is a valid Starknet.id domain.
*
* @param {string} domain - The domain string to validate.
* @returns {boolean} - True if the domain is a valid Starknet.id domain, false otherwise.
* @example
* ```typescript
* const result = starknetId.isStarkDomain("example.stark");
* // result = true
*
* const result2 = starknetId.isStarkDomain("invalid-domain");
* // result2 = false
* ```
*/
export function isStarkDomain(domain: string): boolean {
return /^(?:[a-z0-9-]{1,48}(?:[a-z0-9-]{1,48}[a-z0-9-])?\.)*[a-z0-9-]{1,48}\.stark$/.test(domain);
}

0 comments on commit 51702db

Please sign in to comment.