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 allowed_programs: Vec<Pubkey>,
    pub profile_data_config: HashMap<String, ProfileDataType>,
}
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.

§allowed_programs: Vec<Pubkey>

List of allowed programs that can interact (CPI) with this project. If it’s emmpty only honeycomb programs will be able to perform CPI with this project.

§profile_data_config: HashMap<String, ProfileDataType>

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

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 Projectwhere u8: BorshDeserialize, Pubkey: BorshDeserialize, String: BorshDeserialize, Indexing: BorshDeserialize, Vec<Service>: BorshDeserialize, Vec<Pubkey>: BorshDeserialize, HashMap<String, ProfileDataType>: 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 Projectwhere u8: BorshSerialize, Pubkey: BorshSerialize, String: BorshSerialize, Indexing: BorshSerialize, Vec<Service>: BorshSerialize, Vec<Pubkey>: BorshSerialize, HashMap<String, ProfileDataType>: BorshSerialize,

source§

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

§

fn try_to_vec(&self) -> Result<Vec<u8, Global>, 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 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

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. 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 Twhere 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 = mem::align_of::<T>()

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<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere 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 Twhere 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 Twhere 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 Twhere V: MultiLane<T>,

§

fn vzip(self) -> V