1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
use anchor_lang::prelude::*;
use errors::*;
use instructions::*;
use state::*;

pub mod errors;
pub mod instructions;
pub mod state;
pub mod utils;

declare_id!("SCERbrcgSPwgkrJ7j4TABr17dhYzdgiwPZUSSfFPt8x");

#[program]
pub mod sol_cerberus {
    use crate::utils::utc_now;

    use super::*;

    pub fn initialize_app(ctx: Context<InitializeApp>, app_data: AppData) -> Result<()> {
        instructions::initialize_app::initialize_app(ctx, app_data)
    }

    pub fn update_authority(ctx: Context<UpdateAuthority>, new_authority: Pubkey) -> Result<()> {
        instructions::update_authority::update_authority(ctx, new_authority)
    }

    pub fn add_rule(ctx: Context<AddRule>, rule_data: RuleData) -> Result<()> {
        instructions::add_rule::add_rule(ctx, rule_data)
    }

    pub fn delete_rule(ctx: Context<DeleteRule>) -> Result<()> {
        emit!(RulesChanged {
            time: utc_now(),
            app_id: ctx.accounts.app.id,
        });
        Ok(())
    }

    pub fn assign_role(ctx: Context<AssignRole>, assign_role_data: AssignRoleData) -> Result<()> {
        instructions::assign_role::assign_role(ctx, assign_role_data)
    }

    pub fn delete_assigned_role(ctx: Context<DeleteAssignedRole>) -> Result<()> {
        emit!(RolesChanged {
            time: utc_now(),
            app_id: ctx.accounts.app.id,
        });
        Ok(())
    }

    pub fn allowed(ctx: Context<Allowed>, allowed_params: AllowedRule) -> Result<()> {
        instructions::allowed::allowed(ctx, allowed_params)
    }
}