/*############################################################################
  # Copyright 2016-2017 Intel Corporation
  #
  # 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 EPID_VERIFIER_1_1_SRC_CONTEXT_H_
#define EPID_VERIFIER_1_1_SRC_CONTEXT_H_
/*!
 * \file
 * \brief Intel(R) EPID 1.1 Verifier context interface.
 */
#include "epid/common/1.1/src/commitment.h"
#include "epid/common/1.1/src/epid11params.h"
#include "epid/common/1.1/src/grouppubkey.h"
#include "epid/common/math/ecgroup.h"
#include "epid/common/math/finitefield.h"

/// Verifier context definition
struct Epid11VerifierCtx {
  Epid11GroupPubKey_* pub_key;  ///< Group public key
  /// Verifier pre-computation
  FfElement* e12;  ///< an element in GT
  FfElement* e22;  ///< an element in GT
  FfElement* e2w;  ///< an element in GT
  /// Revocation lists
  Epid11PrivRl const* priv_rl;    ///< Private key based RL - not owned
  Epid11SigRl const* sig_rl;      ///< Signature based RL - not owned
  Epid11GroupRl const* group_rl;  ///< Group RL - not owned

  Epid11Params_* epid11_params;      ///< Intel(R) EPID 1.1 params
  Epid11CommitValues commit_values;  ///< Hashed values to create commitment
  uint8_t* basename;                 ///< Basename to use - NULL for random base
  size_t basename_len;               ///< Number of bytes in basename
  EcPoint* basename_hash;            ///< Epid11EcHash of the basename
};

#endif  // EPID_VERIFIER_1_1_SRC_CONTEXT_H_