summaryrefslogtreecommitdiffstats
path: root/mobile/android/services/src/main/java/org/mozilla/gecko/browserid/VerifyingPublicKey.java
blob: 74b534b90cdd59b05602c0a66e79a9314b2942a1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

package org.mozilla.gecko.browserid;

import java.security.GeneralSecurityException;

import org.mozilla.gecko.sync.ExtendedJSONObject;


public interface VerifyingPublicKey {
  /**
   * Generate a JSON representation of a public key.
   *
   * @param publicKey
   *          to represent.
   * @return JSON representation.
   */
  public ExtendedJSONObject toJSONObject();

  /**
   * Verify a signature.
   *
   * @param message
   *          to verify signature of.
   * @param signature
   *          to verify.
   * @return true if signature is a signature of message produced by the private
   *         key corresponding to this public key.
   * @throws GeneralSecurityException
   */
  public boolean verifyMessage(byte[] message, byte[] signature) throws GeneralSecurityException;
}