netwerk/dns/nsIDNSListener.idl
author Georg Fritzsche <georg.fritzsche@googlemail.com>
Wed, 15 Feb 2017 17:00:41 +0100
changeset 345334 bc61502be42e77e1dac46183c7a9075768f8292d
parent 201660 6dd877592b3569d9dda4d58630d6ee4eb9cbca35
child 436992 7aa742bff8fbae4338e258a4477d5397d0d6f7ad
permissions -rw-r--r--
Bug 1313326 - Part 4: Flush the event IPC buffer when hitting a limit. r=chutten

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

interface nsICancelable;
interface nsIDNSRecord;

/**
 * nsIDNSListener
 */
[scriptable, function, uuid(27d49bfe-280c-49e0-bbaa-f6200c232c3d)]
interface nsIDNSListener : nsISupports
{
    /**
     * called when an asynchronous host lookup completes.
     *
     * @param aRequest
     *        the value returned from asyncResolve.
     * @param aRecord
     *        the DNS record corresponding to the hostname that was resolved.
     *        this parameter is null if there was an error.
     * @param aStatus
     *        if the lookup failed, this parameter gives the reason.
     */
    void onLookupComplete(in nsICancelable aRequest,
                          in nsIDNSRecord  aRecord,
                          in nsresult      aStatus);
};

/**
 * nsIDNSListenerProxy:
 *
 * Must be implemented by classes that wrap the original listener passed to
 * nsIDNSService.AsyncResolve, so we have access to original listener for
 * comparison purposes.
 */
[uuid(60eff0e4-6f7c-493c-add9-1cbea59063ad)]
interface nsIDNSListenerProxy : nsISupports
{
  /*
   * The original nsIDNSListener which requested hostname resolution.
   */
  readonly attribute nsIDNSListener originalListener;
};