2

Net::MsmgrCPAN にモジュールがあります。きれいに書かれており、コードは一見信頼できるように見えます。ただし、このモジュールはベータ版のようで、ドキュメントはほとんどなく、テストもありません :-/

このモジュールを本番環境で使用した人はいますか? すべてのイベント ループ処理をアプリケーションで実行する必要があり、既に述べたように、ドキュメントがほとんどなく、学習する実用的な例がないため、今のところ実行できていません。

それが私がこれまでに行った場所です:

#!/usr/bin/perl
use strict;
use warnings;

use Event;
use Net::Msmgr::Object;
use Net::Msmgr::Session;
use Net::Msmgr::User;

use constant DEBUG => 511;
use constant EVENT_TIMEOUT => 5; # seconds

my ($username, $password) = qw/my.username@live.com my.password/;
my $buddy = 'your.username@live.com';

my $user = Net::Msmgr::User->new(user => $username, password => $password);
my $session = Net::Msmgr::Session->new;
$session->debug(DEBUG);
$session->login_handler(\&login_handler);
$session->user($user);

my $conv;

sub login_handler {
    my $self = shift;
    print "LOGIN\n";
    $self->ui_state_nln;
    $conv = $session->ui_new_conversation;
    $conv->invite($buddy);
}

our %watcher;

sub ConnectHandler {
    my ($connection) = @_;
    warn "CONNECT\n";
    my $socket = $connection->socket;
    $watcher{$connection} = Event->io(fd => $socket,
                                      cb => [ $connection, '_recv_message' ],
                                      poll => 're',
                                      desc => 'recv_watcher',
                                      repeat => 1);
}

sub DisconnectHandler {
    my $connection = shift;
    print "DISCONNECT\n";
    $watcher{$connection}->cancel;
}

$session->connect_handler(\&ConnectHandler);
$session->disconnect_handler(\&DisconnectHandler);

$session->Login;

Event::loop();

それが出力するものです:

Dispatch Server connecting to: messenger.hotmail.com:1863
Dispatch Server connected
CONNECT
Dispatch Server >>>VER 1 MSNP2 CVR0
--> VER 1 MSNP2 CVR0
Dispatch Server >>>USR 2 MD5 I my.username@live.com
--> USR 2 MD5 I my.username@live.com
Dispatch Server <<<VER 1 CVR0
<-- VER 1 CVR0

それだけです。ここでハングします。ログイン時のハンドラーがトリガーされていません。私は何を間違っていますか?

4

1 に答える 1

-2

これらのドキュメントがお役に立てば幸いです

1) Net::Msmgr のドキュメント

2)ネット::Msmgr::セッション

于 2010-04-26T09:03:13.763 に答える