Wt examples  3.3.8
Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes | List of all members
Session Class Reference

#include <Session.h>

Public Member Functions

 Session ()
 
 ~Session ()
 
Wt::Auth::AbstractUserDatabaseusers ()
 
Wt::Auth::Loginlogin ()
 
std::vector< UsertopUsers (int limit)
 
std::string userName () const
 
int findRanking ()
 
void addToScore (int s)
 

Static Public Member Functions

static void configureAuth ()
 
static const Wt::Auth::AuthServiceauth ()
 
static const Wt::Auth::AbstractPasswordServicepasswordAuth ()
 
static const std::vector< const Wt::Auth::OAuthService * > & oAuth ()
 

Private Member Functions

Wt::Dbo::ptr< Useruser () const
 

Private Attributes

Wt::Dbo::backend::Sqlite3 sqlite3_
 
Wt::Dbo::Session session_
 
UserDatabaseusers_
 
Wt::Auth::Login login_
 

Detailed Description

Definition at line 23 of file Session.h.

Constructor & Destructor Documentation

Session::Session ( )

Definition at line 95 of file Session.C.

96  : sqlite3_(WApplication::instance()->appRoot() + "hangman.db")
97 {
99  sqlite3_.setProperty("show-queries", "true");
100 
101  session_.mapClass<User>("user");
102  session_.mapClass<AuthInfo>("auth_info");
103  session_.mapClass<AuthInfo::AuthIdentityType>("auth_identity");
105 
107 
108  dbo::Transaction transaction(session_);
109  try {
111 
112  /*
113  * Add a default guest/guest account
114  */
115  Auth::User guestUser = users_->registerNew();
116  guestUser.addIdentity(Auth::Identity::LoginName, "guest");
117  myPasswordService.updatePassword(guestUser, "guest");
118 
119  Wt::log("info") << "Database created";
120  } catch (...) {
121  Wt::log("info") << "Using existing database";
122  }
123 
124  transaction.commit();
125 }
UserDatabase * users_
Definition: Session.h:50
Wt::Auth::Dbo::UserDatabase< AuthInfo > UserDatabase
Definition: Session.h:21
Definition: User.h:22
Wt::Dbo::Session session_
Definition: Session.h:49
Wt::Dbo::backend::Sqlite3 sqlite3_
Definition: Session.h:48
void setConnection(SqlConnection &connection)
void addIdentity(const std::string &provider, const WString &identity)
void mapClass(const char *tableName)
void setProperty(const std::string &name, const std::string &value)
Session::~Session ( )

Definition at line 127 of file Session.C.

128 {
129  delete users_;
130 }
UserDatabase * users_
Definition: Session.h:50

Member Function Documentation

void Session::addToScore ( int  s)

Definition at line 156 of file Session.C.

157 {
158  dbo::Transaction transaction(session_);
159 
160  dbo::ptr<User> u = user();
161  if (u) {
162  u.modify()->score += s;
163  ++u.modify()->gamesPlayed;
164  u.modify()->lastGame = WDateTime::currentDateTime();
165  }
166 
167  transaction.commit();
168 }
Wt::Dbo::ptr< User > user() const
Definition: Session.C:132
C * modify() const
Wt::WDateTime lastGame
Definition: User.h:30
Wt::Dbo::Session session_
Definition: Session.h:49
int gamesPlayed
Definition: User.h:28
long long score
Definition: User.h:29
const Auth::AuthService & Session::auth ( )
static

Definition at line 213 of file Session.C.

214 {
215  return myAuthService;
216 }
void Session::configureAuth ( )
static

Definition at line 73 of file Session.C.

74 {
75  myAuthService.setAuthTokensEnabled(true, "hangmancookie");
76  myAuthService.setEmailVerificationEnabled(true);
77 
79  verifier->addHashFunction(new Auth::BCryptHashFunction(7));
80 
81 #ifdef HAVE_CRYPT
82  // We want to still support users registered in the pre - Wt::Auth
83  // version of the hangman example
84  verifier->addHashFunction(new UnixCryptHashFunction());
85 #endif
86 
87  myPasswordService.setVerifier(verifier);
88  myPasswordService.setStrengthValidator(new Auth::PasswordStrengthValidator());
89  myPasswordService.setAttemptThrottlingEnabled(true);
90 
91  if (Auth::GoogleService::configured())
92  myOAuthServices.push_back(new Auth::GoogleService(myAuthService));
93 }
void addHashFunction(HashFunction *function)
int Session::findRanking ( )

Definition at line 192 of file Session.C.

