× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



I posted about parsing certificates from the telnet server quite a while back 
and hadn't
gotten it working.  I found out from IBM that the offset to the certificate was 
off by
two (though they didn't officially call it a bug.)  The program below may still 
have some
leftover bits unrelated to the problem and may not be the "best" way to do some 
things,
but it does retrieve the CN (username) from the certificate.  I thought I'd 
post it in
case anyone else was trying to do something similar.

Apply standard disclaimers here.


/* Log connections, verify certificate on SSL connections */ /* Thanks to Scott Klement for some of the code that he posted on MIDRANGE-L */ /* http://archive.midrange.com/midrange-l/200103/msg00068.html */

     H DFTACTGRP(*NO) ACTGRP('TELNET') BNDDIR('QC2LE')

     D inet_ntoa       PR              *   ExtProc('inet_ntoa')
     D  ulong_addr                   10U 0 VALUE

     D Cmd             PR                  ExtPgm('QCMDEXC')
     D   Command                    500A   const options(*varsize)
     D   Length                      15P 5 const

     D ParseCert       PR                  ExtProc('QsyParseCertificate')
     D   Certificate                   *   value
     D   CertType                    10I 0 value
     D   CertLen                     10I 0 value
     D   CertFmt                      8    const
     D   CertRcvr                      *   value
     D   CertRcvrLen                 10I 0 value
     D   CertErr                       *   value

     D peUserDscInfo   S              1A
     D peDevDscInfo    S              1A
     D peCnnDscInfo    S              1A
     D peEnvOpt        S              1A
     D peEnvOptLen     S             10I 0
     D peAllowConn     S              1A
     D peAutoSignOn    S              1A
     D p_Cert          S               *   inz(*NULL)
     D CertType        S             10I 0 inz(1)
     D ParseFmt        S              8    inz('CERT0200')
     D CrtUser         S             10A
     D Msg             S            500A   varying

     D p_UserDscInfo   S               *   inz(*NULL)
     D dsUserDscInfo   DS                  based(p_UserDscInfo)
     D  dsUserLen                    10I 0
     D  dsUserProfile                10A
     D  dsUserCurLib                 10A
     D  dsUserProgram                10A
     D  dsUserMenu                   10A

     D p_DevDscInfo    S               *   inz(*NULL)
     D dsDevDscInfo    DS                  based(p_DevDscInfo)
     D  dsDevName                    10A
     D  dsDevFormat                   8A
     D  dsDevReserved                 2A
     D  dsDevAttrOff                 10I 0
     D  dsDevAttrLen                 10I 0

     D p_CnnDscInfo    S               *   inz(*NULL)
     D dsCnnDscInfo    DS                  based(p_CnnDscInfo)
     D  dsCnnLen                     10I 0
     D  dsCnnAddr                    20A                                        
Client IP address
     D  dsCnnPWvalid                  1A
     D  dsCnnWStype                  12A
     D  dsCnnRsv1                     2A                                        
Part of WStype?
     D  dsCnnSSL                      1A
     D  dsCnnSvrAddr                 20A                                        
Server IP address
     D  dsCnnClAut                    1A                                        
Client Auth Level
     D  dsCnnRsv2                     3A
     D  dsCnnCertVld                 10I 0                                      
Return Code
     D  dsCnnCertOff                 10I 0                                      
Offset to Cert
     D  dsCnnCertLen                 10I 0                                      
Certificate Length

     D p_Addr          S               *   inz(*NULL)
     D dsAddr          DS                  based(p_Addr)
     D  dsAddrLen                     3I 0
     D  dsAddrFamily                  3I 0
     D  dsAddrPort                    5U 0
     D  dsAddrIP                     10U 0

     D dsCert          DS         32767
     D  dsCertLen              1      4I 0
     D  dsCertAvail            5      8I 0
     D  dsCertCNOff          105    108I 0                                      
Common Name (user)
     D  dsCertCNLen          109    112I 0

     D dsEC            DS
     D  dsECBytesP             1      4I 0 inz(256)
     D  dsECBytesA             5      8I 0 inz(0)
     D  dsECMsgID              9     15
     D  dsECReserv            16     16
     D  dsECMsgDta            17    256

     c     *entry        plist
     c                   parm                    peUserDscInfo
     c                   parm                    peDevDscInfo
     c                   parm                    peCnnDscInfo
     c                   parm                    peEnvOpt
     c                   parm                    peEnvOptLen
     c                   parm                    peAllowConn
     c                   parm                    peAutoSignOn

     c                   eval      p_UserDscInfo = %addr(peUserDscInfo)
     c                   eval      p_DevDscInfo = %addr(peDevDscInfo)
     c                   eval      p_CnnDscInfo = %addr(peCnnDscInfo)

     c                   if        dsCnnSSL = '1'
      * validate certificate
     c     dsCnnCertLen  ifne      *ZERO
     c                   eval      p_Cert = p_CnnDscInfo + dsCnnCertOff + 2
     c                   callp     ParseCert(p_Cert : CertType : dsCnnCertLen
     c                             : ParseFmt : %addr(dsCert)
     c                             : %len(dsCert) : %addr(dsEC))
     c     dsECBytesA    ifne      *ZERO
      * an error has occurred
     c                   else
     c     dsCertCNOff   ifeq      *ZERO
      * no CN?
     c                   else
     c                   eval      CrtUser = %subst(dsCert :
     c                             dsCertCNOff + 1 : dsCertCNLen)
     c                   dsply                   CrtUser
     c                   endif                                                  
dsCertCNOff=0
     c                   endif                                                  
dsECBytesA<>0
     c                   endif                                                  
dsCnnCertLen<>0
     c                   endif                                                  
dsCnnSSL='1'
     c                   return

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.