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)
}
}