






 
This section explains how to write your own certificate name check callback and certificate name mismatch callback, as mentioned in Section 7.4, "Using the Security Callbacks."
Callbacks are implemented using functors. See Chapter 8, "The Functor Package," in the Threads Module User's Guide for more information.
As you write the callback functions, keep the required function signatures in mind. You can add additional parameters as callee data as described in Chapter 8, "The Functor Package," in the Threads Module User's Guide.
Rogue Wave does not provide technical support for writing callbacks. The functions in the HTTPS package that set the callback are provided for convenience only.
To use your callback, you will:
Create an appropriate functor that wraps your function and passes in any necessary data. For example, you could pass in a handle to your windowing system to pop up a message box from the callback.
Call either RWHttpsSecurityManager::setNameCheckCallback() or RWHttpsSecurityManager::setNameMismatchCallback() and pass your functor as the argument.
Example 12 adds callback functions to Example 10. (See Section 7.1, "Getting Started with HTTPS.")
This example uses utility functions provided in util.h.
| // File: examples\https\manual\CallbackExample.cpp
#include <rw/itc/RWTIOUResult.h>
#include <rw/internet/RWURL.h>
#include <rw/network/RWWinSockInfo.h>
#include <rw/secsock/RWSecureSocketPackageInit.h>
#include <rw/secsock/RWSecureSocketContext.h>
#include <rw/http/RWHttpAgent.h>
#include <rw/http/RWHttpReply.h>
#include <rw/https/RWHttpsSecurityManager.h>
#include <rw/functor/functor.h>
#if defined(RW_NO_IOSTD)
#  include <iostream.h>
#else
#  include <iostream>
   using std::cout;
   using std::cerr;
   using std::endl;
#endif
#include <../httpsexampledefs.h>
#include <../util.h>
bool myCertificateNameCheckCallback(RWCString host, RWX509Certificate cert);
{
  cout <<  "My Certificate Name Check Function called!" << endl;
  // This function should return true if the names match and false 
  // if they don't.
  // We return false every time to ensure the Name Mismatch
  // Callback gets called. (Example purposes only. Don't do this!)
  return false;
}
void  myCertificateNameMismatchCallback(RWCString host, RWX509Certificate cert);
{
  cout <<  "My Certificate Name Mismatch Function called!" << endl;
}
int main(int argc, char** argv) 
{
  RWWinSockInfo info;                                          
  RWSecureSocketPackageInit secsockInit;                       
#if defined(RW_SECSOCK_RNG_NEEDS_SEEDING)                      
    RWSecureSocketPackageInit::seedRNGFromFile(SEED_DATA_FILE);
#endif
  int port = parseCommandLine(argc, argv);
  RWSecureSocketContext context;                               
  context.prepareToAuthenticate(TRUSTED_CERTS_FILE);           
  RWHttpsSecurityManager::setAgentContext(context);            
  RWHttpsNameCheckCallback nccFunctor =
    rwtMakeFunctorR2G(bool, RWCString, RWX509Certificate,
      bool, myCertificateNameCheckCallback,
      RWCString, RWX509Certificate);                            //1
  RWHttpsSecurityManager::setNameCheckCallback(nccFunctor);     //2
RWHttpsNameMismatchCallback nmcFunctor =   
        rwtMakeFunctor2G(RWCString, RWX509Certificate, void, 
        myCertificateNameMismatchCallback, RWCString,
        RWX509Certificate);                                     //3
  RWHttpsSecurityManager::setNameMismatchCallback(nmcFunctor);  //4
  RWHttpAgent agent;      
  char urlStr[30];
   sprintf(urlStr, "https://localhost:%d/", port);    
                                 
  RWURL url(urlStr); 
                        
  RWTIOUResult<RWHttpReply> replyIOU;                          
  try {
    replyIOU = agent.executeGet(url);                          
    RWHttpReply reply = replyIOU.redeem();                     
    cout << reply.asString() << endl;
    
    if(reply.is2XX()) {                                         
      cout << reply.getBody() << endl;
    }
  } catch(const RWxmsg& msg) {                                 
    cerr << "An unexpected exception occurred: " 
         << msg.why() << endl;
    return 1;
  }
  return 0;
}
  // This example is a modification of the RWHttpSecureAgentExample
  // which adds the new callback functions.     
  // The first step is to write the callback functions to do what
  // you want keeping the required function signatures in mind. You
  // can add additional parameters as "Callee Data" as described in
  // the Functor User's Guide.        
                                                               
 | 
| //1 | Creates the name Check Callback functor. | 
| //2 | Directs the HTTPS package to use this functor as the name Check Callback. | 
| //3 | Creates the Name Mismatch Callback. | 
| //4 | Directs the HTTPS package to use this functor as the name Mismatch Callback. | 
To stop using your callback, call one of these set functions:
RWHttpsSecurityManager::setNameCheckCallback()
RWHttpsSecurityManager::setNameMismatchCallback() with a functor that does not have a body attached; in other words, a default constructed functor handle. See Example 13.
| RWHttpsNameMismatchCallback functor; RWHttpsSecurityManager::setNameMismatchCallback (functor); | 





Copyright © Rogue Wave Software, Inc. All Rights Reserved.
The Rogue Wave name and logo, and SourcePro, are registered trademarks of Rogue Wave Software. All other trademarks are the property of their respective owners.
Provide feedback to Rogue Wave about its documentation.