193 {
194  dbo::Transaction transaction(session_);
195 
196  dbo::ptr<User> u = user();
197  int ranking = -1;
198 
199  if (u)
200  ranking = session_.query<int>("select distinct count(score) from user")
201  .where("score > ?").bind(u->score);
202 
203  transaction.commit();
204 
205  return ranking + 1;
206 }
Wt::Dbo::ptr< User > user() const
Definition: Session.C:132
Wt::Dbo::Session session_
Definition: Session.h:49
long long score
Definition: User.h:29
Query< Result, BindStrategy > query(const std::string &sql)
Wt::Auth::Login& Session::login ( )
inline

Definition at line 32 of file Session.h.

32 { return login_; }
Wt::Auth::Login login_
Definition: Session.h:51
const std::vector< const Auth::OAuthService * > & Session::oAuth ( )
static

Definition at line 223 of file Session.C.

224 {
225  return myOAuthServices;
226 }
const Auth::AbstractPasswordService & Session::passwordAuth ( )
static

Definition at line 218 of file Session.C.

219 {
220  return myPasswordService;
221 }
std::vector< User > Session::topUsers ( int  limit)

Definition at line 170 of file Session.C.

171 {
172  dbo::Transaction transaction(session_);
173 
174  Users top = session_.find<User>().orderBy("score desc").limit(limit);
175 
176  std::vector<User> result;
177  for (Users::const_iterator i = top.begin(); i != top.end(); ++i) {
178  dbo::ptr<User> user = *i;
179  result.push_back(*user);
180 
181  dbo::ptr<AuthInfo> auth = *user->authInfos.begin();
182  std::string name = auth->identity(Auth::Identity::LoginName).toUTF8();
183 
184  result.back().name = name;
185  }
186 
187  transaction.commit();
188 
189  return result;
190 }
Wt::Dbo::ptr< User > user() const
Definition: Session.C:132
Query< ptr< C >, BindStrategy > find(const std::string &condition=std::string())
Definition: User.h:22
static const Wt::Auth::AuthService & auth()
Definition: Session.C:213
Wt::Dbo::Session session_
Definition: Session.h:49
std::string toUTF8() const
WString identity(const std::string &provider) const
Wt::Dbo::collection< Wt::Dbo::ptr< AuthInfo > > authInfos
Definition: User.h:31
dbo::ptr< User > Session::user ( ) const
private

Definition at line 132 of file Session.C.

133 {
134  if (login_.loggedIn()) {
135  dbo::ptr<AuthInfo> authInfo = users_->find(login_.user());
136  dbo::ptr<User> user = authInfo->user();
137 
138  if (!user) {
139  user = session_.add(new User());
140  authInfo.modify()->setUser(user);
141  }
142 
143  return user;
144  } else
145  return dbo::ptr<User>();
146 }
Wt::Dbo::ptr< DboType > find(const User &user) const
UserDatabase * users_
Definition: Session.h:50
Wt::Dbo::ptr< User > user() const
Definition: Session.C:132
ptr< C > add(ptr< C > &ptr)
C * modify() const
Wt::Dbo::ptr< UserType > user() const
bool loggedIn() const
Wt::Auth::Login login_
Definition: Session.h:51
Definition: User.h:22
Wt::Dbo::Session session_
Definition: Session.h:49
void setUser(Wt::Dbo::ptr< UserType > user)
const User & user() const
std::string Session::userName ( ) const

Definition at line 148 of file Session.C.

149 {
150  if (login_.loggedIn())
151  return login_.user().identity(Auth::Identity::LoginName).toUTF8();
152  else
153  return std::string();
154 }
WString identity(const std::string &provider) const
bool loggedIn() const
Wt::Auth::Login login_
Definition: Session.h:51
std::string toUTF8() const
const User & user() const
Auth::AbstractUserDatabase & Session::users ( )

Definition at line 208 of file Session.C.

209 {
210  return *users_;
211 }
UserDatabase * users_
Definition: Session.h:50

Member Data Documentation

Wt::Auth::Login Session::login_
private

Definition at line 51 of file Session.h.

Wt::Dbo::Session Session::session_
mutableprivate

Definition at line 49 of file Session.h.

Wt::Dbo::backend::Sqlite3 Session::sqlite3_
private

Definition at line 48 of file Session.h.

UserDatabase* Session::users_
private

Definition at line 50 of file Session.h.


The documentation for this class was generated from the following files:

Generated on Mon Sep 4 2017 for the C++ Web Toolkit (Wt) by doxygen 1.8.11