f17f6ffb92204d7597fd868e9058a14fbdb381aa
5 use std
::net
::{SocketAddr
, SocketAddrV4
, ToSocketAddrs
};
6 use serde
::{Serialize
, Serializer
};
8 use crate::HLQueryError
::{IOError
,A2SError
};
10 #[derive(Debug, Serialize)]
11 struct HLQueryResult
{
12 address
: SocketAddrV4
,
13 info
: Result
<a2s
::info
::Info
, HLQueryError
>,
14 rules
: Result
<Vec
<a2s
::rules
::Rule
>, HLQueryError
>,
15 players
: Result
<Vec
<a2s
::players
::Player
>, HLQueryError
>
19 fn new(a2s_client
: &A2SClient
, server
: SocketAddrV4
) -> Self {
22 info
: a2s_client
.in
fo
(server
).map_err(From
::from
),
23 rules
: a2s_client
.rules(server
).map_err(From
::from
),
24 players
: a2s_client
.players(server
).map_err(From
::from
)
31 IOError(std
::io
::Error
),
32 A2SError(a2s
::errors
::Error
)
35 impl Display
for HLQueryError
{
36 fn fmt(&self, f
: &mut fmt
::Formatter
) -> fmt
::Result
{
38 IOError(e
) => write
!(f
, "{}", e
),
39 A2SError(e
) => write
!(f
, "{}", e
)
44 impl Error
for HLQueryError
{}
46 impl Serialize
for HLQueryError
{
47 fn serialize
<S
>(&self, serializer
: S
) -> Result
<S
::Ok
, S
::Error
>
51 serializer
.serialize_str(&format
!("{self}"))
55 impl From
<std
::io
::Error
> for HLQueryError
{
56 fn from(e
: std
::io
::Error
) -> Self {
61 impl From
<a2s
::errors
::Error
> for HLQueryError
{
62 fn from(e
: a2s
::errors
::Error
) -> Self {
69 let client
= A2SClient
::new().unwrap
();
70 let query_results
: Vec
<Result
<Vec
<HLQueryResult
>, HLQueryError
>> = args().skip(1)
71 .map(|arg
| arg
.to_socket_addrs())
72 .map(|lookup_result
| match lookup_result
{
74 Ok(iter_addr
.filter
_map
(|sa
| match sa
{
75 SocketAddr
::V4(sa4
) => Some(sa4
),
79 Err(e
) => Err(HLQueryError
::IOError(e
))
81 .map(|address_group
| address_group
.map(|addresses
| addresses
.map(|addr
| HLQueryResult
::new(&client
, addr
)).collect()))
84 println
!("{}\n", serde_json
::to_string_pretty(&query_results
).unwrap
());