line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package WG::API::WoT; |
2
|
|
|
|
|
|
|
|
3
|
2
|
|
|
2
|
|
387
|
use Const::Fast; |
|
2
|
|
|
|
|
874
|
|
|
2
|
|
|
|
|
12
|
|
4
|
|
|
|
|
|
|
|
5
|
2
|
|
|
2
|
|
116
|
use Moo; |
|
2
|
|
|
|
|
4
|
|
|
2
|
|
|
|
|
10
|
|
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
with 'WG::API::Base'; |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
=head1 NAME |
10
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
WG::API::WoT - Module to work with Wargaming.net Public API for World of Tanks |
12
|
|
|
|
|
|
|
|
13
|
|
|
|
|
|
|
=head1 VERSION |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
Version v0.12 |
16
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
=cut |
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
our $VERSION = 'v0.12'; |
20
|
|
|
|
|
|
|
|
21
|
|
|
|
|
|
|
const my $api_uri => '//api.worldoftanks.ru/'; |
22
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
sub _api_uri { |
24
|
1
|
|
|
1
|
|
2
|
my ($self) = @_; |
25
|
|
|
|
|
|
|
|
26
|
1
|
|
|
|
|
9
|
return $api_uri; |
27
|
|
|
|
|
|
|
} |
28
|
|
|
|
|
|
|
|
29
|
|
|
|
|
|
|
=head1 SYNOPSIS |
30
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
Wargaming.net Public API is a set of API methods that provide access to Wargaming.net content, including in-game and game-related content, as well as player statistics. |
32
|
|
|
|
|
|
|
|
33
|
|
|
|
|
|
|
This module provide access to WG Public API |
34
|
|
|
|
|
|
|
|
35
|
|
|
|
|
|
|
use WG::API; |
36
|
|
|
|
|
|
|
|
37
|
|
|
|
|
|
|
my $wot = WG::API->new( application_id => 'demo' )->wot(); |
38
|
|
|
|
|
|
|
... |
39
|
|
|
|
|
|
|
my $player = $wot->account_info( account_id => '1' ); |
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
|
43
|
|
|
|
|
|
|
=head1 CONSTRUCTOR |
44
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
=head2 new |
46
|
|
|
|
|
|
|
|
47
|
|
|
|
|
|
|
Create new object with params. Rerquired application id: L<https://developers.wargaming.net/documentation/guide/getting-started/> |
48
|
|
|
|
|
|
|
|
49
|
|
|
|
|
|
|
Params: |
50
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
- application_id * |
52
|
|
|
|
|
|
|
- languare |
53
|
|
|
|
|
|
|
- api_uri |
54
|
|
|
|
|
|
|
|
55
|
|
|
|
|
|
|
=head1 METHODS |
56
|
|
|
|
|
|
|
|
57
|
|
|
|
|
|
|
=head2 Account |
58
|
|
|
|
|
|
|
|
59
|
|
|
|
|
|
|
=over 1 |
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
=item B<account_list( [ %params ] )> |
62
|
|
|
|
|
|
|
|
63
|
|
|
|
|
|
|
Method returns partial list of players. The list is filtered by initial characters of user name and sorted alphabetically |
64
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
=over 2 |
66
|
|
|
|
|
|
|
|
67
|
|
|
|
|
|
|
=item I<required fields:> |
68
|
|
|
|
|
|
|
|
69
|
|
|
|
|
|
|
search - Player name search string. Parameter "type" defines minimum length and type of search. Using the exact search type, you can enter several names, separated with commas. Maximum length: 24. |
70
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
=back |
72
|
|
|
|
|
|
|
|
73
|
|
|
|
|
|
|
=cut |
74
|
|
|
|
|
|
|
|
75
|
|
|
|
|
|
|
sub account_list { |
76
|
|
|
|
|
|
|
return shift->_request( |
77
|
0
|
|
|
0
|
1
|
0
|
'get', 'wot/account/list/', [ 'language', 'fields', 'type', 'search', 'limit' ], ['search'], |
78
|
|
|
|
|
|
|
@_ |
79
|
|
|
|
|
|
|
); |
80
|
|
|
|
|
|
|
} |
81
|
|
|
|
|
|
|
|
82
|
|
|
|
|
|
|
=item B<account_info( [ %params ] )> |
83
|
|
|
|
|
|
|
|
84
|
|
|
|
|
|
|
Method returns player details. |
85
|
|
|
|
|
|
|
|
86
|
|
|
|
|
|
|
=over 2 |
87
|
|
|
|
|
|
|
|
88
|
|
|
|
|
|
|
=item I<required fields:> |
89
|
|
|
|
|
|
|
|
90
|
|
|
|
|
|
|
account_id - Account ID. Max limit is 100. Min value is 1. |
91
|
|
|
|
|
|
|
|
92
|
|
|
|
|
|
|
=back |
93
|
|
|
|
|
|
|
|
94
|
|
|
|
|
|
|
=cut |
95
|
|
|
|
|
|
|
|
96
|
|
|
|
|
|
|
sub account_info { |
97
|
|
|
|
|
|
|
return shift->_request( |
98
|
1
|
|
|
1
|
1
|
29725
|
'get', 'wot/account/info/', [ 'language', 'fields', 'access_token', 'extra', 'account_id' ], |
99
|
|
|
|
|
|
|
['account_id'], @_ |
100
|
|
|
|
|
|
|
); |
101
|
|
|
|
|
|
|
} |
102
|
|
|
|
|
|
|
|
103
|
|
|
|
|
|
|
=item B<account_tanks( [ %params ] )> |
104
|
|
|
|
|
|
|
|
105
|
|
|
|
|
|
|
Method returns details on player's vehicles. |
106
|
|
|
|
|
|
|
|
107
|
|
|
|
|
|
|
=over 2 |
108
|
|
|
|
|
|
|
|
109
|
|
|
|
|
|
|
=item I<required fields:> |
110
|
|
|
|
|
|
|
|
111
|
|
|
|
|
|
|
account_id - Account ID. Max limit is 100. Min value is 1. |
112
|
|
|
|
|
|
|
|
113
|
|
|
|
|
|
|
=back |
114
|
|
|
|
|
|
|
|
115
|
|
|
|
|
|
|
=cut |
116
|
|
|
|
|
|
|
|
117
|
|
|
|
|
|
|
sub account_tanks { |
118
|
|
|
|
|
|
|
return shift->_request( |
119
|
0
|
|
|
0
|
1
|
|
'get', 'wot/account/tanks/', [ 'language', 'fields', 'access_token', 'account_id', 'tank_id' ], |
120
|
|
|
|
|
|
|
['account_id'], @_ |
121
|
|
|
|
|
|
|
); |
122
|
|
|
|
|
|
|
} |
123
|
|
|
|
|
|
|
|
124
|
|
|
|
|
|
|
=item B<account_achievements( [ %params ] )> |
125
|
|
|
|
|
|
|
|
126
|
|
|
|
|
|
|
Method returns players' achievement details. |
127
|
|
|
|
|
|
|
|
128
|
|
|
|
|
|
|
Achievement properties define the achievements field values: |
129
|
|
|
|
|
|
|
|
130
|
|
|
|
|
|
|
1-4 for Mastery Badges and Stage Achievements (type: "class"); |
131
|
|
|
|
|
|
|
maximum value of Achievement series (type: "series"); |
132
|
|
|
|
|
|
|
number of achievements earned from sections: Battle Hero, Epic Achievements, Group Achievements, Special Achievements, etc. (type: "repeatable, single, custom"). |
133
|
|
|
|
|
|
|
|
134
|
|
|
|
|
|
|
=over 2 |
135
|
|
|
|
|
|
|
|
136
|
|
|
|
|
|
|
=item I<required fields:> |
137
|
|
|
|
|
|
|
|
138
|
|
|
|
|
|
|
account_id - Account ID. Max limit is 100. Min value is 1. |
139
|
|
|
|
|
|
|
|
140
|
|
|
|
|
|
|
=back |
141
|
|
|
|
|
|
|
|
142
|
|
|
|
|
|
|
=cut |
143
|
|
|
|
|
|
|
|
144
|
|
|
|
|
|
|
sub account_achievements { |
145
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/account/achievements/', [ 'language', 'fields', 'account_id' ], ['account_id'], @_ ); |
146
|
|
|
|
|
|
|
} |
147
|
|
|
|
|
|
|
|
148
|
|
|
|
|
|
|
=item B<stronghold_claninfo( [ %params ] )> |
149
|
|
|
|
|
|
|
|
150
|
|
|
|
|
|
|
Method returns general information and the battle statistics of clans in the Stronghold mode. Please note that information about the number of battles fought as well as the number of defeats and victories is updated once every 24 hours. |
151
|
|
|
|
|
|
|
|
152
|
|
|
|
|
|
|
=over 2 |
153
|
|
|
|
|
|
|
|
154
|
|
|
|
|
|
|
=item I<required_fields:> |
155
|
|
|
|
|
|
|
|
156
|
|
|
|
|
|
|
clan_id - Clan IDs. Maximum limit: 100 |
157
|
|
|
|
|
|
|
|
158
|
|
|
|
|
|
|
=back |
159
|
|
|
|
|
|
|
|
160
|
|
|
|
|
|
|
=cut |
161
|
|
|
|
|
|
|
|
162
|
|
|
|
|
|
|
sub stronghold_claninfo { |
163
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/stronghold/claninfo/', [ 'clan_id', 'fields', 'language' ], ['clan_id'], @_ ); |
164
|
|
|
|
|
|
|
} |
165
|
|
|
|
|
|
|
|
166
|
|
|
|
|
|
|
=item B<stronghold_clanreserves( [ %params ] )> |
167
|
|
|
|
|
|
|
|
168
|
|
|
|
|
|
|
Method returns information about available Reserves and their current status. |
169
|
|
|
|
|
|
|
|
170
|
|
|
|
|
|
|
=over 2 |
171
|
|
|
|
|
|
|
|
172
|
|
|
|
|
|
|
=item I<required_fields:> |
173
|
|
|
|
|
|
|
|
174
|
|
|
|
|
|
|
access_token - Access token for the private data of a user's account; can be received via the authorization method; valid within a stated time period |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
=back |
177
|
|
|
|
|
|
|
|
178
|
|
|
|
|
|
|
=back |
179
|
|
|
|
|
|
|
|
180
|
|
|
|
|
|
|
=cut |
181
|
|
|
|
|
|
|
|
182
|
|
|
|
|
|
|
sub stronghold_clanreserves { |
183
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/stronghold/clanreserves/', [ 'access_token', 'fields', 'language' ], ['access_token'], @_ ); |
184
|
|
|
|
|
|
|
} |
185
|
|
|
|
|
|
|
|
186
|
|
|
|
|
|
|
=head2 Encyclopedia |
187
|
|
|
|
|
|
|
|
188
|
|
|
|
|
|
|
=over 1 |
189
|
|
|
|
|
|
|
|
190
|
|
|
|
|
|
|
=item B<encyclopedia_vehicles( [ %params ] )> |
191
|
|
|
|
|
|
|
|
192
|
|
|
|
|
|
|
Method returns list of available vehicles. |
193
|
|
|
|
|
|
|
|
194
|
|
|
|
|
|
|
=cut |
195
|
|
|
|
|
|
|
|
196
|
|
|
|
|
|
|
sub encyclopedia_vehicles { |
197
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/vehicles/', [ 'fields', 'language', 'limit', 'nation', 'page_no', 'tank_id', 'tier', 'type' ], undef, @_ ); |
198
|
|
|
|
|
|
|
} |
199
|
|
|
|
|
|
|
|
200
|
|
|
|
|
|
|
=item B<encyclopedia_vehicleprofile( [ %params ] )> |
201
|
|
|
|
|
|
|
|
202
|
|
|
|
|
|
|
=over 2 |
203
|
|
|
|
|
|
|
|
204
|
|
|
|
|
|
|
=item I<required fields> |
205
|
|
|
|
|
|
|
|
206
|
|
|
|
|
|
|
tank_id - vehicle id |
207
|
|
|
|
|
|
|
|
208
|
|
|
|
|
|
|
=back |
209
|
|
|
|
|
|
|
|
210
|
|
|
|
|
|
|
=cut |
211
|
|
|
|
|
|
|
|
212
|
|
|
|
|
|
|
sub encyclopedia_vehicleprofile { |
213
|
|
|
|
|
|
|
return shift->_request( |
214
|
0
|
|
|
0
|
1
|
|
'get', 'wot/encyclopedia/vehicleprofile/', |
215
|
|
|
|
|
|
|
[ 'tank_id', 'engine_id', 'fields', 'gun_id', 'language', 'profile_id', 'radio_id', 'suspension_id', 'turret_id' ], |
216
|
|
|
|
|
|
|
['tank_id'], |
217
|
|
|
|
|
|
|
@_ |
218
|
|
|
|
|
|
|
); |
219
|
|
|
|
|
|
|
} |
220
|
|
|
|
|
|
|
|
221
|
|
|
|
|
|
|
=item B<encyclopedia_achievements( [ %params ] )> |
222
|
|
|
|
|
|
|
|
223
|
|
|
|
|
|
|
Method returns information about achievements. |
224
|
|
|
|
|
|
|
|
225
|
|
|
|
|
|
|
=cut |
226
|
|
|
|
|
|
|
|
227
|
|
|
|
|
|
|
sub encyclopedia_achievements { |
228
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/achievements/', [ 'fields', 'language' ], undef, @_ ); |
229
|
|
|
|
|
|
|
} |
230
|
|
|
|
|
|
|
|
231
|
|
|
|
|
|
|
=item B<encyclopedia_info( [ %params ] )> |
232
|
|
|
|
|
|
|
|
233
|
|
|
|
|
|
|
Method returns information about Tankopedia. |
234
|
|
|
|
|
|
|
|
235
|
|
|
|
|
|
|
=cut |
236
|
|
|
|
|
|
|
|
237
|
|
|
|
|
|
|
sub encyclopedia_info { |
238
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/info/', [ 'fields', 'language' ], undef, @_ ); |
239
|
|
|
|
|
|
|
} |
240
|
|
|
|
|
|
|
|
241
|
|
|
|
|
|
|
=item B<encyclopedia_arenas( [ %params ] )> |
242
|
|
|
|
|
|
|
|
243
|
|
|
|
|
|
|
Method returns information about maps. |
244
|
|
|
|
|
|
|
|
245
|
|
|
|
|
|
|
=cut |
246
|
|
|
|
|
|
|
|
247
|
|
|
|
|
|
|
sub encyclopedia_arenas { |
248
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/arenas/', [ 'fields', 'language' ], undef, @_ ); |
249
|
|
|
|
|
|
|
} |
250
|
|
|
|
|
|
|
|
251
|
|
|
|
|
|
|
=item B<encyclopedia_provisions( [ %params ] )> |
252
|
|
|
|
|
|
|
|
253
|
|
|
|
|
|
|
Method returns a list of available equipment and consumables. |
254
|
|
|
|
|
|
|
|
255
|
|
|
|
|
|
|
=cut |
256
|
|
|
|
|
|
|
|
257
|
|
|
|
|
|
|
sub encyclopedia_provisions { |
258
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/provisions/', [ 'fields', 'language', 'limit', 'page_no', 'provision_id', 'type' ], undef, @_ ); |
259
|
|
|
|
|
|
|
} |
260
|
|
|
|
|
|
|
|
261
|
|
|
|
|
|
|
=item B<encyclopedia_personalmissions( [ %params ] )> |
262
|
|
|
|
|
|
|
|
263
|
|
|
|
|
|
|
Method returns details on Personal Missions on the basis of specified campaign IDs, operation IDs, mission branch and tag IDs. |
264
|
|
|
|
|
|
|
|
265
|
|
|
|
|
|
|
=cut |
266
|
|
|
|
|
|
|
|
267
|
|
|
|
|
|
|
sub encyclopedia_personalmissions { |
268
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/personalmissions/', [ 'compaign_id', 'fields', 'language', 'operation_id', 'set_id', 'tag' ], undef, @_ ); |
269
|
|
|
|
|
|
|
} |
270
|
|
|
|
|
|
|
|
271
|
|
|
|
|
|
|
=item B<encyclopedia_boosters( [ %params ] )> |
272
|
|
|
|
|
|
|
|
273
|
|
|
|
|
|
|
Method returns information about Personal Reserves. |
274
|
|
|
|
|
|
|
|
275
|
|
|
|
|
|
|
=cut |
276
|
|
|
|
|
|
|
|
277
|
|
|
|
|
|
|
sub encyclopedia_boosters { |
278
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/boosters/', [ 'fields', 'language' ], undef, @_ ); |
279
|
|
|
|
|
|
|
} |
280
|
|
|
|
|
|
|
|
281
|
|
|
|
|
|
|
=item B<encyclopedia_vehicleprofiles( [ %params ] )> |
282
|
|
|
|
|
|
|
|
283
|
|
|
|
|
|
|
Method returns vehicle configuration characteristics. |
284
|
|
|
|
|
|
|
|
285
|
|
|
|
|
|
|
=over 2 |
286
|
|
|
|
|
|
|
|
287
|
|
|
|
|
|
|
=item I<required fields> |
288
|
|
|
|
|
|
|
|
289
|
|
|
|
|
|
|
tank_id - vehicle id. |
290
|
|
|
|
|
|
|
|
291
|
|
|
|
|
|
|
=back |
292
|
|
|
|
|
|
|
|
293
|
|
|
|
|
|
|
=cut |
294
|
|
|
|
|
|
|
|
295
|
|
|
|
|
|
|
sub encyclopedia_vehicleprofiles { |
296
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/vehicleprofiles/', [ 'tank_id', 'fields', 'language', 'order_by' ], ['tank_id'], @_ ); |
297
|
|
|
|
|
|
|
} |
298
|
|
|
|
|
|
|
|
299
|
|
|
|
|
|
|
=item B<encyclopedia_modules( [ %params ] )> |
300
|
|
|
|
|
|
|
|
301
|
|
|
|
|
|
|
Method returns list of available modules that can be installed on vehicles, such as engines, turrets, etc. At least one input filter parameter (module ID, type) is required to be indicated. |
302
|
|
|
|
|
|
|
|
303
|
|
|
|
|
|
|
=cut |
304
|
|
|
|
|
|
|
|
305
|
|
|
|
|
|
|
sub encyclopedia_modules { |
306
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/modules/', [ 'extra', 'fields', 'language', 'limit', 'module_id', 'nation', 'page_no', 'type' ], undef, @_ ); |
307
|
|
|
|
|
|
|
} |
308
|
|
|
|
|
|
|
|
309
|
|
|
|
|
|
|
=item B<encyclopedia_badges( [ %params ] )> |
310
|
|
|
|
|
|
|
|
311
|
|
|
|
|
|
|
Method returns list of available badges a player can gain in Ranked Battles. |
312
|
|
|
|
|
|
|
|
313
|
|
|
|
|
|
|
=cut |
314
|
|
|
|
|
|
|
|
315
|
|
|
|
|
|
|
sub encyclopedia_badges { |
316
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/badges/', [ 'fields', 'language' ], undef, @_ ); |
317
|
|
|
|
|
|
|
} |
318
|
|
|
|
|
|
|
|
319
|
|
|
|
|
|
|
=item B<encyclopedia_crewroles( [ %params ] )> |
320
|
|
|
|
|
|
|
|
321
|
|
|
|
|
|
|
Method returns full description of all crew qualifications. |
322
|
|
|
|
|
|
|
|
323
|
|
|
|
|
|
|
=cut |
324
|
|
|
|
|
|
|
|
325
|
|
|
|
|
|
|
sub encyclopedia_crewroles { |
326
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/crewroles/', [ 'fields', 'language', 'role' ], undef, @_ ); |
327
|
|
|
|
|
|
|
} |
328
|
|
|
|
|
|
|
|
329
|
|
|
|
|
|
|
=item B<encyclopedia_crewskills( [ %params ] )> |
330
|
|
|
|
|
|
|
|
331
|
|
|
|
|
|
|
Method returns full description of all crew skills. |
332
|
|
|
|
|
|
|
|
333
|
|
|
|
|
|
|
=cut |
334
|
|
|
|
|
|
|
|
335
|
|
|
|
|
|
|
sub encyclopedia_crewskills { |
336
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/encyclopedia/crewskills/', [ 'fields', 'language', 'role', 'skill' ], undef, @_ ); |
337
|
|
|
|
|
|
|
} |
338
|
|
|
|
|
|
|
|
339
|
|
|
|
|
|
|
=back |
340
|
|
|
|
|
|
|
|
341
|
|
|
|
|
|
|
=head2 Clan ratings |
342
|
|
|
|
|
|
|
|
343
|
|
|
|
|
|
|
=over 1 |
344
|
|
|
|
|
|
|
|
345
|
|
|
|
|
|
|
=item B<clanratings_types()> |
346
|
|
|
|
|
|
|
|
347
|
|
|
|
|
|
|
Method returns details on ratings types and categories. |
348
|
|
|
|
|
|
|
|
349
|
|
|
|
|
|
|
=cut |
350
|
|
|
|
|
|
|
|
351
|
|
|
|
|
|
|
sub clanratings_types { |
352
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/clanratings/types/', [], [], @_ ); |
353
|
|
|
|
|
|
|
} |
354
|
|
|
|
|
|
|
|
355
|
|
|
|
|
|
|
=item B<calnratings_dates( [ %params ] )> |
356
|
|
|
|
|
|
|
|
357
|
|
|
|
|
|
|
Method returns dates with available rating data. |
358
|
|
|
|
|
|
|
|
359
|
|
|
|
|
|
|
=cut |
360
|
|
|
|
|
|
|
|
361
|
|
|
|
|
|
|
sub clanratings_dates { |
362
|
0
|
|
|
0
|
0
|
|
return shift->_request( 'get', 'wot/clanratings/dates/', ['limit'], undef, @_ ); |
363
|
|
|
|
|
|
|
} |
364
|
|
|
|
|
|
|
|
365
|
|
|
|
|
|
|
=item B<clanratings_clans> |
366
|
|
|
|
|
|
|
|
367
|
|
|
|
|
|
|
Method returns clan ratings by specified IDs. |
368
|
|
|
|
|
|
|
|
369
|
|
|
|
|
|
|
=over 2 |
370
|
|
|
|
|
|
|
|
371
|
|
|
|
|
|
|
=item I<required_fields:> |
372
|
|
|
|
|
|
|
|
373
|
|
|
|
|
|
|
clan_id - Clan IDs. Maximum limit: 100 |
374
|
|
|
|
|
|
|
|
375
|
|
|
|
|
|
|
=back |
376
|
|
|
|
|
|
|
|
377
|
|
|
|
|
|
|
=cut |
378
|
|
|
|
|
|
|
|
379
|
|
|
|
|
|
|
sub clanratings_clans { |
380
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/clanratings/clans/', [ 'clan_id', 'date', 'fields', 'language' ], ['clan_id'], @_ ); |
381
|
|
|
|
|
|
|
} |
382
|
|
|
|
|
|
|
|
383
|
|
|
|
|
|
|
=item B<clanratings_neighbors( [ %params ] )> |
384
|
|
|
|
|
|
|
|
385
|
|
|
|
|
|
|
Method returns list of adjacent positions in specified clan rating |
386
|
|
|
|
|
|
|
|
387
|
|
|
|
|
|
|
=over 2 |
388
|
|
|
|
|
|
|
|
389
|
|
|
|
|
|
|
=item I<required_fields:> |
390
|
|
|
|
|
|
|
|
391
|
|
|
|
|
|
|
clan_id - Clan IDs. Maximum limit: 100 |
392
|
|
|
|
|
|
|
rank_field - Rating category |
393
|
|
|
|
|
|
|
|
394
|
|
|
|
|
|
|
=back |
395
|
|
|
|
|
|
|
|
396
|
|
|
|
|
|
|
=cut |
397
|
|
|
|
|
|
|
|
398
|
|
|
|
|
|
|
sub clanratings_neighbors { |
399
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/clanratings/neighbors/', [ 'clan_id', 'rank_field', 'date', 'fields', 'language', 'limit' ], [ 'clan_id', 'rank_field' ], @_ ); |
400
|
|
|
|
|
|
|
} |
401
|
|
|
|
|
|
|
|
402
|
|
|
|
|
|
|
=item B<clanratings_top( [ %params ] )> |
403
|
|
|
|
|
|
|
|
404
|
|
|
|
|
|
|
Method returns the list of top clans by specified parameters |
405
|
|
|
|
|
|
|
|
406
|
|
|
|
|
|
|
=over 2 |
407
|
|
|
|
|
|
|
|
408
|
|
|
|
|
|
|
=item I<required_fields:> |
409
|
|
|
|
|
|
|
|
410
|
|
|
|
|
|
|
rank_field - Rating category |
411
|
|
|
|
|
|
|
|
412
|
|
|
|
|
|
|
=back |
413
|
|
|
|
|
|
|
|
414
|
|
|
|
|
|
|
=back |
415
|
|
|
|
|
|
|
|
416
|
|
|
|
|
|
|
=cut |
417
|
|
|
|
|
|
|
|
418
|
|
|
|
|
|
|
sub clanratings_top { |
419
|
0
|
|
|
0
|
1
|
|
return shift->_request( 'get', 'wot/clanratings/top/', [ 'rank_field', 'date', 'fields', 'language', 'limit', 'page_no' ], ['rank_field'], @_ ); |
420
|
|
|
|
|
|
|
} |
421
|
|
|
|
|
|
|
|
422
|
|
|
|
|
|
|
=head2 Player's vehicles |
423
|
|
|
|
|
|
|
|
424
|
|
|
|
|
|
|
=over 1 |
425
|
|
|
|
|
|
|
|
426
|
|
|
|
|
|
|
=item B<tanks_stats( [ %params ] )> |
427
|
|
|
|
|
|
|
|
428
|
|
|
|
|
|
|
Method returns overall statistics, Tank Company statistics, and clan statistics per each vehicle for each user. |
429
|
|
|
|
|
|
|
|
430
|
|
|
|
|
|
|
=over 2 |
431
|
|
|
|
|
|
|
|
432
|
|
|
|
|
|
|
=item I<required fields:> |
433
|
|
|
|
|
|
|
|
434
|
|
|
|
|
|
|
account_id - Account ID. Max limit is 100. Min value is 1. |
435
|
|
|
|
|
|
|
|
436
|
|
|
|
|
|
|
=cut |
437
|
|
|
|
|
|
|
|
438
|
|
|
|
|
|
|
sub tanks_stats { |
439
|
|
|
|
|
|
|
return shift->_request( |
440
|
0
|
|
|
0
|
1
|
|
'get', 'wot/tanks/stats/', |
441
|
|
|
|
|
|
|
[ 'language', 'fields', 'access_token', 'account_id', 'tank_id', 'in_garage', 'extra' ], |
442
|
|
|
|
|
|
|
['account_id'], @_ |
443
|
|
|
|
|
|
|
); |
444
|
|
|
|
|
|
|
} |
445
|
|
|
|
|
|
|
|
446
|
|
|
|
|
|
|
=item B<tanks_achievements( [ %params ] )> |
447
|
|
|
|
|
|
|
|
448
|
|
|
|
|
|
|
Method returns list of achievements on all vehicles. |
449
|
|
|
|
|
|
|
|
450
|
|
|
|
|
|
|
Achievement properties define the achievements field values: |
451
|
|
|
|
|
|
|
|
452
|
|
|
|
|
|
|
1-4 for Mastery Badges and Stage Achievements (type: "class"); |
453
|
|
|
|
|
|
|
maximum value of Achievement series (type: "series"); |
454
|
|
|
|
|
|
|
number of achievements earned from sections: Battle Hero, Epic Achievements, Group Achievements, Special Achievements, etc. (type: "repeatable, single, custom"). |
455
|
|
|
|
|
|
|
|
456
|
|
|
|
|
|
|
=over 2 |
457
|
|
|
|
|
|
|
|
458
|
|
|
|
|
|
|
=item I<required fields:> |
459
|
|
|
|
|
|
|
|
460
|
|
|
|
|
|
|
account_id - Account ID. Max limit is 100. Min value is 1. |
461
|
|
|
|
|
|
|
|
462
|
|
|
|
|
|
|
=back |
463
|
|
|
|
|
|
|
|
464
|
|
|
|
|
|
|
=back |
465
|
|
|
|
|
|
|
|
466
|
|
|
|
|
|
|
=cut |
467
|
|
|
|
|
|
|
|
468
|
|
|
|
|
|
|
sub tanks_achievements { |
469
|
|
|
|
|
|
|
return shift->_request( |
470
|
0
|
|
|
0
|
1
|
|
'get', 'wot/tanks/achievements/', |
471
|
|
|
|
|
|
|
[ 'language', 'fields', 'access_token', 'account_id', 'tank_id', 'in_garage' ], |
472
|
|
|
|
|
|
|
['account_id'], @_ |
473
|
|
|
|
|
|
|
); |
474
|
|
|
|
|
|
|
} |
475
|
|
|
|
|
|
|
|
476
|
|
|
|
|
|
|
=back |
477
|
|
|
|
|
|
|
|
478
|
|
|
|
|
|
|
=head1 BUGS |
479
|
|
|
|
|
|
|
|
480
|
|
|
|
|
|
|
Please report any bugs or feature requests to C<cynovg at cpan.org>, or through the web interface at L<https://gitlab.com/cynovg/WG-API/issues>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. |
481
|
|
|
|
|
|
|
|
482
|
|
|
|
|
|
|
=head1 SUPPORT |
483
|
|
|
|
|
|
|
|
484
|
|
|
|
|
|
|
You can find documentation for this module with the perldoc command. |
485
|
|
|
|
|
|
|
|
486
|
|
|
|
|
|
|
perldoc WG::API |
487
|
|
|
|
|
|
|
|
488
|
|
|
|
|
|
|
You can also look for information at: |
489
|
|
|
|
|
|
|
|
490
|
|
|
|
|
|
|
=over 4 |
491
|
|
|
|
|
|
|
|
492
|
|
|
|
|
|
|
=item * RT: Gitlab's request tracker (report bugs here) |
493
|
|
|
|
|
|
|
|
494
|
|
|
|
|
|
|
L<https://gitlab.com/cynovg/WG-API/issues> |
495
|
|
|
|
|
|
|
|
496
|
|
|
|
|
|
|
=item * AnnoCPAN: Annotated CPAN documentation |
497
|
|
|
|
|
|
|
|
498
|
|
|
|
|
|
|
L<http://annocpan.org/dist/WG-API> |
499
|
|
|
|
|
|
|
|
500
|
|
|
|
|
|
|
=item * CPAN Ratings |
501
|
|
|
|
|
|
|
|
502
|
|
|
|
|
|
|
L<http://cpanratings.perl.org/d/WG-API> |
503
|
|
|
|
|
|
|
|
504
|
|
|
|
|
|
|
=item * Search CPAN |
505
|
|
|
|
|
|
|
|
506
|
|
|
|
|
|
|
L<https://metacpan.org/pod/WG::API> |
507
|
|
|
|
|
|
|
|
508
|
|
|
|
|
|
|
=back |
509
|
|
|
|
|
|
|
|
510
|
|
|
|
|
|
|
|
511
|
|
|
|
|
|
|
=head1 ACKNOWLEDGEMENTS |
512
|
|
|
|
|
|
|
|
513
|
|
|
|
|
|
|
... |
514
|
|
|
|
|
|
|
|
515
|
|
|
|
|
|
|
=head1 SEE ALSO |
516
|
|
|
|
|
|
|
|
517
|
|
|
|
|
|
|
WG API Reference L<https://developers.wargaming.net/> |
518
|
|
|
|
|
|
|
|
519
|
|
|
|
|
|
|
=head1 AUTHOR |
520
|
|
|
|
|
|
|
|
521
|
|
|
|
|
|
|
Cyrill Novgorodcev , C<< <cynovg at cpan.org> >> |
522
|
|
|
|
|
|
|
|
523
|
|
|
|
|
|
|
=head1 LICENSE AND COPYRIGHT |
524
|
|
|
|
|
|
|
|
525
|
|
|
|
|
|
|
Copyright 2015 Cyrill Novgorodcev. |
526
|
|
|
|
|
|
|
|
527
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it |
528
|
|
|
|
|
|
|
under the terms of the the Artistic License (2.0). You may obtain a |
529
|
|
|
|
|
|
|
copy of the full license at: |
530
|
|
|
|
|
|
|
|
531
|
|
|
|
|
|
|
L<http://www.perlfoundation.org/artistic_license_2_0> |
532
|
|
|
|
|
|
|
|
533
|
|
|
|
|
|
|
Any use, modification, and distribution of the Standard or Modified |
534
|
|
|
|
|
|
|
Versions is governed by this Artistic License. By using, modifying or |
535
|
|
|
|
|
|
|
distributing the Package, you accept this license. Do not use, modify, |
536
|
|
|
|
|
|
|
or distribute the Package, if you do not accept this license. |
537
|
|
|
|
|
|
|
|
538
|
|
|
|
|
|
|
If your Modified Version has been derived from a Modified Version made |
539
|
|
|
|
|
|
|
by someone other than you, you are nevertheless required to ensure that |
540
|
|
|
|
|
|
|
your Modified Version complies with the requirements of this license. |
541
|
|
|
|
|
|
|
|
542
|
|
|
|
|
|
|
This license does not grant you the right to use any trademark, service |
543
|
|
|
|
|
|
|
mark, tradename, or logo of the Copyright Holder. |
544
|
|
|
|
|
|
|
|
545
|
|
|
|
|
|
|
This license includes the non-exclusive, worldwide, free-of-charge |
546
|
|
|
|
|
|
|
patent license to make, have made, use, offer to sell, sell, import and |
547
|
|
|
|
|
|
|
otherwise transfer the Package with respect to any patent claims |
548
|
|
|
|
|
|
|
licensable by the Copyright Holder that are necessarily infringed by the |
549
|
|
|
|
|
|
|
Package. If you institute patent litigation (including a cross-claim or |
550
|
|
|
|
|
|
|
counterclaim) against any party alleging that the Package constitutes |
551
|
|
|
|
|
|
|
direct or contributory patent infringement, then this Artistic License |
552
|
|
|
|
|
|
|
to you shall terminate on the date that such litigation is filed. |
553
|
|
|
|
|
|
|
|
554
|
|
|
|
|
|
|
Disclaimer of Warranty: THE PACKAGE IS PROVIDED BY THE COPYRIGHT HOLDER |
555
|
|
|
|
|
|
|
AND CONTRIBUTORS "AS IS' AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES. |
556
|
|
|
|
|
|
|
THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
557
|
|
|
|
|
|
|
PURPOSE, OR NON-INFRINGEMENT ARE DISCLAIMED TO THE EXTENT PERMITTED BY |
558
|
|
|
|
|
|
|
YOUR LOCAL LAW. UNLESS REQUIRED BY LAW, NO COPYRIGHT HOLDER OR |
559
|
|
|
|
|
|
|
CONTRIBUTOR WILL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, OR |
560
|
|
|
|
|
|
|
CONSEQUENTIAL DAMAGES ARISING IN ANY WAY OUT OF THE USE OF THE PACKAGE, |
561
|
|
|
|
|
|
|
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
562
|
|
|
|
|
|
|
|
563
|
|
|
|
|
|
|
|
564
|
|
|
|
|
|
|
=cut |
565
|
|
|
|
|
|
|
|
566
|
|
|
|
|
|
|
1; # End of WG::API::WoT |