LCOV - code coverage report
Current view: top level - extensions/auth - nsAuthGSSAPI.h (source / functions) Hit Total Coverage
Test: output.info Lines: 0 1 0.0 %
Date: 2017-07-14 16:53:18 Functions: 0 1 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /* vim:set ts=4 sw=4 et cindent: */
       2             : /* This Source Code Form is subject to the terms of the Mozilla Public
       3             :  * License, v. 2.0. If a copy of the MPL was not distributed with this
       4             :  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
       5             : 
       6             : #ifndef nsAuthGSSAPI_h__
       7             : #define nsAuthGSSAPI_h__
       8             : 
       9             : #include "nsAuth.h"
      10             : #include "nsIAuthModule.h"
      11             : #include "nsString.h"
      12             : #include "mozilla/Attributes.h"
      13             : 
      14             : #define GSS_USE_FUNCTION_POINTERS 1
      15             : 
      16             : #include "gssapi.h"
      17             : 
      18             : // The nsAuthGSSAPI class provides responses for the GSS-API Negotiate method
      19             : // as specified by Microsoft in draft-brezak-spnego-http-04.txt
      20             : 
      21             : /* Some remarks on thread safety ...
      22             :  *
      23             :  * The thread safety of this class depends largely upon the thread safety of
      24             :  * the underlying GSSAPI and Kerberos libraries. This code just loads the
      25             :  * system GSSAPI library, and whilst it avoids loading known bad libraries,
      26             :  * it cannot determine the thread safety of the the code it loads.
      27             :  *
      28             :  * When used with a non-threadsafe library, it is not safe to simultaneously
      29             :  * use multiple instantiations of this class.
      30             :  *
      31             :  * When used with a threadsafe Kerberos library, multiple instantiations of
      32             :  * this class may happily co-exist. Methods may be sequentially called from
      33             :  * multiple threads. The nature of the GSSAPI protocol is such that a correct
      34             :  * implementation will never call methods in parallel, as the results of the
      35             :  * last call are required as input to the next.
      36             :  */
      37             : 
      38             : class nsAuthGSSAPI final : public nsIAuthModule
      39             : {
      40             : public:
      41             :     NS_DECL_THREADSAFE_ISUPPORTS
      42             :     NS_DECL_NSIAUTHMODULE
      43             : 
      44             :     explicit nsAuthGSSAPI(pType package);
      45             : 
      46             :     static void Shutdown();
      47             : 
      48             : private:
      49           0 :     ~nsAuthGSSAPI() { Reset(); }
      50             : 
      51             :     void    Reset();
      52             :     gss_OID GetOID() { return mMechOID; }
      53             : 
      54             : private:
      55             :     gss_ctx_id_t mCtx;
      56             :     gss_OID      mMechOID;
      57             :     nsCString    mServiceName;
      58             :     uint32_t     mServiceFlags;
      59             :     nsString     mUsername;
      60             :     bool         mComplete;
      61             : };
      62             : 
      63             : #endif /* nsAuthGSSAPI_h__ */

Generated by: LCOV version 1.13