ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/cvsroot/Net-XMPP2/samples/limit_searcher
Revision: 1.3
Committed: Fri Jul 6 22:22:21 2007 UTC (17 years ago) by elmex
Branch: MAIN
CVS Tags: HEAD
Changes since 1.2: +1 -1 lines
Log Message:
implemented dataforms - phew! that was a bullet of work

File Contents

# User Rev Content
1 elmex 1.1 #!/opt/perl/bin/perl
2     use strict;
3     use utf8;
4     use Event;
5     use AnyEvent;
6     use Net::XMPP2::Client;
7     use Net::XMPP2::Util qw/simxml/;
8     use Net::XMPP2::Ext::Disco;
9    
10     my $j = AnyEvent->condvar;
11     my $cl = Net::XMPP2::Client->new;
12    
13 elmex 1.2 $cl->add_account ('net_xmpp2@jabber.org', 'test');
14 elmex 1.1
15     my $max_size = 100000;
16     my $first_size = $max_size;
17     my $last_nok_size = $max_size;
18     my $last_ok_size = 0;
19 elmex 1.2 my $delta = 10;
20 elmex 1.1
21     $cl->reg_cb (
22 elmex 1.3 session_ready => sub {
23 elmex 1.1 my ($cl, $acc) = @_;
24     my $con = $acc->connection;
25 elmex 1.2
26     $con->{max_write_length} = 4096;
27    
28 elmex 1.1 if (($last_nok_size - $last_ok_size) < $delta) {
29     print "Found limit in delta range: $last_ok_size for ".$acc->jid."\n";
30     $con->disconnect ("found limit");
31     return 0;
32     }
33 elmex 1.2
34 elmex 1.1 $con->send_iq (set => sub {
35     my ($w) = @_;
36     simxml ($w,
37     defns => 'jabber:iq:private',
38     node => {
39     name => 'query',
40     ns => 'jabber:iq:private',
41     childs => [
42     { name => "test", dns => "test:fe", childs => [ "A" x $first_size ] },
43     ]
44     }
45 elmex 1.2 );
46     print "Trying $first_size...\n";
47 elmex 1.1 }, sub {
48     my ($n, $e) = @_;
49     if ($e) {
50     die "iq private error: " . $e->string . "\n";
51     } else {
52     $con->send_iq (get => sub {
53     my ($w) = @_;
54     simxml ($w,
55     defns => 'jabber:iq:private',
56     node => {
57     name => 'query',
58     ns => 'jabber:iq:private',
59     childs => [ { name => 'test', dns => 'test:fe' } ]
60     }
61     );
62     }, sub {
63 elmex 1.2 my ($n, $e) = @_;
64     if ($e) {
65     $con->disconnect ("bad iq reply");
66     } else {
67     my ($q) = $n->find_all ([qw/jabber:iq:private query/],
68     [qw/test:fe test/]);
69     my $len = length $q->text;
70     if ($len == $first_size) {
71     print "$len seems to be ok!\n";
72     $last_ok_size = $first_size;
73     $first_size = $last_ok_size + ($last_nok_size - $last_ok_size) / 2;
74     $first_size = int ($first_size);
75     $con->disconnect ("retry");
76     } else {
77     $con->disconnect ("too short iq reply");
78     }
79     }
80 elmex 1.1 });
81     }
82     }, timeout => 1000000);
83    
84     1
85     },
86     stream_error => sub {
87     my ($cl, $acc, $err) = @_;
88     print "STREAM ERROR: [" . $err->string . "] at $first_size, retry...\n";
89     1
90     },
91 elmex 1.2 connect_error => sub {
92     my ($cl, $acc, $err) = @_;
93     print "Connect error ".$acc->jid.": $err\n";
94     1
95     },
96 elmex 1.1 disconnect => sub {
97     my ($cl, $acc, $host, $port, $msg) = @_;
98     if ($msg eq 'found limit') { $j->broadcast }
99 elmex 1.2 elsif ($msg ne 'retry') {
100     $last_nok_size = $first_size;
101     $first_size = $last_ok_size + ($last_nok_size - $last_ok_size) / 2;
102     $first_size = int ($first_size);
103     print "disconnect got ($msg), retry with $first_size\n";
104     }
105 elmex 1.1 $cl->update_connections; # reconnect !
106     1
107     },
108     message => sub {
109     my ($cl, $acc, $msg) = @_;
110     print "message from: " . $msg->from . ": " . $msg->any_body . "\n";
111     1
112     }
113     );
114    
115     $cl->start;
116     $j->wait;
117