pub struct Project {
    pub bump: u8,
    pub authority: Pubkey,
    pub key: Pubkey,
    pub driver: Pubkey,
    pub name: String,
    pub mint_indexing: Indexing,
    pub services: Vec<Service>,
    pub collections: Vec<Pubkey>,
    pub creators: Vec<Pubkey>,
    pub profile_data_config: HashMap<String, ProfileDataType>,
    pub merkle_trees: Vec<Pubkey>,
    pub associated_programs: Vec<AssociatedProgram>,
}
Expand description

Project State Account This account represents the cenntralized state and confnigurations of an NFT project on the Honeycomb Protocol. PDA: [‘project’, key] Category: project_state

Fields§

§bump: u8

Bump value used for PDA.

§authority: Pubkey

Public key of the authority controlling this project.

§key: Pubkey

Unique public key identifier for this project account.

§driver: Pubkey

Public key of the driver wallet having partial authority of this project.

§name: String

Name of the project.

§mint_indexing: Indexing

Indexing information for the associated mints of the NFT Collection.

§services: Vec<Service>

List of honeycomb services associated with this project.

§collections: Vec<Pubkey>

List of nft collections (public keys) associated with this project.

§creators: Vec<Pubkey>

List of public keys representing the nft creators involved in this project.

§profile_data_config: HashMap<String, ProfileDataType>

Configuration for profile data stored as key-value pairs in a HashMap.

§merkle_trees: Vec<Pubkey>

List of public keys representing the nft creators involved in this project.

§associated_programs: Vec<AssociatedProgram>

Implementations§

source§

impl Project

source

pub fn validate_profile_data( &self, label: &String, profile_data: &ProfileData ) -> bool

Trait Implementations§

source§

impl AccountDeserialize for Project

source§

fn try_deserialize(buf: &mut &[u8]) -> Result<Self>

Deserializes previously initialized account data. Should fail for all uninitialized accounts, where the bytes are zeroed. Implementations should be unique to a particular account type so that one can never successfully deserialize the data of one account type into another. For example, if the SPL token program were to implement this trait, it should be impossible to deserialize a Mint account into a token Account.
source§

fn try_deserialize_unchecked(buf: &mut &[u8]) -> Result<Self>

Deserializes account data without checking the account discriminator. This should only be used on account initialization, when the bytes of the account are zeroed.
source§

impl AccountSerialize for Project

source§

fn try_serialize<W: Write>(&self, writer: &mut W) -> Result<()>

Serializes the account data into writer.
source§

impl BorshDeserialize for Project
where u8: BorshDeserialize, Pubkey: BorshDeserialize, String: BorshDeserialize, Indexing: BorshDeserialize, Vec<Service>: BorshDeserialize, Vec<Pubkey>: BorshDeserialize, HashMap<String, ProfileDataType>: BorshDeserialize, Vec<AssociatedProgram>: BorshDeserialize,

source§

fn deserialize_reader<R: Read>(reader: &mut R) -> Result<Self, Error>

§

fn deserialize(buf: &mut &[u8]) -> Result<Self, Error>

Deserializes this instance from a given slice of bytes. Updates the buffer to point at the remaining bytes.
§

fn try_from_slice(v: &[u8]) -> Result<Self, Error>

Deserialize this instance from a slice of bytes.
§

fn try_from_reader<R>(reader: &mut R) -> Result<Self, Error>
where R: Read,

source§

impl BorshSerialize for Project
where u8: BorshSerialize, Pubkey: BorshSerialize, String: BorshSerialize, Indexing: BorshSerialize, Vec<Service>: BorshSerialize, Vec<Pubkey>: BorshSerialize, HashMap<String, ProfileDataType>: BorshSerialize, Vec<AssociatedProgram>: BorshSerialize,

source§

fn serialize<W: Write>(&self, writer: &mut W) -> Result<(), Error>

§

fn try_to_vec(&self) -> Result<Vec<u8>, Error>

Serialize this instance into a vector of bytes.
source§

impl Clone for Project

source§

fn clone(&self) -> Project

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Project

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Project

Default implementation for the Project struct. It sets default values for each field when creating a new Project instance.

source§

fn set_defaults(&mut self)

Sets default values for each field of the Project struct.

source§

const LEN: usize = 264usize

source§

impl Discriminator for Project

source§

impl Owner for Project

source§

fn owner() -> Pubkey

source§

impl PartialEq for Project

source§

fn eq(&self, other: &Project) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for Project

source§

impl StructuralEq for Project

source§

impl StructuralPartialEq for Project

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V