File: HangmanDb_8C-source.html

package info (click to toggle)
witty 3.1.2-3
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 45,512 kB
  • ctags: 35,832
  • sloc: cpp: 69,469; ansic: 66,945; xml: 4,383; sh: 594; perl: 108; makefile: 106
file content (160 lines) | stat: -rw-r--r-- 16,503 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>Wt examples: /home/koen/project/wt/public-git/wt/examples/hangman/HangmanDb.C Source File</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.5.6 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
<h1>/home/koen/project/wt/public-git/wt/examples/hangman/HangmanDb.C</h1><a href="HangmanDb_8C.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="preprocessor">#include &lt;iostream&gt;</span>
<a name="l00002"></a>00002 <span class="preprocessor">#include &lt;iomanip&gt;</span>
<a name="l00003"></a>00003 <span class="preprocessor">#include &lt;string&gt;</span>
<a name="l00004"></a>00004 <span class="preprocessor">#include &lt;fstream&gt;</span>
<a name="l00005"></a>00005 
<a name="l00006"></a>00006 <span class="preprocessor">#include &lt;mysql++/mysql++.h&gt;</span>
<a name="l00007"></a>00007 <span class="preprocessor">#include &lt;Wt/WStringUtil&gt;</span>
<a name="l00008"></a>00008 
<a name="l00009"></a>00009 <span class="preprocessor">#include "<a class="code" href="HangmanDb_8h.html">HangmanDb.h</a>"</span>
<a name="l00010"></a>00010 
<a name="l00011"></a>00011 <span class="keyword">using namespace </span>mysqlpp;
<a name="l00012"></a>00012 
<a name="l00013"></a><a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">00013</a> std::string <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">HangmanDb::DbUser</a>()
<a name="l00014"></a>00014 {
<a name="l00015"></a>00015         std::string retval;
<a name="l00016"></a>00016         std::ifstream dbconf(<span class="stringliteral">"HangmanDb.info"</span>);
<a name="l00017"></a>00017         dbconf &gt;&gt; retval;
<a name="l00018"></a>00018         <span class="keywordflow">return</span> retval;
<a name="l00019"></a>00019 }
<a name="l00020"></a>00020 
<a name="l00021"></a><a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">00021</a> std::string <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">HangmanDb::DbPass</a>()
<a name="l00022"></a>00022 {
<a name="l00023"></a>00023         std::string retval;
<a name="l00024"></a>00024         std::ifstream dbconf(<span class="stringliteral">"HangmanDb.info"</span>);
<a name="l00025"></a>00025         dbconf &gt;&gt; retval; <span class="comment">// username</span>
<a name="l00026"></a>00026         dbconf &gt;&gt; retval; <span class="comment">// password</span>
<a name="l00027"></a>00027         <span class="keywordflow">return</span> retval;
<a name="l00028"></a>00028 }
<a name="l00029"></a>00029 
<a name="l00030"></a>00030 <span class="comment">// this function returns false if user existed, true if user inserted</span>
<a name="l00031"></a>00031 <span class="comment">// It guarantees atomic userExists() checking and adding it if the user</span>
<a name="l00032"></a>00032 <span class="comment">// did not yet exits.</span>
<a name="l00033"></a><a class="code" href="classHangmanDb.html#0190e8b4f748d0720bc1d61eeb2a5f4b">00033</a> <span class="keywordtype">bool</span> <a class="code" href="classHangmanDb.html#0190e8b4f748d0720bc1d61eeb2a5f4b">HangmanDb::addUser</a>(<span class="keyword">const</span> std::wstring &amp;user, <span class="keyword">const</span> std::wstring &amp;password)
<a name="l00034"></a>00034 {
<a name="l00035"></a>00035    <span class="keywordflow">try</span> {
<a name="l00036"></a>00036       Connection con(<span class="stringliteral">"hangman"</span>, <span class="stringliteral">"localhost"</span>, <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">DbUser</a>().c_str(), <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">DbPass</a>().c_str());
<a name="l00037"></a>00037       Query q = con.query();
<a name="l00038"></a>00038       q &lt;&lt; <span class="stringliteral">"insert into users "</span>
<a name="l00039"></a>00039         &lt;&lt; <span class="stringliteral">"set user='"</span> &lt;&lt; Wt::toUTF8(user) &lt;&lt; <span class="stringliteral">"', pass=MD5('"</span>
<a name="l00040"></a>00040         &lt;&lt; Wt::toUTF8(password) &lt;&lt; <span class="stringliteral">"'), numgames=0, score=0, lastseen=now()"</span>;
<a name="l00041"></a>00041       q.store();
<a name="l00042"></a>00042       <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l00043"></a>00043    } <span class="keywordflow">catch</span>(Exception &amp;e) {
<a name="l00044"></a>00044       std::cerr &lt;&lt; <span class="stringliteral">"Database exception!\n"</span>;
<a name="l00045"></a>00045       std::cerr &lt;&lt; e.what() &lt;&lt; std::endl;
<a name="l00046"></a>00046       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l00047"></a>00047    }
<a name="l00048"></a>00048 }
<a name="l00049"></a>00049 
<a name="l00050"></a><a class="code" href="classHangmanDb.html#f64e7b180549bdf218992a1b37ab0549">00050</a> <span class="keywordtype">bool</span> <a class="code" href="classHangmanDb.html#f64e7b180549bdf218992a1b37ab0549">HangmanDb::validLogin</a>(<span class="keyword">const</span> std::wstring &amp;user, <span class="keyword">const</span> std::wstring &amp;pass)
<a name="l00051"></a>00051 {
<a name="l00052"></a>00052    <span class="keywordflow">try</span> {
<a name="l00053"></a>00053       Connection con(<span class="stringliteral">"hangman"</span>, <span class="stringliteral">"localhost"</span>, <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">DbUser</a>().c_str(), <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">DbPass</a>().c_str());
<a name="l00054"></a>00054       Query q = con.query();
<a name="l00055"></a>00055       q &lt;&lt; <span class="stringliteral">"select user,pass from users where "</span>
<a name="l00056"></a>00056         &lt;&lt; <span class="stringliteral">"user='"</span> &lt;&lt; Wt::toUTF8(user)
<a name="l00057"></a>00057         &lt;&lt; <span class="stringliteral">"' and pass=MD5('"</span> &lt;&lt; Wt::toUTF8(pass) &lt;&lt; <span class="stringliteral">"')"</span>;
<a name="l00058"></a>00058       StoreQueryResult res = q.store();
<a name="l00059"></a>00059       <span class="keywordflow">return</span> res.size() &gt; 0;
<a name="l00060"></a>00060    } <span class="keywordflow">catch</span>(Exception &amp;e) {
<a name="l00061"></a>00061       std::cerr &lt;&lt; <span class="stringliteral">"Database exception!\n"</span>;
<a name="l00062"></a>00062       std::cerr &lt;&lt; e.what() &lt;&lt; std::endl;
<a name="l00063"></a>00063       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l00064"></a>00064    }
<a name="l00065"></a>00065 }
<a name="l00066"></a>00066 
<a name="l00067"></a><a class="code" href="classHangmanDb.html#3f039b9d0d96ca0ac8baa7bbff12f0db">00067</a> <span class="keywordtype">void</span> <a class="code" href="classHangmanDb.html#3f039b9d0d96ca0ac8baa7bbff12f0db">HangmanDb::addToScore</a>(<span class="keyword">const</span> std::wstring &amp;user, <span class="keywordtype">int</span> delta)
<a name="l00068"></a>00068 {
<a name="l00069"></a>00069    <span class="keywordflow">try</span> {
<a name="l00070"></a>00070       Connection con(<span class="stringliteral">"hangman"</span>, <span class="stringliteral">"localhost"</span>, <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">DbUser</a>().c_str(), <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">DbPass</a>().c_str());
<a name="l00071"></a>00071       Query q = con.query();
<a name="l00072"></a>00072       q &lt;&lt; <span class="stringliteral">"update users set score=(score+"</span> &lt;&lt; delta &lt;&lt; <span class="stringliteral">"), "</span>
<a name="l00073"></a>00073         &lt;&lt; <span class="stringliteral">"numgames=(numgames+1), lastseen=now() "</span>
<a name="l00074"></a>00074         &lt;&lt; <span class="stringliteral">"where user='"</span> &lt;&lt; Wt::toUTF8(user) &lt;&lt; <span class="stringliteral">"'"</span>;
<a name="l00075"></a>00075       StoreQueryResult res = q.store();
<a name="l00076"></a>00076    } <span class="keywordflow">catch</span>(Exception &amp;e) {
<a name="l00077"></a>00077       std::cerr &lt;&lt; <span class="stringliteral">"Database exception!\n"</span>;
<a name="l00078"></a>00078       std::cerr &lt;&lt; e.what() &lt;&lt; std::endl;
<a name="l00079"></a>00079    }
<a name="l00080"></a>00080 }
<a name="l00081"></a>00081 
<a name="l00082"></a><a class="code" href="classHangmanDb.html#76b21f25db8d1939fcc57d9eb2e6d5c0">00082</a> std::vector&lt;HangmanDb::Score&gt; <a class="code" href="classHangmanDb.html#76b21f25db8d1939fcc57d9eb2e6d5c0">HangmanDb::getHighScores</a>(<span class="keywordtype">int</span> top)
<a name="l00083"></a>00083 {
<a name="l00084"></a>00084    std::vector&lt;HangmanDb::Score&gt; retval;
<a name="l00085"></a>00085    <span class="keywordflow">try</span> {
<a name="l00086"></a>00086       Connection con(<span class="stringliteral">"hangman"</span>, <span class="stringliteral">"localhost"</span>, <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">DbUser</a>().c_str(), <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">DbPass</a>().c_str());
<a name="l00087"></a>00087       Query q = con.query();
<a name="l00088"></a>00088       q &lt;&lt; <span class="stringliteral">"select user, numgames, score, lastseen from users "</span>
<a name="l00089"></a>00089         &lt;&lt; <span class="stringliteral">"order by score desc "</span>
<a name="l00090"></a>00090         &lt;&lt; <span class="stringliteral">"limit "</span> &lt;&lt; top;
<a name="l00091"></a>00091       StoreQueryResult res = q.store();
<a name="l00092"></a>00092 
<a name="l00093"></a>00093       <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i = 0; i &lt; res.size(); ++i) {
<a name="l00094"></a>00094          <span class="keyword">struct </span><a class="code" href="structHangmanDb_1_1Score.html">Score</a> s;
<a name="l00095"></a>00095          s.<a class="code" href="structHangmanDb_1_1Score.html#13f13771f8ae33f3373d0659ddadc5e2">number</a> = i + 1;
<a name="l00096"></a>00096          s.<a class="code" href="structHangmanDb_1_1Score.html#3959752a946d56b3e48acd27b6229d21">user</a> = Wt::fromUTF8((std::string)res.at(i)[<span class="stringliteral">"user"</span>]);
<a name="l00097"></a>00097          s.<a class="code" href="structHangmanDb_1_1Score.html#602fc68f5609343eb9ed20b5bca2c2b5">numgames</a> = res.at(i)[<span class="stringliteral">"numgames"</span>];
<a name="l00098"></a>00098          s.<a class="code" href="structHangmanDb_1_1Score.html#26c5fb07c6654e5122e2a98659a857d8">score</a> = res.at(i)[<span class="stringliteral">"score"</span>];
<a name="l00099"></a>00099          s.<a class="code" href="structHangmanDb_1_1Score.html#2d61f30856924ebf175209d1903708f1">lastseen</a> = Wt::fromUTF8((std::string)res.at(i)[<span class="stringliteral">"lastseen"</span>]);
<a name="l00100"></a>00100          retval.push_back(s);
<a name="l00101"></a>00101       }
<a name="l00102"></a>00102    } <span class="keywordflow">catch</span>(Exception &amp;e) {
<a name="l00103"></a>00103       std::cerr &lt;&lt; <span class="stringliteral">"Database exception!\n"</span>;
<a name="l00104"></a>00104       std::cerr &lt;&lt; e.what() &lt;&lt; std::endl;
<a name="l00105"></a>00105    }
<a name="l00106"></a>00106    <span class="keywordflow">return</span> retval;
<a name="l00107"></a>00107 }
<a name="l00108"></a>00108 
<a name="l00109"></a><a class="code" href="classHangmanDb.html#3b623adea086ec71342220dd4f2359f7">00109</a> <a class="code" href="structHangmanDb_1_1Score.html">HangmanDb::Score</a> <a class="code" href="classHangmanDb.html#3b623adea086ec71342220dd4f2359f7">HangmanDb::getUserPosition</a>(<span class="keyword">const</span> std::wstring &amp;user)
<a name="l00110"></a>00110 {
<a name="l00111"></a>00111    <span class="keywordflow">try</span> {
<a name="l00112"></a>00112       Connection con(<span class="stringliteral">"hangman"</span>, <span class="stringliteral">"localhost"</span>, <a class="code" href="classHangmanDb.html#36c9d6aeaee2c97bbeb5e8c8b6a5bba4">DbUser</a>().c_str(), <a class="code" href="classHangmanDb.html#c085430ceb59cac54dfd5fa90586741a">DbPass</a>().c_str());
<a name="l00113"></a>00113       Query q = con.query();
<a name="l00114"></a>00114       q &lt;&lt; <span class="stringliteral">"select user, numgames, score, lastseen from users "</span>
<a name="l00115"></a>00115         &lt;&lt; <span class="stringliteral">"order by score desc"</span>;
<a name="l00116"></a>00116       StoreQueryResult res = q.store();
<a name="l00117"></a>00117 
<a name="l00118"></a>00118       <span class="comment">// There MUST be a better way to do this...</span>
<a name="l00119"></a>00119       <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i = 0; i &lt; res.size(); ++i) {
<a name="l00120"></a>00120          <span class="keywordflow">if</span>(Wt::fromUTF8((std::string)res.at(i)[<span class="stringliteral">"user"</span>]) == user) {
<a name="l00121"></a>00121             <span class="keyword">struct </span><a class="code" href="structHangmanDb_1_1Score.html">Score</a> s;
<a name="l00122"></a>00122             s.<a class="code" href="structHangmanDb_1_1Score.html#13f13771f8ae33f3373d0659ddadc5e2">number</a> = i + 1;
<a name="l00123"></a>00123             s.<a class="code" href="structHangmanDb_1_1Score.html#3959752a946d56b3e48acd27b6229d21">user</a> = Wt::fromUTF8((std::string)res.at(i)[<span class="stringliteral">"user"</span>]);
<a name="l00124"></a>00124             s.<a class="code" href="structHangmanDb_1_1Score.html#602fc68f5609343eb9ed20b5bca2c2b5">numgames</a> = res.at(i)[<span class="stringliteral">"numgames"</span>];
<a name="l00125"></a>00125             s.<a class="code" href="structHangmanDb_1_1Score.html#26c5fb07c6654e5122e2a98659a857d8">score</a> = res.at(i)[<span class="stringliteral">"score"</span>];
<a name="l00126"></a>00126             s.<a class="code" href="structHangmanDb_1_1Score.html#2d61f30856924ebf175209d1903708f1">lastseen</a> = Wt::fromUTF8((std::string)res.at(i)[<span class="stringliteral">"lastseen"</span>]);
<a name="l00127"></a>00127             <span class="keywordflow">return</span> s;
<a name="l00128"></a>00128          }
<a name="l00129"></a>00129       }
<a name="l00130"></a>00130    } <span class="keywordflow">catch</span>(Exception &amp;e) {
<a name="l00131"></a>00131       std::cerr &lt;&lt; <span class="stringliteral">"Database exception!\n"</span>;
<a name="l00132"></a>00132       std::cerr &lt;&lt; e.what() &lt;&lt; std::endl;
<a name="l00133"></a>00133    }
<a name="l00134"></a>00134    <a class="code" href="structHangmanDb_1_1Score.html">Score</a> s;
<a name="l00135"></a>00135    s.<a class="code" href="structHangmanDb_1_1Score.html#13f13771f8ae33f3373d0659ddadc5e2">number</a>=0;
<a name="l00136"></a>00136    s.<a class="code" href="structHangmanDb_1_1Score.html#3959752a946d56b3e48acd27b6229d21">user</a>=L<span class="stringliteral">"DBase error"</span>;
<a name="l00137"></a>00137    s.<a class="code" href="structHangmanDb_1_1Score.html#602fc68f5609343eb9ed20b5bca2c2b5">numgames</a> = s.<a class="code" href="structHangmanDb_1_1Score.html#26c5fb07c6654e5122e2a98659a857d8">score</a> = 0;
<a name="l00138"></a>00138    <span class="keywordflow">return</span> s;
<a name="l00139"></a>00139 }
</pre></div></div>
<hr size="1"><address style="align: right;"><small>
Generated on Fri Mar 26 17:12:12 2010 for <a href="http://www.webtoolkit.eu/wt/">Wt</a> by&nbsp;<a href="http://www.doxygen.org/index.html"><img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6</small></address>
</body>
</html>