diff -r 000000000000 -r 6474c204b198 netwerk/base/public/nsISecretDecoderRing.idl --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/netwerk/base/public/nsISecretDecoderRing.idl Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,66 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* 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/. */ + +#include "nsISupports.idl" + +/** + * Buffer type - for storing 8-bit octet values. + */ +[ptr] native buffer(unsigned char); + +[scriptable, uuid(0EC80360-075C-11d4-9FD4-00C04F1B83D8)] +interface nsISecretDecoderRing: nsISupports { + + /** + * Encrypt a buffer - callable only from C++. + * + * @return The length of the data in the output buffer. + */ + [noscript] long encrypt(in buffer data, in long dataLen, out buffer result); + + /** + * Decrypt a buffer - callable only from C++. + * + * @return The length of the data in the output buffer. + */ + [noscript] long decrypt(in buffer data, in long dataLen, out buffer result); + + /** + * Encrypt nul-terminated string to BASE64 output. + */ + string encryptString(in string text); + + /** + * Decrypt BASE64 input to nul-terminated string output. There is + * no check for embedded nul values in the decrypted output. + */ + string decryptString(in string crypt); + + /** + * Prompt the user to change the password on the SDR key. + */ + void changePassword(); + + /** + * Logout of the security device that protects the SDR key. + */ + void logout(); + + /** + * Logout of the security device that protects the SDR key and tear + * down authenticated objects. + */ + void logoutAndTeardown(); +}; + +/** + * Configuration interface for the Secret Decoder Ring + * - this interface allows setting the window that will be + * used as parent for dialog windows (such as password prompts) + */ +[scriptable, uuid(01D8C0F0-0CCC-11d4-9FDD-000064657374)] +interface nsISecretDecoderRingConfig: nsISupports { + void setWindow(in nsISupports w); +};