Chromium Code Reviews| Index: Source/modules/credentialmanager/CredentialsContainer.cpp |
| diff --git a/Source/modules/credentialmanager/CredentialsContainer.cpp b/Source/modules/credentialmanager/CredentialsContainer.cpp |
| index 2d99b217bd655653874452fc07320a4fd7e2c457..4e17565ce071ff2178fe18bdb98df2390753d929 100644 |
| --- a/Source/modules/credentialmanager/CredentialsContainer.cpp |
| +++ b/Source/modules/credentialmanager/CredentialsContainer.cpp |
| @@ -14,9 +14,68 @@ |
| #include "modules/credentialmanager/Credential.h" |
| #include "platform/weborigin/SecurityOrigin.h" |
| #include "public/platform/Platform.h" |
| +#include "public/platform/WebCredential.h" |
| +#include "public/platform/WebCredentialManager.h" |
| +#include "public/platform/WebCredentialManagerError.h" |
| namespace blink { |
| +static void rejectDueToCredentialManagerError(PassRefPtr<ScriptPromiseResolver> resolver, WebCredentialManagerError* reason) |
| +{ |
| + |
| + switch (reason->errorType) { |
| + case WebCredentialManagerError::DisabledErrorType: |
| + resolver->reject(DOMException::create(InvalidStateError, "The credential manager is disabled.")); |
| + break; |
| + case WebCredentialManagerError::UnknownErrorType: |
| + resolver->reject(DOMException::create(NotReadableError, "An unknown error occured while talking to the credential manager.")); |
| + break; |
|
tkent
2014/08/11 08:43:50
Will the break-then-ASSERT_NO_REACHED work well?
Mike West
2014/08/11 09:13:40
You're right, this is still prototypey-enough that
|
| + }; |
|
tkent
2014/08/11 08:43:50
; is unnecessary.
Mike West
2014/08/11 09:13:40
Done.
|
| + ASSERT_NOT_REACHED(); |
| + resolver->reject(DOMException::create(InvalidStateError)); |
| +} |
| + |
| +class NotificationCallbacks : public WebCredentialManager::NotificationCallbacks { |
|
yhirano
2014/08/11 08:58:48
How about enclosing this class with an unnamed nam
|
| + WTF_MAKE_NONCOPYABLE(NotificationCallbacks); |
| +public: |
| + explicit NotificationCallbacks(PassRefPtr<ScriptPromiseResolver> resolver) : m_resolver(resolver) { } |
| + virtual ~NotificationCallbacks() { } |
| + |
| + virtual void onSuccess() OVERRIDE |
| + { |
| + m_resolver->resolve(); |
| + } |
| + |
| + virtual void onError(WebCredentialManagerError* reason) OVERRIDE |
|
yhirano
2014/08/11 08:58:48
IIRC WebCallbacks handler parameter ownership is t
Mike West
2014/08/11 09:13:40
Hrm. My impression was that CallbackPromiseAdaptor
yhirano
2014/08/12 06:55:28
OK, I see.
|
| + { |
| + rejectDueToCredentialManagerError(m_resolver, reason); |
| + } |
| + |
| +private: |
| + const RefPtr<ScriptPromiseResolver> m_resolver; |
| +}; |
| + |
| +class RequestCallbacks : public WebCredentialManager::RequestCallbacks { |
|
yhirano
2014/08/11 08:58:48
ditto
|
| + WTF_MAKE_NONCOPYABLE(RequestCallbacks); |
| +public: |
| + explicit RequestCallbacks(PassRefPtr<ScriptPromiseResolver> resolver) : m_resolver(resolver) { } |
| + virtual ~RequestCallbacks() { } |
| + |
| + virtual void onSuccess(WebCredential* credential) OVERRIDE |
|
yhirano
2014/08/11 08:58:48
ditto
|
| + { |
| + m_resolver->resolve(Credential::create(credential->id(), credential->name(), credential->avatarURL())); |
| + } |
| + |
| + virtual void onError(WebCredentialManagerError* reason) OVERRIDE |
|
yhirano
2014/08/11 08:58:48
ditto
|
| + { |
| + rejectDueToCredentialManagerError(m_resolver, reason); |
| + } |
| + |
| +private: |
| + const RefPtr<ScriptPromiseResolver> m_resolver; |
| +}; |
| + |
| + |
| CredentialsContainer* CredentialsContainer::create() |
| { |
| return new CredentialsContainer(); |