gsaslserverpam.h
Go to the documentation of this file.
1 //
2 // Copyright (C) 2001-2013 Graeme Walker <graeme_walker@users.sourceforge.net>
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
16 // ===
20 
21 #ifndef G_SASL_SERVER_PAM_H
22 #define G_SASL_SERVER_PAM_H
23 
24 #include "gdef.h"
25 #include "gauth.h"
26 #include "gvalid.h"
27 #include "gsecrets.h"
28 #include "gsaslserver.h"
29 #include "gexception.h"
30 #include "gaddress.h"
31 #include "gstrings.h"
32 #include "gpath.h"
33 #include <map>
34 #include <memory>
35 
37 namespace GAuth
38 {
39  class SaslServerPamImp ;
40  class SaslServerPam ;
41 }
42 
54 {
55 public:
56 
57  SaslServerPam( const Secrets & , bool ignored , bool force_one_mechanism ) ;
59 
60  virtual ~SaslServerPam() ;
62 
63  virtual bool requiresEncryption() const ;
65 
66  virtual bool active() const ;
68 
69  virtual std::string mechanisms( char sep = ' ' ) const ;
71 
72  virtual bool init( const std::string & mechanism ) ;
74 
75  virtual std::string mechanism() const ;
77 
78  virtual bool mustChallenge() const ;
80 
81  virtual std::string initialChallenge() const ;
83 
84  virtual std::string apply( const std::string & response , bool & done ) ;
86 
87  virtual bool authenticated() const ;
89 
90  virtual std::string id() const ;
92 
93  virtual bool trusted( GNet::Address ) const ;
95 
96 private:
97  SaslServerPam( const SaslServerPam & ) ; // not implemented
98  void operator=( const SaslServerPam & ) ; // not implemented
99 
100 private:
101  SaslServerPamImp * m_imp ;
102 } ;
103 
104 #endif
virtual bool trusted(GNet::Address) const
Final override from GAuth::SaslServer.
The Address class encapsulates an IP transport address.
Definition: gaddress.h:48
virtual std::string initialChallenge() const
Final override from GAuth::SaslServer.
virtual ~SaslServerPam()
Destructor.
virtual std::string mechanisms(char sep= ' ') const
Final override from GAuth::SaslServer.
virtual bool requiresEncryption() const
Final override from GAuth::SaslServer.
virtual std::string id() const
Final override from GAuth::SaslServer.
A class for implementing the server-side SASL challenge/response concept.
Definition: gsaslserver.h:77
virtual std::string apply(const std::string &response, bool &done)
Final override from GAuth::SaslServer.
A private implementation class used by GAuth::SaslServerPam.
virtual bool authenticated() const
Final override from GAuth::SaslServer.
An implementation of the SaslServer interface using PAM as the authentication mechanism.
SaslServerPam(const Secrets &, bool ignored, bool force_one_mechanism)
Constructor.
virtual std::string mechanism() const
Final override from GAuth::SaslServer.
virtual bool active() const
Final override from GAuth::SaslServer.
An interface used by GAuth::SaslServer to obtain authentication secrets.
Definition: gsaslserver.h:81
SASL authentication classes.
virtual bool mustChallenge() const
Final override from GAuth::SaslServer.
virtual bool init(const std::string &mechanism)
Final override from GAuth::SaslServer.