diff options
-rw-r--r-- | content/child/webcrypto/jwk.cc | 10 | ||||
-rw-r--r-- | content/child/webcrypto/status.cc | 30 | ||||
-rw-r--r-- | content/child/webcrypto/status.h | 25 | ||||
-rw-r--r-- | content/child/webcrypto/test/aes_cbc_unittest.cc | 14 | ||||
-rw-r--r-- | content/child/webcrypto/test/status_unittest.cc | 8 | ||||
-rw-r--r-- | content/child/webcrypto/webcrypto_util.cc | 2 |
6 files changed, 48 insertions, 41 deletions
diff --git a/content/child/webcrypto/jwk.cc b/content/child/webcrypto/jwk.cc index b0073cc..d6729ca 100644 --- a/content/child/webcrypto/jwk.cc +++ b/content/child/webcrypto/jwk.cc @@ -345,9 +345,9 @@ Status JwkReader::GetString(const std::string& member_name, std::string* result) const { base::Value* value = NULL; if (!dict_->Get(member_name, &value)) - return Status::ErrorJwkPropertyMissing(member_name); + return Status::ErrorJwkMemberMissing(member_name); if (!value->GetAsString(result)) - return Status::ErrorJwkPropertyWrongType(member_name, "string"); + return Status::ErrorJwkMemberWrongType(member_name, "string"); return Status::Success(); } @@ -360,7 +360,7 @@ Status JwkReader::GetOptionalString(const std::string& member_name, return Status::Success(); if (!value->GetAsString(result)) - return Status::ErrorJwkPropertyWrongType(member_name, "string"); + return Status::ErrorJwkMemberWrongType(member_name, "string"); *member_exists = true; return Status::Success(); @@ -375,7 +375,7 @@ Status JwkReader::GetOptionalList(const std::string& member_name, return Status::Success(); if (!value->GetAsList(result)) - return Status::ErrorJwkPropertyWrongType(member_name, "list"); + return Status::ErrorJwkMemberWrongType(member_name, "list"); *member_exists = true; return Status::Success(); @@ -421,7 +421,7 @@ Status JwkReader::GetOptionalBool(const std::string& member_name, return Status::Success(); if (!value->GetAsBoolean(result)) - return Status::ErrorJwkPropertyWrongType(member_name, "boolean"); + return Status::ErrorJwkMemberWrongType(member_name, "boolean"); *member_exists = true; return Status::Success(); diff --git a/content/child/webcrypto/status.cc b/content/child/webcrypto/status.cc index a7afdb3..9910cff 100644 --- a/content/child/webcrypto/status.cc +++ b/content/child/webcrypto/status.cc @@ -6,6 +6,10 @@ namespace content { +// TODO(eroman): The error text for JWK uses the terminology "property" however +// it should instead call it a "member". Changing this needs to coordinate with +// the Blink LayoutTests as they depend on the old names. + namespace webcrypto { bool Status::IsError() const { @@ -33,22 +37,23 @@ Status Status::ErrorJwkNotDictionary() { "JWK input could not be parsed to a JSON dictionary"); } -Status Status::ErrorJwkPropertyMissing(const std::string& property) { - return Status(blink::WebCryptoErrorTypeData, - "The required JWK property \"" + property + "\" was missing"); +Status Status::ErrorJwkMemberMissing(const std::string& member_name) { + return Status( + blink::WebCryptoErrorTypeData, + "The required JWK property \"" + member_name + "\" was missing"); } -Status Status::ErrorJwkPropertyWrongType(const std::string& property, - const std::string& expected_type) { +Status Status::ErrorJwkMemberWrongType(const std::string& member_name, + const std::string& expected_type) { return Status( blink::WebCryptoErrorTypeData, - "The JWK property \"" + property + "\" must be a " + expected_type); + "The JWK property \"" + member_name + "\" must be a " + expected_type); } -Status Status::ErrorJwkBase64Decode(const std::string& property) { +Status Status::ErrorJwkBase64Decode(const std::string& member_name) { return Status( blink::WebCryptoErrorTypeData, - "The JWK property \"" + property + "\" could not be base64 decoded"); + "The JWK property \"" + member_name + "\" could not be base64 decoded"); } Status Status::ErrorJwkExtInconsistent() { @@ -105,15 +110,16 @@ Status Status::ErrorJwkIncorrectKeyLength() { "of key data for the given algorithm."); } -Status Status::ErrorJwkEmptyBigInteger(const std::string& property) { +Status Status::ErrorJwkEmptyBigInteger(const std::string& member_name) { return Status(blink::WebCryptoErrorTypeData, - "The JWK \"" + property + "\" property was empty."); + "The JWK \"" + member_name + "\" property was empty."); } -Status Status::ErrorJwkBigIntegerHasLeadingZero(const std::string& property) { +Status Status::ErrorJwkBigIntegerHasLeadingZero( + const std::string& member_name) { return Status( blink::WebCryptoErrorTypeData, - "The JWK \"" + property + "\" property contained a leading zero."); + "The JWK \"" + member_name + "\" property contained a leading zero."); } Status Status::ErrorJwkDuplicateKeyOps() { diff --git a/content/child/webcrypto/status.h b/content/child/webcrypto/status.h index 4c1aae6..17735c3 100644 --- a/content/child/webcrypto/status.h +++ b/content/child/webcrypto/status.h @@ -54,16 +54,16 @@ class CONTENT_EXPORT Status { // convertable to a dictionary. static Status ErrorJwkNotDictionary(); - // The required property |property| was missing. - static Status ErrorJwkPropertyMissing(const std::string& property); + // The required JWK member |member_name| was missing. + static Status ErrorJwkMemberMissing(const std::string& member_name); - // The property |property| was not of type |expected_type|. - static Status ErrorJwkPropertyWrongType(const std::string& property, - const std::string& expected_type); + // The JWK member |member_name| was not of type |expected_type|. + static Status ErrorJwkMemberWrongType(const std::string& member_name, + const std::string& expected_type); - // The property |property| was a string, however could not be successfully - // base64 decoded. - static Status ErrorJwkBase64Decode(const std::string& property); + // The JWK member |member_name| was a string, however could not be + // successfully base64 decoded. + static Status ErrorJwkBase64Decode(const std::string& member_name); // The "ext" parameter was specified but was // incompatible with the value requested by the Web Crypto call. @@ -103,13 +103,14 @@ class CONTENT_EXPORT Status { // given that is an error. static Status ErrorJwkIncorrectKeyLength(); - // The JWK property |property| is supposed to represent a big-endian unsigned + // The JWK member |member_name| is supposed to represent a big-endian unsigned // integer, however was the empty string. - static Status ErrorJwkEmptyBigInteger(const std::string& property); + static Status ErrorJwkEmptyBigInteger(const std::string& member_name); - // The big-endian unsigned integer |property| contained leading zeros. This + // The big-endian unsigned integer |member_name| contained leading zeros. This // violates the JWA requirement that such octet strings be minimal. - static Status ErrorJwkBigIntegerHasLeadingZero(const std::string& property); + static Status ErrorJwkBigIntegerHasLeadingZero( + const std::string& member_name); // The key_ops lists a usage more than once. static Status ErrorJwkDuplicateKeyOps(); diff --git a/content/child/webcrypto/test/aes_cbc_unittest.cc b/content/child/webcrypto/test/aes_cbc_unittest.cc index 95a6d2c..c6fe95d 100644 --- a/content/child/webcrypto/test/aes_cbc_unittest.cc +++ b/content/child/webcrypto/test/aes_cbc_unittest.cc @@ -557,7 +557,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkMissingKty) { base::DictionaryValue dict; dict.SetString("k", "GADWrMRHwQfoNaXU5fZvTg=="); EXPECT_EQ( - Status::ErrorJwkPropertyMissing("kty"), + Status::ErrorJwkMemberMissing("kty"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, @@ -574,7 +574,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkKtyWrongType) { dict.SetString("k", "GADWrMRHwQfoNaXU5fZvTg=="); EXPECT_EQ( - Status::ErrorJwkPropertyWrongType("kty", "string"), + Status::ErrorJwkMemberWrongType("kty", "string"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, @@ -610,7 +610,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkUseWrongType) { dict.SetString("k", "GADWrMRHwQfoNaXU5fZvTg=="); EXPECT_EQ( - Status::ErrorJwkPropertyWrongType("use", "string"), + Status::ErrorJwkMemberWrongType("use", "string"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, @@ -628,7 +628,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkExtWrongType) { dict.SetString("k", "GADWrMRHwQfoNaXU5fZvTg=="); EXPECT_EQ( - Status::ErrorJwkPropertyWrongType("ext", "boolean"), + Status::ErrorJwkMemberWrongType("ext", "boolean"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, @@ -646,7 +646,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkKeyOpsWrongType) { dict.SetBoolean("key_ops", true); EXPECT_EQ( - Status::ErrorJwkPropertyWrongType("key_ops", "list"), + Status::ErrorJwkMemberWrongType("key_ops", "list"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, @@ -718,7 +718,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkNonStringKeyOp) { dict.Set("key_ops", key_ops); key_ops->AppendString("encrypt"); key_ops->AppendInteger(3); - EXPECT_EQ(Status::ErrorJwkPropertyWrongType("key_ops[1]", "string"), + EXPECT_EQ(Status::ErrorJwkMemberWrongType("key_ops[1]", "string"), ImportKeyJwkFromDict(dict, algorithm, false, usages, &key)); } @@ -730,7 +730,7 @@ TEST(WebCryptoAesCbcTest, ImportJwkMissingK) { dict.SetString("kty", "oct"); EXPECT_EQ( - Status::ErrorJwkPropertyMissing("k"), + Status::ErrorJwkMemberMissing("k"), ImportKeyJwkFromDict(dict, CreateAlgorithm(blink::WebCryptoAlgorithmIdAesCbc), false, diff --git a/content/child/webcrypto/test/status_unittest.cc b/content/child/webcrypto/test/status_unittest.cc index 11d014e..93b4369 100644 --- a/content/child/webcrypto/test/status_unittest.cc +++ b/content/child/webcrypto/test/status_unittest.cc @@ -29,8 +29,8 @@ TEST(WebCryptoStatusTest, Basic) { EXPECT_NE(Status::Success(), Status::OperationError()); EXPECT_EQ(Status::Success(), Status::Success()); - EXPECT_EQ(Status::ErrorJwkPropertyWrongType("kty", "string"), - Status::ErrorJwkPropertyWrongType("kty", "string")); + EXPECT_EQ(Status::ErrorJwkMemberWrongType("kty", "string"), + Status::ErrorJwkMemberWrongType("kty", "string")); Status status = Status::Success(); @@ -52,13 +52,13 @@ TEST(WebCryptoStatusTest, Basic) { EXPECT_EQ("The requested operation is unsupported", status.error_details()); EXPECT_EQ(blink::WebCryptoErrorTypeNotSupported, status.error_type()); - status = Status::ErrorJwkPropertyMissing("kty"); + status = Status::ErrorJwkMemberMissing("kty"); EXPECT_TRUE(status.IsError()); EXPECT_EQ("The required JWK property \"kty\" was missing", status.error_details()); EXPECT_EQ(blink::WebCryptoErrorTypeData, status.error_type()); - status = Status::ErrorJwkPropertyWrongType("kty", "string"); + status = Status::ErrorJwkMemberWrongType("kty", "string"); EXPECT_TRUE(status.IsError()); EXPECT_EQ("The JWK property \"kty\" must be a string", status.error_details()); diff --git a/content/child/webcrypto/webcrypto_util.cc b/content/child/webcrypto/webcrypto_util.cc index 410acdd..bb4cbb9 100644 --- a/content/child/webcrypto/webcrypto_util.cc +++ b/content/child/webcrypto/webcrypto_util.cc @@ -84,7 +84,7 @@ Status GetWebCryptoUsagesFromJwkKeyOps(const base::ListValue* key_ops, for (size_t i = 0; i < key_ops->GetSize(); ++i) { std::string key_op; if (!key_ops->GetString(i, &key_op)) { - return Status::ErrorJwkPropertyWrongType( + return Status::ErrorJwkMemberWrongType( base::StringPrintf("key_ops[%d]", static_cast<int>(i)), "string"); } |