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 37 by douglas, 2004-07-22T16:00:52-07:00 vs.
Revision 60 by douglas, 2004-09-15T19:43:29-07:00

# Line 30 | Line 30 | Collector::Collector(const ext::String&
30  
31   int Collector::collect()
32   {
33 <        cerr << bright << green << "Started collector daemon.\n" << reset;
33 >        api::Cerr << bright << green << "Started collector daemon at " << Stamp()
34 >                << ".\n" << reset;
35  
36          net::Oscar::Session session;
37          net::Oscar::AuthTool auth(session);
# Line 52 | Line 53 | int Collector::collect()
53  
54          net::Oscar::StringSet buddies;
55  
56 <        for (std::set<Buddy>::const_iterator buddy(this->buddies.begin()); buddy != this->buddies.end(); ++buddy)
57 <                buddies.Insert(*buddy);
56 >        for (std::set<Buddy>::const_iterator buddy(this->buddies.begin());
57 >                buddy != this->buddies.end(); ++buddy) buddies.Insert(*buddy);
58  
59          buddy.Insert(buddies);
60  
61          net::Oscar::Capabilities capabilities;
62  
63          capabilities.Insert(net::Oscar::ChatCapability);
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=2>Mommy told me not to talk to strangers.</font> O:-)", capabilities);
64 >        info.SetProfile("<font face=\"Tahoma\" size=2>I am <a href=\""
65 >                + Zoe::generator(Zoe::url) + "\">Zoe</a>.</font> :-*", "<font face=\""
66 >                "Tahoma\" size=2>Mommy told me not to talk to strangers.</font> O:-)",
67 >                capabilities);
68  
69 <        // figure out whether or not we logged in
69 >        // XXX figure out whether or not we logged in
70  
71 <        while (true) sleep(Minute(1));
71 >        while (true) sleep(Hour(1));
72   }
73  
74   void Collector::prompt()
# Line 77 | Line 80 | void Collector::prompt()
80  
81          this->password = password;
82  
83 <        for (size_t index(std::strlen(password)); index > 0; --index) password[index - 1] = '\0';
83 >        for (size_t index(std::strlen(password)); index > 0; --index)
84 >                password[index - 1] = '\0';
85   }
86  
87   void Collector::status(const net::Oscar::UserInfo& user)
# Line 87 | Line 91 | void Collector::status(const net::Oscar:
91  
92          if (!ext::String(message).IsEmpty()) // XXX
93          {
94 <                ext::Handle<dbi::Connection> db(dbi::Connect(database.driver, database.host, database.user, database.password,
95 <                        database.db));
96 <                ext::Handle<dbi::ResultSet> previous(db->Execute("SELECT message FROM messages "
97 <                        "WHERE stamp=(SELECT MAX(stamp) FROM messages WHERE id='"
98 <                        + lexical_cast<ext::String>(buddy.getId()) + "') AND id='"
99 <                        + lexical_cast<ext::String>(buddy.getId()) + "'"));
94 >                if (Zoe::debug) api::Cerr << "buddy = " << buddy << "\nmessage = "
95 >                        << message << "\n";
96 >
97 >                ext::Handle<dbi::Driver> driver(dbi::GetDriver(database.driver));
98 >                ext::Handle<dbi::Connection> db(driver->Connect(database.host,
99 >                        database.user, database.password, database.db));
100 >                ext::Handle<dbi::ResultSet> previous(db->Execute(ios::String()
101 >                        << "SELECT message FROM messages WHERE stamp=(SELECT MAX(stamp) "
102 >                        << "FROM messages WHERE id='" << buddy.getId() << "') AND id='"
103 >                        << buddy.getId() << "'"));
104  
105                  if (previous->MoveNext())
106                  {
107                          if (ext::String(message) == previous->GetString("message")) return;
108                  }
109  
110 <                db->Execute("INSERT INTO messages (stamp, message, id) VALUES ('"
111 <                        + ext::String(message.getStamp()) + "', '" + db->Escape(message)
112 <                        + "', '" + lexical_cast<ext::String>(buddy.getId()) + "')");
110 >                db->Execute(ios::String() << "INSERT INTO messages (stamp, message, id)"
111 >                        << " VALUES ('" << message.getStamp() << "', '"
112 >                        << db->Escape(message) << "', '" << buddy.getId() << "')");
113 >
114 >                api::Cerr << bright << red << "Collected away message from " << blue
115 >                        << buddy << red << " at " << Stamp() << ".\n" << reset;
116 >        }
117 >
118 >        if (user.screenname != buddy.getDisplay(database))
119 >        {
120 >                buddy.setDisplay(user.screenname, database);
121 >
122 >                sleep(1);
123  
124 <                cerr << bright << red << "Collected away message from " << blue << buddy
107 <                        << red << ".\n" << reset;
124 >                icbm->Simple(buddy, "<font face=\"Tahoma\" size=2>So sexy!</font> :-*");
125          }
126   }
127  
128   void Collector::receive(const ext::String& buddy, const ext::String& message)
129   {
130 <        if (Zoe::debug) cerr << "buddy = " << Buddy(buddy) << "\nmessage = "
131 <                << message << '\n';
130 >        if (Zoe::debug) api::Cerr << "buddy = " << Buddy(buddy) << "\nmessage = "
131 >                << message << "\n";
132  
133          if (buddies.find(buddy) != buddies.end())
134          {
# Line 119 | Line 136 | void Collector::receive(const ext::Strin
136                  
137                  sleep(1);
138  
139 <                icbm->Simple(buddy, ext::String(buddy_) + " = {\n   rss = "
140 <                        + buddy_.getRss() + "\n   atom = " + buddy_.getAtom() + "\n}");
139 >                icbm->Simple(buddy, "<font face=\"Tahoma\" size=2>Hello! I am Zoe. I am"
140 >                        " supposed to be collecting your <a href=\"" + buddy_.getLink()
141 >                        + "\">Away Messages</a> (<a href=\"" + buddy_.getRssLink() + "\">"
142 >                        "RSS 2.0</a>) (<a href=\"" + buddy_.getAtomLink() + "\">Atom</a>)."
143 >                        "</font> :-*");
144          }
145          else
146          {

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines