| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "remoting/host/pam_authorization_factory_posix.h" | 5 #include "remoting/host/pam_authorization_factory_posix.h" |
| 6 | 6 |
| 7 #include <security/pam_appl.h> | 7 #include <security/pam_appl.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/environment.h" | 11 #include "base/environment.h" |
| 12 #include "remoting/base/logging.h" | 12 #include "remoting/base/logging.h" |
| 13 #include "remoting/host/username.h" | 13 #include "remoting/host/username.h" |
| 14 #include "remoting/protocol/channel_authenticator.h" | 14 #include "remoting/protocol/channel_authenticator.h" |
| 15 #include "third_party/libjingle/source/talk/xmllite/xmlelement.h" | 15 #include "third_party/libjingle/source/talk/xmllite/xmlelement.h" |
| 16 | 16 |
| 17 namespace remoting { | 17 namespace remoting { |
| 18 | 18 |
| 19 namespace { | 19 namespace { |
| 20 class PamAuthorizer : public protocol::Authenticator { | 20 class PamAuthorizer : public protocol::Authenticator { |
| 21 public: | 21 public: |
| 22 PamAuthorizer(scoped_ptr<protocol::Authenticator> underlying); | 22 PamAuthorizer(scoped_ptr<protocol::Authenticator> underlying); |
| 23 virtual ~PamAuthorizer(); | 23 virtual ~PamAuthorizer(); |
| 24 | 24 |
| 25 // protocol::Authenticator interface. | 25 // protocol::Authenticator interface. |
| 26 virtual State state() const OVERRIDE; | 26 virtual State state() const OVERRIDE; |
| 27 virtual bool has_auth_started() const OVERRIDE; |
| 27 virtual RejectionReason rejection_reason() const OVERRIDE; | 28 virtual RejectionReason rejection_reason() const OVERRIDE; |
| 28 virtual void ProcessMessage(const buzz::XmlElement* message, | 29 virtual void ProcessMessage(const buzz::XmlElement* message, |
| 29 const base::Closure& resume_callback) OVERRIDE; | 30 const base::Closure& resume_callback) OVERRIDE; |
| 30 virtual scoped_ptr<buzz::XmlElement> GetNextMessage() OVERRIDE; | 31 virtual scoped_ptr<buzz::XmlElement> GetNextMessage() OVERRIDE; |
| 31 virtual scoped_ptr<protocol::ChannelAuthenticator> | 32 virtual scoped_ptr<protocol::ChannelAuthenticator> |
| 32 CreateChannelAuthenticator() const OVERRIDE; | 33 CreateChannelAuthenticator() const OVERRIDE; |
| 33 | 34 |
| 34 private: | 35 private: |
| 35 void MaybeCheckLocalLogin(); | 36 void MaybeCheckLocalLogin(); |
| 36 bool IsLocalLoginAllowed(); | 37 bool IsLocalLoginAllowed(); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 55 } | 56 } |
| 56 | 57 |
| 57 protocol::Authenticator::State PamAuthorizer::state() const { | 58 protocol::Authenticator::State PamAuthorizer::state() const { |
| 58 if (local_login_status_ == DISALLOWED) { | 59 if (local_login_status_ == DISALLOWED) { |
| 59 return REJECTED; | 60 return REJECTED; |
| 60 } else { | 61 } else { |
| 61 return underlying_->state(); | 62 return underlying_->state(); |
| 62 } | 63 } |
| 63 } | 64 } |
| 64 | 65 |
| 66 bool PamAuthorizer::has_auth_started() const { |
| 67 CHECK(underlying_); |
| 68 return underlying_->has_auth_started(); |
| 69 } |
| 70 |
| 65 protocol::Authenticator::RejectionReason | 71 protocol::Authenticator::RejectionReason |
| 66 PamAuthorizer::rejection_reason() const { | 72 PamAuthorizer::rejection_reason() const { |
| 67 if (local_login_status_ == DISALLOWED) { | 73 if (local_login_status_ == DISALLOWED) { |
| 68 return INVALID_CREDENTIALS; | 74 return INVALID_CREDENTIALS; |
| 69 } else { | 75 } else { |
| 70 return underlying_->rejection_reason(); | 76 return underlying_->rejection_reason(); |
| 71 } | 77 } |
| 72 } | 78 } |
| 73 | 79 |
| 74 void PamAuthorizer::ProcessMessage(const buzz::XmlElement* message, | 80 void PamAuthorizer::ProcessMessage(const buzz::XmlElement* message, |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 165 const std::string& remote_jid, | 171 const std::string& remote_jid, |
| 166 const buzz::XmlElement* first_message) { | 172 const buzz::XmlElement* first_message) { |
| 167 scoped_ptr<protocol::Authenticator> authenticator( | 173 scoped_ptr<protocol::Authenticator> authenticator( |
| 168 underlying_->CreateAuthenticator(local_jid, remote_jid, first_message)); | 174 underlying_->CreateAuthenticator(local_jid, remote_jid, first_message)); |
| 169 return scoped_ptr<protocol::Authenticator>( | 175 return scoped_ptr<protocol::Authenticator>( |
| 170 new PamAuthorizer(authenticator.Pass())); | 176 new PamAuthorizer(authenticator.Pass())); |
| 171 } | 177 } |
| 172 | 178 |
| 173 | 179 |
| 174 } // namespace remoting | 180 } // namespace remoting |
| OLD | NEW |