123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- import { Filter, FilterResult } from './pool-filters';
- import { Connection } from '@solana/web3.js';
- import { LiquidityPoolKeysV4 } from '@raydium-io/raydium-sdk';
- import { getPdaMetadataKey } from '@raydium-io/raydium-sdk';
- import { MetadataAccountData, MetadataAccountDataArgs } from '@metaplex-foundation/mpl-token-metadata';
- import { Serializer } from '@metaplex-foundation/umi/serializers';
- import { logger } from '../helpers';
- export class MutableFilter implements Filter {
- private readonly errorMessage: string[] = [];
- constructor(
- private readonly connection: Connection,
- private readonly metadataSerializer: Serializer<MetadataAccountDataArgs, MetadataAccountData>,
- private readonly checkMutable: boolean,
- private readonly checkSocials: boolean,
- ) {
- if (this.checkMutable) {
- this.errorMessage.push('mutable');
- }
- if (this.checkSocials) {
- this.errorMessage.push('socials');
- }
- }
- async execute(poolKeys: LiquidityPoolKeysV4): Promise<FilterResult> {
- try {
- const metadataPDA = getPdaMetadataKey(poolKeys.baseMint);
- const metadataAccount = await this.connection.getAccountInfo(metadataPDA.publicKey, this.connection.commitment);
- if (!metadataAccount?.data) {
- return { ok: false, message: 'Mutable -> Failed to fetch account data' };
- }
- const deserialize = this.metadataSerializer.deserialize(metadataAccount.data);
- const mutable = !this.checkMutable || deserialize[0].isMutable;
- const hasSocials = !this.checkSocials || (await this.hasSocials(deserialize[0]));
- const ok = !mutable && hasSocials;
- const message: string[] = [];
- if (mutable) {
- message.push('metadata can be changed');
- }
- if (!hasSocials) {
- message.push('has no socials');
- }
- return { ok: ok, message: ok ? undefined : `MutableSocials -> Token ${message.join(' and ')}` };
- } catch (e) {
- logger.error({ mint: poolKeys.baseMint }, `MutableSocials -> Failed to check ${this.errorMessage.join(' and ')}`);
- }
- return {
- ok: false,
- message: `MutableSocials -> Failed to check ${this.errorMessage.join(' and ')}`,
- };
- }
- private async hasSocials(metadata: MetadataAccountData) {
- const response = await fetch(metadata.uri);
- const data = await response.json();
- return Object.values(data?.extensions ?? {}).some((value: any) => value !== null && value.length > 0);
- }
- }
|