Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2527)

Unified Diff: chrome/browser/autofill/wallet/wallet_items.h

Issue 11293078: Integrating Online Wallet into Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: More fixes from code review Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/autofill/wallet/wallet_items.h
diff --git a/chrome/browser/autofill/wallet/wallet_items.h b/chrome/browser/autofill/wallet/wallet_items.h
new file mode 100644
index 0000000000000000000000000000000000000000..1bd01e23bf965c79642d600aebc6a98fa6967a02
--- /dev/null
+++ b/chrome/browser/autofill/wallet/wallet_items.h
@@ -0,0 +1,191 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_AUTOFILL_WALLET_WALLET_ITEMS_H_
+#define CHROME_BROWSER_AUTOFILL_WALLET_WALLET_ITEMS_H_
+
+#include <string>
+#include <vector>
+
+#include "base/basictypes.h"
+#include "base/logging.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/memory/scoped_vector.h"
+#include "chrome/browser/autofill/wallet/wallet_address.h"
+
+namespace base {
+class DictionaryValue;
+}
+
+namespace wallet {
+
+// WalletItems primarily serves as a container for the user's instruments and
+// address, however, it also provides a transaction id which must be used
+// throughout all API calls being made using this data. Additionally, user
+// actions may be required before a purchase can be completing using Online
Albert Bodenhamer 2012/12/05 19:22:29 typo: completed, not completing
ahutter 2012/12/05 23:37:23 Done.
+// Wallet and those actions are present in the object as well.
+class WalletItems {
+ public:
+ // Container for all information about a credit card except for it's card
+ // verfication number (CVN) and it's complete primary account number (PAN).
+ class MaskedInstrument {
+ public:
+ enum Type {
+ UNKNOWN,
+ VISA,
+ MASTER_CARD,
+ AMEX,
+ DISCOVER,
+ SOLO,
+ MAESTRO,
+ SWITCH,
Dan Beam 2012/12/05 19:34:59 nit: is there a rationale to the order of these en
ahutter 2012/12/05 23:37:23 Nope. Now alphabetized.
+ };
+ enum Status {
+ PENDING,
+ VALID,
+ DECLINED,
+ UNSUPPORTED_COUNTRY,
+ EXPIRED,
+ BILLING_INCOMPLETE,
+ // correspond to any other inapplicable reasons that do not listed above
Dan Beam 2012/12/05 19:34:59 nit: fix this comment
ahutter 2012/12/05 23:37:23 Done.
+ INAPPLICABLE,
+ };
+ MaskedInstrument(const std::string& descriptve_name,
+ Type type,
Dan Beam 2012/12/05 19:34:59 nit: why are |type| and |status| not const-ref?
ahutter 2012/12/05 23:37:23 Done.
+ std::vector<std::string> supported_currencies,
+ const std::string& last_four_digits,
+ int expiration_month,
+ int expiration_year,
+ const std::string& brand,
+ Address* address,
+ Status status,
+ const std::string& object_id);
+ ~MaskedInstrument();
+
+ // Returns null if input is invalid or a valid masked instrument. Caller
+ // owns returned pointer.
+ static MaskedInstrument* CreateMaskedInstrument(
+ const base::DictionaryValue& dictionary);
+
+ bool operator==(const MaskedInstrument& other) const;
+ bool operator!=(const MaskedInstrument& other) const;
+
+ const std::string descriptive_name() const { return descriptive_name_; }
+ Type type() const { return type_; }
+ const std::vector<std::string> supported_currencies() const {
+ return supported_currencies_;
+ }
+ const std::string last_four_digits() const { return last_four_digits_; }
+ int expiration_month() const { return expiration_month_; }
+ int expiration_year() const { return expiration_year_; }
+ const std::string brand() const { return brand_; }
+ const Address* address() const { return address_.get(); }
+ Status status() const { return status_; }
+ const std::string object_id() const { return object_id_; }
+
+ private:
+ static Type TypeFromString(const std::string& type_string);
+ static Status StatusFromString(const std::string& status_string);
+ std::string descriptive_name_;
+ Type type_;
+ std::vector<std::string> supported_currencies_;
+ std::string last_four_digits_;
+ int expiration_month_;
+ int expiration_year_;
+ std::string brand_;
+ scoped_ptr<Address> address_;
+ Status status_;
+ std::string object_id_;
+ DISALLOW_COPY_AND_ASSIGN(MaskedInstrument);
+ };
+
+ // Class representing a legal document that the user must accept before they
+ // can use Online Wallet.
+ class LegalDocument {
+ public:
+ LegalDocument(const std::string& document_id,
+ const std::string& display_name,
+ const std::string& document_body);
+ ~LegalDocument();
+
+ // Returns null if input is invalid or a valid legal document. Caller owns
+ // returned pointer.
+ static LegalDocument* CreateLegalDocument(
+ const base::DictionaryValue& dictionary);
+
+ bool operator==(const LegalDocument& other) const;
+ bool operator!=(const LegalDocument& other) const;
+
+ const std::string document_id() const { return document_id_; }
+ const std::string display_name() const { return display_name_; }
+ const std::string document_body() const { return document_body_; }
+
+ private:
+ std::string document_id_;
+ std::string display_name_;
+ std::string document_body_;
+ DISALLOW_COPY_AND_ASSIGN(LegalDocument);
+ };
+
+ WalletItems(const std::vector<std::string>& required_actions,
+ const std::string& google_transaction_id,
+ const std::string& default_instrument_id,
+ const std::string& default_address_id);
+ ~WalletItems();
+
+ // Returns null on invalid input, an empty wallet items with required
+ // actions if any are present, and a populated wallet items otherwise. Caller
+ // owns returned pointer.
+ static WalletItems* CreateWalletItems(
+ const base::DictionaryValue& dictionary);
+
+ bool operator==(const WalletItems& other) const;
+ bool operator!=(const WalletItems& other) const;
+
+ void AddInstrument(MaskedInstrument* instrument) {
+ DCHECK(instrument);
+ instruments_.push_back(instrument);
+ }
+ void AddAddress(Address* address) {
+ DCHECK(address);
+ addresses_.push_back(address);
+ }
+ void AddLegalDocument(LegalDocument* legal_document) {
+ DCHECK(legal_document);
+ legal_documents_.push_back(legal_document);
+ }
+ const std::vector<std::string> required_actions() const {
+ return required_actions_;
+ }
+ const std::string google_transaction_id() const {
+ return google_transaction_id_;
+ }
+ const std::vector<MaskedInstrument*> instruments() const {
+ return instruments_.get();
+ }
+ const std::string default_instrument_id() const {
+ return default_instrument_id_;
+ }
+ const std::vector<Address*> addresses() const { return addresses_.get(); }
+ const std::string default_address_id() const {
+ return default_address_id_;
+ }
+ const std::vector<LegalDocument*> legal_documents() const {
+ return legal_documents_.get();
+ }
+
+ private:
+ std::vector<std::string> required_actions_;
+ std::string google_transaction_id_;
+ std::string default_instrument_id_;
+ std::string default_address_id_;
+ ScopedVector<MaskedInstrument> instruments_;
+ ScopedVector<Address> addresses_;
+ ScopedVector<LegalDocument> legal_documents_;
+ DISALLOW_COPY_AND_ASSIGN(WalletItems);
+};
+
+} // end namespace wallet
+
+#endif // CHROME_BROWSER_AUTOFILL_WALLET_WALLET_ITEMS_H_

Powered by Google App Engine
This is Rietveld 408576698