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 21 by douglas, 2004-07-16T23:37:41-07:00 vs.
Revision 34 by douglas, 2004-07-20T16:49:06-07:00

# Line 16 | Line 16 | extern "C"
16   #include <unistd.h>
17   }
18  
19 < Collector::Collector(const ext::String& login, ext::String& password, const
20 <        std::set<Buddy>& buddies, const Database& database, bool start) :
21 <        login(login), password(password), buddies(buddies), database(database),
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)
# Line 31 | Line 30 | Collector::Collector(const ext::String&
30  
31   int Collector::collect()
32   {
33 <        cerr << "Collector::collect()\n";
33 >        cerr << bright << green << "Collector::collect()\n" << reset;
34  
35          net::Oscar::Session session;
36          net::Oscar::AuthTool auth(session);
# Line 46 | Line 45 | int Collector::collect()
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::reply, this);
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 !=
56 <                this->buddies.end(); ++buddy) buddies.Insert(*buddy);
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          icbm.RequestParams();
# Line 61 | Line 61 | int Collector::collect()
61          net::Oscar::Capabilities capabilities;
62  
63          capabilities.Insert(net::Oscar::ChatCapability);
64 <        info.SetProfile("<font size=3>I am <a href=\"http://computers.douglasthrift.net/zoe.xml\">Zoe</a>.</font> :-*", "<font size=3>Mommy told me not to talk to strangers.</font> O:-)", capabilities);
64 >        info.SetProfile("<font face=\"Tahoma\" size=2>I am <a href=\"http://computers.douglasthrift.net/zoe.xml\">Zoe</a>."
65 >                "</font> :-*", "<font face=\"Tahoma\" size=3>Mommy told me not to talk to strangers.</font> O:-)", capabilities);
66  
67          // figure out whether or not we logged in
68  
69 <        while (true) sleep(60);
69 >        while (true) sleep(Minute(1));
70   }
71  
72   void Collector::prompt()
# Line 77 | Line 78 | void Collector::prompt()
78  
79          this->password = password;
80  
81 <        for (size_t index(std::strlen(password)); index > 0; --index)
81 <                password[index - 1] = '\0';
81 >        for (size_t index(std::strlen(password)); index > 0; --index) password[index - 1] = '\0';
82   }
83  
84 < void Collector::reply(const Buddy& buddy, const ext::String& message)
84 > void Collector::status(const net::Oscar::UserInfo& user)
85   {
86 +        Buddy buddy(*buddies.find(user));
87 +        AwayMessage message(buddy, *info);
88 +
89 +        if (!ext::String(message).IsEmpty()) // XXX
90 +        {
91 +                ext::Handle<dbi::Connection> db(dbi::Connect(database.driver, database.host, database.user, database.password,
92 +                        database.db));
93 +                ext::Handle<dbi::ResultSet> previous(db->Execute("SELECT message FROM messages WHERE stamp=(SELECT MAX(stamp) "
94 +                        "FROM messages WHERE id='" + lexical_cast<ext::String>(buddy.getId()) + "') AND id='"
95 +                        + lexical_cast<ext::String>(buddy.getId()) + "'"));
96 +
97 +                if (previous->MoveNext()) if (ext::String(message) == previous->GetString("message")) return;
98 +
99 +                cerr << bright << red << "Collector::status(" << blue << buddy << red << ", " << reset << message << bright << red
100 +                        << ")\n" << reset;
101 +
102 +                db->Execute("INSERT INTO messages (stamp, message, id) VALUES ('" + ext::String(message.getStamp()) + "', '"
103 +                        + db->Escape(message) + "', '" + lexical_cast<ext::String>(buddy.getId()) + "')");
104 +        }
105 + }
106 +
107 + void Collector::receive(const ext::String& buddy, const ext::String& message)
108 + {
109 +        cerr << bright << red << "Collector::receive(" << blue << Buddy(buddy) << red << ", " << reset << message << bright
110 +                << red << ")\n" << reset;
111 +
112          if (buddies.find(buddy) != buddies.end())
113          {
114 <                //
114 >                Stamp stamp;
115 >                
116 >                sleep(1);
117 >
118 >                icbm->Simple(buddy, stamp);
119          }
120          else
121          {
122                  sleep(1);
123  
124 <                icbm->Simple(buddy, "<font size=3>Mommy told me not to talk to strangers. O:-)");
124 >                icbm->Simple(buddy, "<font face=\"Tahoma\" size=2>Mommy told me not to talk to strangers. O:-)");
125          }
126   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines