ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/zoe/trunk/Collector.cpp
(Generate patch)

Comparing trunk/Collector.cpp (file contents):
Revision 13 by douglas, 2004-07-11T23:49:09-07:00 vs.
Revision 37 by douglas, 2004-07-22T16:00:52-07:00

# Line 4 | Line 4
4   //
5   // $Id$
6  
7 + #include "AwayMessage.hpp"
8   #include "Collector.hpp"
9 + #include "Stamp.hpp"
10  
11 < Collector::Collector(const std::set<Buddy>& buddies)
11 > #include <cstring>
12 >
13 > extern "C"
14 > {
15 > #include <pwd.h>
16 > #include <unistd.h>
17 > }
18 >
19 > Collector::Collector(const ext::String& login, ext::String& password, const     std::set<Buddy>& buddies,
20 >        const Database& database, bool start) : login(login), password(password), buddies(buddies), database(database),
21 >        start(start), prompted(false)
22 > {
23 >        if (start)
24 >        {
25 >                if (password.IsEmpty()) prompt();
26 >
27 >                collector.Spawn(etl::Bind<0>(&Collector::collect, this));
28 >        }
29 > }
30 >
31 > int Collector::collect()
32   {
33 <        //
33 >        cerr << bright << green << "Started collector daemon.\n" << reset;
34 >
35 >        net::Oscar::Session session;
36 >        net::Oscar::AuthTool auth(session);
37 >        net::Oscar::BuddyTool buddy(session);
38 >        net::Oscar::ChatTool chat(session);
39 >        net::Oscar::IcbmTool icbm(session);
40 >        net::Oscar::InfoTool info(session);
41 >
42 >        auth.Login(login, password);
43 >
44 >        if (prompted) password.Clear();
45 >
46 >        this->buddy = &buddy;
47 >        this->icbm = &icbm;
48 >        this->info = &info;
49 >
50 >        buddy.OnOnline += etl::Bind<0>(&Collector::status, this);
51 >        icbm.OnReceive += etl::Bind<0>(&Collector::receive, this);
52 >
53 >        net::Oscar::StringSet buddies;
54 >
55 >        for (std::set<Buddy>::const_iterator buddy(this->buddies.begin()); buddy != this->buddies.end(); ++buddy)
56 >                buddies.Insert(*buddy);
57 >
58 >        buddy.Insert(buddies);
59 >
60 >        net::Oscar::Capabilities capabilities;
61 >
62 >        capabilities.Insert(net::Oscar::ChatCapability);
63 >        info.SetProfile("<font face=\"Tahoma\" size=2>I am <a href=\"http://computers.douglasthrift.net/zoe.xml\">Zoe</a>."
64 >                "</font> :-*", "<font face=\"Tahoma\" size=2>Mommy told me not to talk to strangers.</font> O:-)", capabilities);
65 >
66 >        // figure out whether or not we logged in
67 >
68 >        while (true) sleep(Minute(1));
69 > }
70 >
71 > void Collector::prompt()
72 > {
73 >        if (!prompted) prompted = true;
74 >
75 >        ext::String prompt(login + "'s AIM Password: ");
76 >        char* password(getpass(prompt.NullTerminate()));
77 >
78 >        this->password = password;
79 >
80 >        for (size_t index(std::strlen(password)); index > 0; --index) password[index - 1] = '\0';
81 > }
82 >
83 > void Collector::status(const net::Oscar::UserInfo& user)
84 > {
85 >        Buddy buddy(*buddies.find(user));
86 >        AwayMessage message(buddy, *info);
87 >
88 >        if (!ext::String(message).IsEmpty()) // XXX
89 >        {
90 >                ext::Handle<dbi::Connection> db(dbi::Connect(database.driver, database.host, database.user, database.password,
91 >                        database.db));
92 >                ext::Handle<dbi::ResultSet> previous(db->Execute("SELECT message FROM messages "
93 >                        "WHERE stamp=(SELECT MAX(stamp) FROM messages WHERE id='"
94 >                        + lexical_cast<ext::String>(buddy.getId()) + "') AND id='"
95 >                        + lexical_cast<ext::String>(buddy.getId()) + "'"));
96 >
97 >                if (previous->MoveNext())
98 >                {
99 >                        if (ext::String(message) == previous->GetString("message")) return;
100 >                }
101 >
102 >                db->Execute("INSERT INTO messages (stamp, message, id) VALUES ('"
103 >                        + ext::String(message.getStamp()) + "', '" + db->Escape(message)
104 >                        + "', '" + lexical_cast<ext::String>(buddy.getId()) + "')");
105 >
106 >                cerr << bright << red << "Collected away message from " << blue << buddy
107 >                        << red << ".\n" << reset;
108 >        }
109 > }
110 >
111 > void Collector::receive(const ext::String& buddy, const ext::String& message)
112 > {
113 >        if (Zoe::debug) cerr << "buddy = " << Buddy(buddy) << "\nmessage = "
114 >                << message << '\n';
115 >
116 >        if (buddies.find(buddy) != buddies.end())
117 >        {
118 >                Buddy buddy_(*buddies.find(buddy));
119 >                
120 >                sleep(1);
121 >
122 >                icbm->Simple(buddy, ext::String(buddy_) + " = {\n   rss = "
123 >                        + buddy_.getRss() + "\n   atom = " + buddy_.getAtom() + "\n}");
124 >        }
125 >        else
126 >        {
127 >                sleep(1);
128 >
129 >                icbm->Simple(buddy, "<font face=\"Tahoma\" size=2>Mommy told me not to "
130 >                        "talk to strangers.</font> O:-)");
131 >        }
132   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines