toolkit/components/passwordmgr/nsILoginMetaInfo.idl
author Mihai Alexandru Michis <malexandru@mozilla.com>
Thu, 24 Sep 2020 10:52:40 +0300
changeset 550100 7b98b01d238e1581d109397b51ba3356568e6566
parent 470303 0f12aebacdd6845bed9e7f2cbf8e33dbd9b50b8b
permissions -rw-r--r--
Backed out 2 changesets (bug 1666373, bug 1665802) for causing gv-junit and xpcshell failures. Backed out changeset 296c8ba967c9 (bug 1666373) Backed out changeset c1fe3374ab97 (bug 1665802)

/* 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"

/**
 * An object containing metainfo for a login stored by the login manager.
 *
 * Code using login manager can generally ignore this interface. When adding
 * logins, default value will be created. When modifying logins, these
 * properties will be unchanged unless a change is explicitly requested [by
 * using modifyLogin() with a nsIPropertyBag]. When deleting a login or
 * comparing logins, these properties are ignored.
 */
[scriptable, uuid(20d8eb40-c494-497f-b2a6-aaa32f807ebd)]
interface nsILoginMetaInfo : nsISupports {
  /**
   * The GUID to uniquely identify the login. This can be any arbitrary
   * string, but a format as created by nsIUUIDGenerator is recommended.
   * For example, "{d4e1a1f6-5ea0-40ee-bff5-da57982f21cf}"
   *
   * addLogin will generate a random value unless a value is provided.
   *
   * addLogin and modifyLogin will throw if the GUID already exists.
   */
  attribute AString guid;

  /**
   * The time, in Unix Epoch milliseconds, when the login was first created.
   */
  attribute unsigned long long timeCreated;

  /**
   * The time, in Unix Epoch milliseconds, when the login was last submitted
   * in a form or used to begin an HTTP auth session.
   */
  attribute unsigned long long timeLastUsed;

  /**
   * The time, in Unix Epoch milliseconds, when the login was last modified.
   *
   * Contrary to what the name may suggest, this attribute takes into account
   * not only the password but also the username attribute.
   */
  attribute unsigned long long timePasswordChanged;

  /**
   * The number of times the login was submitted in a form or used to begin
   * an HTTP auth session.
   */
  attribute unsigned long timesUsed;
};