sns-wasm 0.1.1

Client-side SDK for interacting with Solana Name Service Program.
Documentation
//! Build instruction to create new SNS domain.

use solana_instruction::Instruction;
use solana_program_error::ProgramError;
use solana_pubkey::Pubkey;

use super::CreateInstBuilder;
use crate::{TLDomain, derive_domain};

/// Builds instruction to register domain.
#[derive(Debug)]
pub struct CreateDomainInstBuilder {
    payer: Pubkey,
    tld: TLDomain,
    owner: Option<Pubkey>,
    class: Option<Pubkey>,
    name: String,
    space: Option<u32>,
}

impl CreateDomainInstBuilder {
    /// Returns new builder for given payer, parent SNS record and user defined name.
    ///
    /// - Reserves no extra space for user data, like URLs and social media handles. See
    ///   [`space`](Self::space)
    /// - Unless [`owner`](Self::owner) explicitly set defaults to payer
    /// - Unless [`class``](Self::class) explicitly set defaults to System Program (null address),
    pub fn new(payer: Pubkey, tld: TLDomain, name: String) -> Self {
        Self { payer, tld, owner: None, class: None, name, space: None }
    }

    /// Sets owner to register for SNS record.
    pub fn owner(mut self, owner: Option<Pubkey>) -> Self {
        self.owner = owner;
        self
    }

    /// Sets class to derive SNS record address from.
    pub fn class(mut self, class: Option<Pubkey>) -> Self {
        self.class = class;
        self
    }

    /// Sets additional blockchain space to allocate for SNS record other than minimum reserved for
    /// [`SNS_RECORD_HEADER_BYTE_LEN`].
    ///
    /// Registering domains at <https://v1.sns.id> allocates 10 KB extra.
    pub fn space(mut self, space: Option<u32>) -> Self {
        self.space = space;
        self
    }

    /// Builds instruction to input into transaction to create new SNS domain.
    pub fn build(self) -> Result<Instruction, ProgramError> {
        let Self { payer, tld: parent, owner, class, name, space } = self;

        // derive domain PDA
        let account = derive_domain(&parent.pda, class.as_ref(), &name);

        let builder =
            CreateInstBuilder { payer, account, parent: parent.into(), owner, class, space };
        builder.build()
    }
}