1 | #! perl |
1 | #! perl |
2 | |
2 | |
3 | use List::Util; |
3 | use List::Util; |
4 | |
4 | |
5 | my %apartment = ( |
5 | our %apartment = ( |
6 | "/scorn/apartment/apartments" => [ 1, "scorn", "skorn"], |
6 | "/scorn/apartment/apartments" => [ 1, "scorn", "skorn"], |
7 | "/santo_dominion/sdomino_appartment" => [ 10, "santo dominion", "domino"], |
7 | "/santo_dominion/sdomino_appartment" => [ 10, "santo dominion", "domino"], |
8 | "/darcap/darcap/apartment" => [ 30, "darcap", "thecap"], |
8 | "/darcap/darcap/apartment" => [ 30, "darcap", "thecap"], |
|
|
9 | "/gotischerbereich/steinwandstadt/sapartment1" => [ 100, "steinwandstadt", "konkret"], |
9 | "/navar_city/apartments/apartment" => [ 250, "navar", "navar"], |
10 | "/navar_city/apartments/apartment" => [ 250, "navar", "navar"], |
|
|
11 | "/celvear_port/tower2/tower2" => [ 300, "celvear port", "kevlar"], |
10 | "/azumauindo/ranbounagisatoshi/apartments/sapartment" => [ 100, "乱暴渚都市", "benjo"], |
12 | "/azumauindo/ranbounagisatoshi/apartments/sapartment" => [ 100, "乱暴渚都市", "benjo"], |
11 | "/azumauindo/suno-yamatoshi/apartments/lapartment1" => [ 1000, "スノー大和島根", "sama"], |
13 | "/azumauindo/suno-yamatoshi/apartments/lapartment1" => [ 1000, "スノー大和島根", "sama"], |
|
|
14 | "/elmex/jeweler/jeweler_inn_upper" => [ 500, "jeweler town", "jewelor"], |
12 | "/pup_land/nurnberg/apartment/main" => [ 300, "nürnberg", "sauerkraut"], |
15 | "/pup_land/nurnberg/apartment/main" => [ 300, "nürnberg", "sauerkraut"], |
|
|
16 | "/lostwages/petapartment" => [ 5000, "lostwages", "losvegas"], |
|
|
17 | "/gotischerbereich/towerapartment/tower1" => [10000, "gotisch", "retreat"], |
|
|
18 | "/lake_country/Butakis/apartment" => [25000, "castle butakis", "expandor"], |
|
|
19 | "/brest/apartments/brest_town_house" => [30000, "brest", "brecht"], |
13 | "/pup_land/lone_town/apartment/groundfloor" => [50000, "lone town", "looney"], |
20 | "/pup_land/lone_town/apartment/groundfloor" => [50000, "lone town", "looney"], |
14 | "/brest/apartments/brest_town_house" => [30000, "brest", "brecht"], |
|
|
15 | ); |
21 | ); |
16 | |
22 | |
17 | # we have to special case some special cases :) |
23 | # we have to special case some special cases :) |
18 | sub reject_entry { |
24 | sub reject_entry { |
19 | my ($pl) = @_; |
25 | my ($pl) = @_; |
20 | |
26 | |
|
|
27 | my $prev_pos = $pl->ob->{_prev_pos}; |
|
|
28 | $pl->ob->goto ($prev_pos ? @$prev_pos : ("/world/world_105_115", 2, 34)); |
|
|
29 | |
21 | cf::override; |
30 | cf::override; |
22 | |
|
|
23 | $pl->goto ("/world/world_105_115", 2, 34) |
|
|
24 | unless |
|
|
25 | $pl->ob->map |
|
|
26 | && !$pl->ob->map->{path}{user_rel}; |
|
|
27 | } |
31 | } |
28 | |
32 | |
29 | sub update_balance { |
33 | sub update_balance { |
30 | my ($pl) = @_; |
34 | my ($pl) = @_; |
31 | |
35 | |
… | |
… | |
47 | } |
51 | } |
48 | |
52 | |
49 | sub pay_balance { |
53 | sub pay_balance { |
50 | my ($pl) = @_; |
54 | my ($pl) = @_; |
51 | |
55 | |
|
|
56 | cf::cede_to_tick; |
|
|
57 | |
52 | update_balance $pl; |
58 | update_balance $pl; |
53 | |
59 | |
54 | return unless $pl->{rent}{balance} > 0; |
60 | return unless $pl->{rent}{balance} > 0; |
55 | |
61 | |
56 | my $deduct = cf::ceil $pl->{rent}{balance}; |
62 | my $deduct = cf::ceil $pl->{rent}{balance}; |
… | |
… | |
59 | |
65 | |
60 | if ($deduct <= $pl->ob->{bank_balance}) { |
66 | if ($deduct <= $pl->ob->{bank_balance}) { |
61 | cf::db_put rent => balance => $deduct + cf::db_get rent => "balance"; |
67 | cf::db_put rent => balance => $deduct + cf::db_get rent => "balance"; |
62 | $pl->ob->{bank_balance} -= $deduct; |
68 | $pl->ob->{bank_balance} -= $deduct; |
63 | $pl->{rent}{balance} -= $deduct; |
69 | $pl->{rent}{balance} -= $deduct; |
64 | $pl->ob->reply (undef, "Something whispers into your ear:\n" |
70 | $pl->ob->reply (undef, "Something whispers into your ear: " |
65 | . "Sir, we deducted your apartment rent ($deduct_string) from your bank account."); |
71 | . "Your highness, we deducted your apartment rent ($deduct_string) from your bank account."); |
66 | } else { |
72 | } else { |
67 | $pl->ob->reply (undef, "Something whispers into your ear:\n" |
73 | $pl->ob->reply (undef, "Something whispers into your ear: " |
68 | . "Sir, we want to deduct the apartment rent ($deduct_string), but the bank informed us that they cannot perform the transaction. " |
74 | . "Your highness, we want to deduct the apartment rent ($deduct_string), but the bank informed us that they cannot perform the transaction. " |
69 | . "Please even out your balance so we can deduct the fees, otherwise we will be forced to shut down your access to the apartment."); |
75 | . "Please even out your balance so we can deduct the fees, otherwise we will be forced to shut down your access to the apartment."); |
70 | } |
76 | } |
71 | } |
77 | } |
72 | |
78 | |
73 | sub check_balance { |
79 | sub check_balance { |
… | |
… | |
91 | my ($pl, $types) = @_; |
97 | my ($pl, $types) = @_; |
92 | |
98 | |
93 | while (my ($k, $v) = each %apartment) { |
99 | while (my ($k, $v) = each %apartment) { |
94 | my $type = exists $pl->{rent}{apartment}{$k} ? 1 : 2; |
100 | my $type = exists $pl->{rent}{apartment}{$k} ? 1 : 2; |
95 | |
101 | |
96 | $pl->ob->reply (undef, "model \"$v->[2]\", situated in $v->[1] (" |
102 | $pl->ob->reply (undef, "model \"$v->[2]\", located in $v->[1] (" |
97 | . (cf::cost_string_from_value $v->[0]) . "/hr)") |
103 | . (cf::cost_string_from_value $v->[0]) . "/hr)\n") |
98 | if $type & $types; |
104 | if $type & $types; |
99 | } |
105 | } |
100 | }; |
106 | }; |
101 | |
107 | |
102 | cf::register_script_function "rent::status" => sub { |
108 | cf::register_script_function "rent::status" => sub { |
… | |
… | |
117 | |
123 | |
118 | update_balance $pl; |
124 | update_balance $pl; |
119 | |
125 | |
120 | $pl->{rent}{apartment}{$apartment} = undef; |
126 | $pl->{rent}{apartment}{$apartment} = undef; |
121 | |
127 | |
122 | $pl->ob->reply (undef, "Wonderful decision, sir! " |
128 | $pl->ob->reply (undef, "Wonderful decision, your highness! " |
123 | . "We told the proprietor in $apartment{$apartment}[1] to expect you and let you in. " |
129 | . "We told the proprietor in $apartment{$apartment}[1] to expect you and let you in. " |
124 | . "We are sure you will be satisfied!"); |
130 | . "We are sure you will be satisfied!"); |
125 | }; |
131 | }; |
126 | |
132 | |
127 | cf::register_script_function "rent::stop" => sub { |
133 | cf::register_script_function "rent::stop" => sub { |
… | |
… | |
145 | $pl->{rent}{last_offline_check} ||= time; |
151 | $pl->{rent}{last_offline_check} ||= time; |
146 | |
152 | |
147 | if ($pl->{rent}{last_online_check}) { |
153 | if ($pl->{rent}{last_online_check}) { |
148 | $pl->{rent}{last_online_check} = time |
154 | $pl->{rent}{last_online_check} = time |
149 | - List::Util::min 3600, |
155 | - List::Util::min 3600, |
150 | $pl->ob->get_ob_key_value ("schmorplog_last_save") - $pl->{rent}{last_online_check}; |
156 | $pl->ob->kv_get ("schmorplog_last_save") - $pl->{rent}{last_online_check}; |
151 | } else { |
157 | } else { |
152 | $pl->{rent}{last_online_check} = time; |
158 | $pl->{rent}{last_online_check} = time; |
153 | } |
159 | } |
154 | |
160 | |
155 | update_balance $pl; |
161 | update_balance $pl; |
… | |
… | |
158 | |
164 | |
159 | cf::map::attachment rent => |
165 | cf::map::attachment rent => |
160 | on_enter => sub { |
166 | on_enter => sub { |
161 | my ($map, $pl, $x, $y) = @_; |
167 | my ($map, $pl, $x, $y) = @_; |
162 | |
168 | |
163 | # can freely enter homes of other people |
169 | return if $pl->ob->flag (cf::FLAG_WIZ); |
164 | { |
|
|
165 | my $path = sprintf "%s/%s/%s/", |
|
|
166 | cf::localdir, cf::playerdir, $pl->ob->name; |
|
|
167 | |
170 | |
|
|
171 | my $pfx = sprintf "~%s/", $pl->ob->name; |
|
|
172 | |
|
|
173 | # only do something if entering ones own apartment |
168 | return if $path ne substr $map->path, 0, length $path; |
174 | if ($pfx eq substr $map->path, 0, length $pfx) { |
|
|
175 | for my $path (keys %{ $pl->{rent}{apartment} }) { |
|
|
176 | $path = sprintf "~%s%s", $pl->ob->name, $path; |
|
|
177 | |
|
|
178 | if ($map->path eq $path) { |
|
|
179 | if (check_balance $pl) { |
|
|
180 | $pl->ob->reply (undef, "Welcome to your apartment, your highness!"); |
|
|
181 | } else { |
|
|
182 | $pl->ob->reply (undef, "We are sorry, your highness, you have to pay your rent first."); |
|
|
183 | reject_entry $pl; |
|
|
184 | } |
|
|
185 | |
|
|
186 | return; |
|
|
187 | } |
|
|
188 | } |
|
|
189 | |
|
|
190 | $pl->ob->reply (undef, "Your highness, you have to rent this apartment in The Apartment Shop in Scorn or other apartment shops first!"); |
|
|
191 | reject_entry $pl; |
169 | } |
192 | } |
170 | |
|
|
171 | for my $path (keys %{ $pl->{rent}{apartment} }) { |
|
|
172 | $path =~ y/\//_/; |
|
|
173 | $path = sprintf "%s/%s/%s/%s", |
|
|
174 | cf::localdir, cf::playerdir, $pl->ob->name, $path; |
|
|
175 | |
|
|
176 | if ($map->path eq $path) { |
|
|
177 | if (check_balance $pl) { |
|
|
178 | $pl->ob->reply (undef, "Welcome to your apartment, sir!"); |
|
|
179 | } else { |
|
|
180 | $pl->ob->reply (undef, "We are sorry, sir, you have to pay your rent first."); |
|
|
181 | reject_entry $pl; |
|
|
182 | } |
|
|
183 | |
|
|
184 | return; |
|
|
185 | } |
|
|
186 | } |
|
|
187 | |
|
|
188 | $pl->ob->reply (undef, "Sir, you have to rent this apartment in The Apartment Shop in Scorn first!"); |
|
|
189 | reject_entry $pl; |
|
|
190 | }, |
193 | }, |
191 | ; |
194 | ; |
192 | |
195 | |
193 | our $RENT_TIMER = Event->timer (after => 60, interval => 3600, data => cf::WF_AUTOCANCEL, cb => sub { |
196 | our $RENT_TIMER = cf::periodic 3600, Coro::unblock_sub { |
194 | pay_balance $_ for cf::player::list; |
197 | pay_balance $_ for cf::player::list; |
195 | }); |
198 | }; |
196 | |
199 | |