forked from starknet-edu/starknet-cairo-101
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathex11.cairo
73 lines (69 loc) · 3.23 KB
/
ex11.cairo
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
////////////////////////////////
// Exercise 11
// Importing functions
////////////////////////////////
// - TODO (Omar): Add a description of the exercise
// - Read this contract and understand how it imports functions from another contract
// - Find the relevant contract it imports from
// - Read the code and understand what is expected of you
////////////////////////////////
#[contract]
mod Ex11 {
////////////////////////////////
// Core Library imports
// These are syscalls and functionalities that allow you to write Starknet contracts
////////////////////////////////
use starknet::get_caller_address;
use starknet::ContractAddress;
////////////////////////////////
// Internal imports
// These function become part of the set of function of the current contract
////////////////////////////////
use starknet_cairo_101::utils::ex11_base::Ex11Base::distribute_points;
use starknet_cairo_101::utils::ex11_base::Ex11Base::validate_exercise;
use starknet_cairo_101::utils::ex11_base::Ex11Base::ex_initializer;
use starknet_cairo_101::utils::ex11_base::Ex11Base::validate_answers;
use starknet_cairo_101::utils::ex11_base::Ex11Base::secret_value_internal;
use starknet_cairo_101::utils::ex00_base::Ex00Base::update_class_hash_by_admin;
////////////////////////////////
// View Functions
// Public variables should be declared explicitly with a getter function (indicated with #[view]) to be visible through the ABI and callable from other contracts
////////////////////////////////
#[view]
fn secret_value() -> u128 {
return secret_value_internal();
}
////////////////////////////////
// Constructor
// This function (indicated with #[constructor]) is called when the contract is deployed and is used to initialize the contract's state
////////////////////////////////
#[constructor]
fn constructor(
_tderc20_address: ContractAddress, _players_registry: ContractAddress, _workshop_id: u128, _exercise_id: u128
) {
ex_initializer(_tderc20_address, _players_registry, _workshop_id, _exercise_id);
}
////////////////////////////////
// External functions
// These functions are callable by other contracts or external calls such as DAPP, which are indicated with #[external] (similar to "public" in Solidity)
////////////////////////////////
#[external]
fn claim_points(secret_value_i_guess: u128, next_secret_value_i_chose: u128) {
// Reading caller address
let sender_address: ContractAddress = get_caller_address();
// Check if your answer is correct
validate_answers(sender_address, secret_value_i_guess, next_secret_value_i_chose);
// Checking if the user has validated the exercise before
validate_exercise(sender_address);
// Sending points to the address specified as parameter
distribute_points(sender_address, 2_u128);
}
////////////////////////////////
// External functions - Administration
// Only admins can call these. You don't need to understand them to finish the exercise.
////////////////////////////////
#[external]
fn update_class_hash(class_hash: felt252) {
update_class_hash_by_admin(class_hash);
}
}