| // Copyright (C) 2013 Google Inc. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| #ifndef I18N_ADDRESSINPUT_ADDRESS_VALIDATOR_H_ |
| #define I18N_ADDRESSINPUT_ADDRESS_VALIDATOR_H_ |
| |
| #include <libaddressinput/address_field.h> |
| #include <libaddressinput/address_problem.h> |
| #include <libaddressinput/util/scoped_ptr.h> |
| |
| #include <map> |
| #include <string> |
| #include <vector> |
| |
| namespace i18n { |
| namespace addressinput { |
| |
| class Downloader; |
| class LoadRulesDelegate; |
| class Storage; |
| struct AddressData; |
| |
| typedef std::vector<AddressProblem> AddressProblems; |
| typedef std::multimap<AddressField, AddressProblem::Type> AddressProblemFilter; |
| |
| // Validates an AddressData structure. Sample usage: |
| // class MyClass : public LoadRulesDelegate { |
| // public: |
| // MyClass() : validator_(AddressValidator::Build( |
| // scoped_ptr<Downloader>(new MyDownloader), |
| // scoped_ptr<Storage>(new MyStorage), |
| // this)) { |
| // validator_->LoadRules("US"); |
| // } |
| // |
| // virtual ~MyClass() {} |
| // |
| // virtual void OnAddressValidationRulesLoaded( |
| // const std::string& country_code, |
| // bool success) { |
| // ... |
| // } |
| // |
| // void ValidateAddress() { |
| // AddressData address; |
| // address.country_code = "US"; |
| // address.administrative_area = "CA"; |
| // AddressProblems problems; |
| // AddressProblemFilter filter; |
| // AddressValidator::Status status = |
| // validator_->ValidateAddress(address, filter, &problems); |
| // if (status == AddressValidator::SUCCESS) { |
| // Process(problems); |
| // } |
| // } |
| // |
| // private: |
| // scoped_ptr<AddressValidator> validator_; |
| // }; |
| class AddressValidator { |
| public: |
| // The status of address validation. |
| enum Status { |
| // Address validation completed successfully. Check |problems| to see if any |
| // problems were found. |
| SUCCESS, |
| |
| // The validation rules are not available, because LoadRules() was not |
| // called or failed. Reload the rules. |
| RULES_UNAVAILABLE, |
| |
| // The validation rules are being loaded. Try again later. |
| RULES_NOT_READY |
| }; |
| |
| virtual ~AddressValidator(); |
| |
| // Builds an address validator. Takes ownership of |downloader| and |storage|, |
| // which cannot be NULL. Does not take ownership of |load_rules_delegate|, |
| // which can be NULL. The caller owns the result. |
| static scoped_ptr<AddressValidator> Build( |
| scoped_ptr<Downloader> downloader, |
| scoped_ptr<Storage> storage, |
| LoadRulesDelegate* load_rules_delegate); |
| |
| // Loads the generic validation rules for |country_code| and specific rules |
| // for the country's administrative areas, localities, and dependent |
| // localities. A typical data size is 10KB. The largest is 250KB. If a country |
| // has language-specific validation rules, then these are also loaded. |
| // |
| // Example rule: |
| // https://i18napis.appspot.com/ssl-aggregate-address/data/US |
| // |
| // If the rules were loaded successfully before or are still being loaded, |
| // then does nothing. Notifies |load_rules_delegate| when the loading |
| // finishes. |
| virtual void LoadRules(const std::string& country_code) = 0; |
| |
| // Validates the |address| and populates |problems| with the validation |
| // problems, filtered according to the |filter| parameter. |
| // |
| // If the |filter| is empty, then all discovered validation problems are |
| // returned. If the |filter| contains problem elements, then only the problems |
| // in the |filter| may be returned. |
| // |
| // If the |problems| parameter is NULL, then checks whether the validation |
| // rules are available, but does not validate the |address|. |
| virtual Status ValidateAddress(const AddressData& address, |
| const AddressProblemFilter& filter, |
| AddressProblems* problems) const = 0; |
| |
| // Fills in |suggestions| for the partially typed in |user_input|, assuming |
| // the user is typing in the |focused_field|. If the number of |suggestions| |
| // is over the |suggestion_limit|, then returns no |suggestions| at all. |
| // |
| // If the |solutions| parameter is NULL, the checks whether the validation |
| // rules are available, but does not fill in suggestions. |
| // |
| // Sample user input 1: |
| // country code = "US" |
| // postal code = "90066" |
| // focused field = POSTAL_CODE |
| // suggestions limit = 1 |
| // Suggestion: |
| // [{administrative_area: "CA"}] |
| // |
| // Sample user input 2: |
| // country code = "CN" |
| // dependent locality = "Zongyang" |
| // focused field = DEPENDENT_LOCALITY |
| // suggestions limit = 10 |
| // Suggestion: |
| // [{dependent_locality: "Zongyang Xian", |
| // locality: "Anqing Shi", |
| // administrative_area: "Anhui Sheng"}] |
| virtual Status GetSuggestions( |
| const AddressData& user_input, |
| AddressField focused_field, |
| size_t suggestion_limit, |
| std::vector<AddressData>* suggestions) const = 0; |
| |
| // Canonicalizes the administrative area in |address_data|. For example, |
| // "texas" changes to "TX". Returns true on success, otherwise leaves |
| // |address_data| alone and returns false. |
| virtual bool CanonicalizeAdministrativeArea(AddressData* address_data) |
| const = 0; |
| }; |
| |
| } // namespace addressinput |
| } // namespace i18n |
| |
| #endif // I18N_ADDRESSINPUT_ADDRESS_VALIDATOR_H_ |