root/third_party/libaddressinput/chromium/cpp/include/libaddressinput/address_validator.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


// 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_

/* [<][>][^][v][top][bottom][index][help] */