1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef EXTENSIONS_BROWSER_API_CAST_CHANNEL_CAST_AUTH_UTIL_H_
6 #define EXTENSIONS_BROWSER_API_CAST_CHANNEL_CAST_AUTH_UTIL_H_
10 namespace extensions
{
12 namespace cast_channel
{
16 class DeviceAuthMessage
;
22 ERROR_PEER_CERT_EMPTY
,
23 ERROR_WRONG_PAYLOAD_TYPE
,
25 ERROR_PAYLOAD_PARSING_FAILED
,
28 ERROR_FINGERPRINT_NOT_FOUND
,
29 ERROR_CERT_PARSING_FAILED
,
30 ERROR_CERT_NOT_SIGNED_BY_TRUSTED_CA
,
31 ERROR_CANNOT_EXTRACT_PUBLIC_KEY
,
32 ERROR_SIGNED_BLOBS_MISMATCH
,
33 ERROR_UNEXPECTED_AUTH_LIBRARY_RESULT
36 enum PolicyType
{ POLICY_NONE
= 0, POLICY_AUDIO_ONLY
= 1 << 0 };
38 // Constructs a AuthResult that corresponds to success.
42 static AuthResult
CreateWithParseError(const std::string
& error_message
,
43 ErrorType error_type
);
44 static AuthResult
CreateWithNSSError(const std::string
& error_message
,
48 bool success() const { return error_type
== ERROR_NONE
; }
50 std::string error_message
;
53 unsigned int channel_policies
;
56 AuthResult(const std::string
& error_message
,
61 // Authenticates the given |challenge_reply|:
62 // 1. Signature contained in the reply is valid.
63 // 2. Certficate used to sign is rooted to a trusted CA.
64 AuthResult
AuthenticateChallengeReply(const CastMessage
& challenge_reply
,
65 const std::string
& peer_cert
);
67 // Auth-library specific implementation of cryptographic signature
68 // verification routines. Verifies that |response| contains a
69 // valid signed form of |peer_cert|.
70 AuthResult
VerifyCredentials(const AuthResponse
& response
,
71 const std::string
& peer_cert
);
73 } // namespace cast_channel
74 } // namespace core_api
75 } // namespace extensions
77 #endif // EXTENSIONS_BROWSER_API_CAST_CHANNEL_CAST_AUTH_UTIL_H_