Hex Artifact Content

Artifact 53c870760b8f00c4ae4da08fde19f914ce8b99b3d4ba4144290a2952e1f4da41:


0000: 2f 2a 0a 20 2a 20 45 6e 63 72 79 70 74 69 6f 6e  /*. * Encryption
0010: 20 46 75 6e 63 74 69 6f 6e 73 20 4d 6f 64 75 6c   Functions Modul
0020: 65 0a 20 2a 0a 20 2a 20 54 68 69 73 20 6d 6f 64  e. *. * This mod
0030: 75 6c 65 20 70 72 6f 76 69 64 65 73 20 63 6f 6d  ule provides com
0040: 6d 61 6e 64 73 20 74 68 61 74 20 63 61 6e 20 62  mands that can b
0050: 65 20 75 73 65 64 20 74 6f 20 65 6e 63 72 79 70  e used to encryp
0060: 74 20 6f 72 20 64 65 63 72 79 70 74 20 64 61 74  t or decrypt dat
0070: 61 2e 0a 20 2a 0a 20 2a 20 43 6f 70 79 72 69 67  a.. *. * Copyrig
0080: 68 74 20 28 43 29 20 32 30 32 33 20 42 72 69 61  ht (C) 2023 Bria
0090: 6e 20 4f 27 48 61 67 61 6e 0a 20 2a 0a 20 2a 2f  n O'Hagan. *. */
00a0: 0a 0a 23 69 6e 63 6c 75 64 65 20 22 74 6c 73 49  ..#include "tlsI
00b0: 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 22  nt.h".#include "
00c0: 74 63 6c 4f 70 74 73 2e 68 22 0a 23 69 6e 63 6c  tclOpts.h".#incl
00d0: 75 64 65 20 3c 74 63 6c 2e 68 3e 0a 23 69 6e 63  ude <tcl.h>.#inc
00e0: 6c 75 64 65 20 3c 73 74 64 69 6f 2e 68 3e 0a 23  lude <stdio.h>.#
00f0: 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e 67 2e  include <string.
0100: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 6f 70 65  h>.#include <ope
0110: 6e 73 73 6c 2f 65 76 70 2e 68 3e 0a 23 69 66 20  nssl/evp.h>.#if 
0120: 4f 50 45 4e 53 53 4c 5f 56 45 52 53 49 4f 4e 5f  OPENSSL_VERSION_
0130: 4e 55 4d 42 45 52 20 3e 3d 20 30 78 33 30 30 30  NUMBER >= 0x3000
0140: 30 30 30 30 4c 0a 23 69 6e 63 6c 75 64 65 20 3c  0000L.#include <
0150: 6f 70 65 6e 73 73 6c 2f 70 61 72 61 6d 73 2e 68  openssl/params.h
0160: 3e 0a 23 65 6e 64 69 66 0a 0a 2f 2a 20 45 6e 63  >.#endif../* Enc
0170: 72 79 70 74 69 6f 6e 20 66 75 6e 63 74 69 6f 6e  ryption function
0180: 73 20 2a 2f 0a 23 64 65 66 69 6e 65 20 54 59 50  s */.#define TYP
0190: 45 5f 4d 44 09 09 30 78 30 31 30 0a 23 64 65 66  E_MD..0x010.#def
01a0: 69 6e 65 20 54 59 50 45 5f 48 4d 41 43 09 30 78  ine TYPE_HMAC.0x
01b0: 30 32 30 0a 23 64 65 66 69 6e 65 20 54 59 50 45  020.#define TYPE
01c0: 5f 43 4d 41 43 09 30 78 30 34 30 0a 23 64 65 66  _CMAC.0x040.#def
01d0: 69 6e 65 20 54 59 50 45 5f 4d 41 43 09 30 78 30  ine TYPE_MAC.0x0
01e0: 38 30 0a 23 64 65 66 69 6e 65 20 54 59 50 45 5f  80.#define TYPE_
01f0: 45 4e 43 52 59 50 54 09 30 78 31 30 30 0a 23 64  ENCRYPT.0x100.#d
0200: 65 66 69 6e 65 20 54 59 50 45 5f 44 45 43 52 59  efine TYPE_DECRY
0210: 50 54 09 30 78 32 30 30 0a 23 64 65 66 69 6e 65  PT.0x200.#define
0220: 20 54 59 50 45 5f 53 49 47 4e 09 30 78 34 30 30   TYPE_SIGN.0x400
0230: 0a 23 64 65 66 69 6e 65 20 54 59 50 45 5f 56 45  .#define TYPE_VE
0240: 52 49 46 59 09 30 78 38 30 30 0a 0a 0a 2f 2a 2a  RIFY.0x800.../**
0250: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0260: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0270: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0280: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0290: 2a 2f 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  */../*. *-------
02a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
02e0: 20 2a 20 45 6e 63 72 79 70 74 49 6e 69 74 69 61   * EncryptInitia
02f0: 6c 69 7a 65 20 2d 2d 0a 20 2a 0a 20 2a 09 49 6e  lize --. *. *.In
0300: 69 74 69 61 6c 69 7a 65 20 61 6e 20 65 6e 63 72  itialize an encr
0310: 79 70 74 69 6f 6e 20 66 75 6e 63 74 69 6f 6e 0a  yption function.
0320: 20 2a 0a 20 2a 20 52 65 74 75 72 6e 73 3a 0a 20   *. * Returns:. 
0330: 2a 09 54 43 4c 5f 4f 4b 20 69 66 20 73 75 63 63  *.TCL_OK if succ
0340: 65 73 73 66 75 6c 20 6f 72 20 54 43 4c 5f 45 52  essful or TCL_ER
0350: 52 4f 52 20 66 6f 72 20 66 61 69 6c 75 72 65 20  ROR for failure 
0360: 77 69 74 68 20 72 65 73 75 6c 74 20 73 65 74 0a  with result set.
0370: 20 2a 09 74 6f 20 65 72 72 6f 72 20 6d 65 73 73   *.to error mess
0380: 61 67 65 2e 0a 20 2a 0a 20 2a 20 53 69 64 65 20  age.. *. * Side 
0390: 65 66 66 65 63 74 73 3a 0a 20 2a 09 4e 6f 20 72  effects:. *.No r
03a0: 65 73 75 6c 74 20 6f 72 20 65 72 72 6f 72 20 6d  esult or error m
03b0: 65 73 73 61 67 65 0a 20 2a 0a 20 2a 2d 2d 2d 2d  essage. *. *----
03c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
0400: 20 2a 2f 0a 69 6e 74 20 45 6e 63 72 79 70 74 49   */.int EncryptI
0410: 6e 69 74 69 61 6c 69 7a 65 28 54 63 6c 5f 49 6e  nitialize(Tcl_In
0420: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 69 6e  terp *interp, in
0430: 74 20 74 79 70 65 2c 20 45 56 50 5f 43 49 50 48  t type, EVP_CIPH
0440: 45 52 5f 43 54 58 20 2a 2a 63 74 78 2c 0a 09 54  ER_CTX **ctx,..T
0450: 63 6c 5f 4f 62 6a 20 2a 63 69 70 68 65 72 4f 62  cl_Obj *cipherOb
0460: 6a 2c 20 54 63 6c 5f 4f 62 6a 20 2a 6b 65 79 4f  j, Tcl_Obj *keyO
0470: 62 6a 2c 20 54 63 6c 5f 4f 62 6a 20 2a 69 76 4f  bj, Tcl_Obj *ivO
0480: 62 6a 29 20 7b 0a 20 20 20 20 63 6f 6e 73 74 20  bj) {.    const 
0490: 45 56 50 5f 43 49 50 48 45 52 20 2a 63 69 70 68  EVP_CIPHER *ciph
04a0: 65 72 3b 0a 20 20 20 20 63 68 61 72 20 2a 63 69  er;.    char *ci
04b0: 70 68 65 72 4e 61 6d 65 20 3d 20 20 4e 55 4c 4c  pherName =  NULL
04c0: 2c 20 2a 6b 65 79 20 3d 20 4e 55 4c 4c 2c 20 2a  , *key = NULL, *
04d0: 69 76 20 3d 20 4e 55 4c 4c 3b 0a 20 20 20 20 69  iv = NULL;.    i
04e0: 6e 74 20 63 69 70 68 65 72 5f 6c 65 6e 20 3d 20  nt cipher_len = 
04f0: 30 2c 20 64 61 74 61 5f 6c 65 6e 20 3d 20 30 2c  0, data_len = 0,
0500: 20 6b 65 79 5f 6c 65 6e 20 3d 20 30 2c 20 69 76   key_len = 0, iv
0510: 5f 6c 65 6e 20 3d 20 30 2c 20 72 65 73 3b 0a 0a  _len = 0, res;..
0520: 20 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c      dprintf("Cal
0530: 6c 65 64 22 29 3b 0a 0a 20 20 20 20 2f 2a 20 47  led");..    /* G
0540: 65 74 20 65 6e 63 72 79 70 74 69 6f 6e 20 70 61  et encryption pa
0550: 72 61 6d 65 74 65 72 73 20 2a 2f 0a 20 20 20 20  rameters */.    
0560: 69 66 20 28 63 69 70 68 65 72 4f 62 6a 20 21 3d  if (cipherObj !=
0570: 20 4e 55 4c 4c 29 20 7b 0a 09 63 69 70 68 65 72   NULL) {..cipher
0580: 4e 61 6d 65 20 3d 20 54 63 6c 5f 47 65 74 53 74  Name = Tcl_GetSt
0590: 72 69 6e 67 46 72 6f 6d 4f 62 6a 28 63 69 70 68  ringFromObj(ciph
05a0: 65 72 4f 62 6a 2c 20 26 63 69 70 68 65 72 5f 6c  erObj, &cipher_l
05b0: 65 6e 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69  en);.    }.    i
05c0: 66 20 28 6b 65 79 4f 62 6a 20 21 3d 20 4e 55 4c  f (keyObj != NUL
05d0: 4c 29 20 7b 0a 09 6b 65 79 20 3d 20 54 63 6c 5f  L) {..key = Tcl_
05e0: 47 65 74 53 74 72 69 6e 67 46 72 6f 6d 4f 62 6a  GetStringFromObj
05f0: 28 6b 65 79 4f 62 6a 2c 20 26 6b 65 79 5f 6c 65  (keyObj, &key_le
0600: 6e 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  n);.    }.    if
0610: 20 28 69 76 4f 62 6a 20 21 3d 20 4e 55 4c 4c 29   (ivObj != NULL)
0620: 20 7b 0a 09 69 76 20 3d 20 54 63 6c 5f 47 65 74   {..iv = Tcl_Get
0630: 53 74 72 69 6e 67 46 72 6f 6d 4f 62 6a 28 69 76  StringFromObj(iv
0640: 4f 62 6a 2c 20 26 69 76 5f 6c 65 6e 29 3b 0a 20  Obj, &iv_len);. 
0650: 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 47 65 74     }..    /* Get
0660: 20 63 69 70 68 65 72 20 6e 61 6d 65 20 2a 2f 0a   cipher name */.
0670: 23 69 66 20 4f 50 45 4e 53 53 4c 5f 56 45 52 53  #if OPENSSL_VERS
0680: 49 4f 4e 5f 4e 55 4d 42 45 52 20 3c 20 30 78 33  ION_NUMBER < 0x3
0690: 30 30 30 30 30 30 30 4c 0a 20 20 20 20 63 69 70  0000000L.    cip
06a0: 68 65 72 20 3d 20 45 56 50 5f 67 65 74 5f 63 69  her = EVP_get_ci
06b0: 70 68 65 72 62 79 6e 61 6d 65 28 63 69 70 68 65  pherbyname(ciphe
06c0: 72 4e 61 6d 65 29 3b 0a 23 65 6c 73 65 0a 20 20  rName);.#else.  
06d0: 20 20 63 69 70 68 65 72 20 3d 20 45 56 50 5f 43    cipher = EVP_C
06e0: 49 50 48 45 52 5f 66 65 74 63 68 28 4e 55 4c 4c  IPHER_fetch(NULL
06f0: 2c 20 63 69 70 68 65 72 4e 61 6d 65 2c 20 4e 55  , cipherName, NU
0700: 4c 4c 29 3b 0a 23 65 6e 64 69 66 0a 20 20 20 20  LL);.#endif.    
0710: 69 66 20 28 63 69 70 68 65 72 20 3d 3d 20 4e 55  if (cipher == NU
0720: 4c 4c 29 20 7b 0a 09 54 63 6c 5f 41 70 70 65 6e  LL) {..Tcl_Appen
0730: 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20  dResult(interp, 
0740: 22 49 6e 76 61 6c 69 64 20 63 69 70 68 65 72 3a  "Invalid cipher:
0750: 20 5c 22 22 2c 20 63 69 70 68 65 72 4e 61 6d 65   \"", cipherName
0760: 2c 20 22 5c 22 22 2c 20 4e 55 4c 4c 29 3b 0a 09  , "\"", NULL);..
0770: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
0780: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
0790: 43 72 65 61 74 65 20 61 6e 64 20 69 6e 69 74 69  Create and initi
07a0: 61 6c 69 7a 65 20 74 68 65 20 63 6f 6e 74 65 78  alize the contex
07b0: 74 20 2a 2f 0a 20 20 20 20 69 66 28 28 2a 63 74  t */.    if((*ct
07c0: 78 20 3d 20 45 56 50 5f 43 49 50 48 45 52 5f 43  x = EVP_CIPHER_C
07d0: 54 58 5f 6e 65 77 28 29 29 20 3d 3d 20 4e 55 4c  TX_new()) == NUL
07e0: 4c 29 20 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64  L) {..Tcl_Append
07f0: 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22  Result(interp, "
0800: 4d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 69 6f  Memory allocatio
0810: 6e 20 65 72 72 6f 72 22 2c 20 28 63 68 61 72 20  n error", (char 
0820: 2a 29 20 4e 55 4c 4c 29 3b 0a 09 72 65 74 75 72  *) NULL);..retur
0830: 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 20  n TCL_ERROR;.   
0840: 20 7d 0a 0a 20 20 20 20 2f 2a 20 49 6e 69 74 69   }..    /* Initi
0850: 61 6c 69 7a 65 20 74 68 65 20 6f 70 65 72 61 74  alize the operat
0860: 69 6f 6e 2e 20 4e 65 65 64 20 61 70 70 72 6f 70  ion. Need approp
0870: 72 69 61 74 65 20 6b 65 79 20 61 6e 64 20 69 76  riate key and iv
0880: 20 73 69 7a 65 2e 20 2a 2f 0a 23 69 66 20 4f 50   size. */.#if OP
0890: 45 4e 53 53 4c 5f 56 45 52 53 49 4f 4e 5f 4e 55  ENSSL_VERSION_NU
08a0: 4d 42 45 52 20 3c 20 30 78 33 30 30 30 30 30 30  MBER < 0x3000000
08b0: 30 4c 0a 20 20 20 20 69 66 20 28 74 79 70 65 20  0L.    if (type 
08c0: 3d 3d 20 54 59 50 45 5f 45 4e 43 52 59 50 54 29  == TYPE_ENCRYPT)
08d0: 20 7b 0a 09 72 65 73 20 3d 20 45 56 50 5f 45 6e   {..res = EVP_En
08e0: 63 72 79 70 74 49 6e 69 74 5f 65 78 28 2a 63 74  cryptInit_ex(*ct
08f0: 78 2c 20 63 69 70 68 65 72 2c 20 4e 55 4c 4c 2c  x, cipher, NULL,
0900: 20 6b 65 79 2c 20 69 76 29 3b 0a 20 20 20 20 7d   key, iv);.    }
0910: 20 65 6c 73 65 20 7b 0a 09 72 65 73 20 3d 20 45   else {..res = E
0920: 56 50 5f 44 65 63 72 79 70 74 49 6e 69 74 5f 65  VP_DecryptInit_e
0930: 78 28 2a 63 74 78 2c 20 63 69 70 68 65 72 2c 20  x(*ctx, cipher, 
0940: 4e 55 4c 4c 2c 20 6b 65 79 2c 20 69 76 29 3b 0a  NULL, key, iv);.
0950: 20 20 20 20 7d 0a 23 65 6c 73 65 0a 09 4f 53 53      }.#else..OSS
0960: 4c 5f 50 41 52 41 4d 20 70 61 72 61 6d 73 5b 32  L_PARAM params[2
0970: 5d 3b 0a 09 69 6e 74 20 69 6e 64 65 78 20 3d 20  ];..int index = 
0980: 30 3b 0a 0a 09 69 66 20 28 69 76 20 21 3d 20 4e  0;...if (iv != N
0990: 55 4c 4c 29 20 7b 0a 09 20 20 20 20 70 61 72 61  ULL) {..    para
09a0: 6d 73 5b 69 6e 64 65 78 2b 2b 5d 20 3d 20 4f 53  ms[index++] = OS
09b0: 53 4c 5f 50 41 52 41 4d 5f 63 6f 6e 73 74 72 75  SL_PARAM_constru
09c0: 63 74 5f 6f 63 74 65 74 5f 73 74 72 69 6e 67 28  ct_octet_string(
09d0: 4f 53 53 4c 5f 43 49 50 48 45 52 5f 50 41 52 41  OSSL_CIPHER_PARA
09e0: 4d 5f 49 56 2c 20 28 76 6f 69 64 20 2a 29 20 69  M_IV, (void *) i
09f0: 76 2c 20 28 73 69 7a 65 5f 74 29 20 69 76 5f 6c  v, (size_t) iv_l
0a00: 65 6e 29 3b 0a 09 7d 0a 09 70 61 72 61 6d 73 5b  en);..}..params[
0a10: 69 6e 64 65 78 5d 20 3d 20 4f 53 53 4c 5f 50 41  index] = OSSL_PA
0a20: 52 41 4d 5f 63 6f 6e 73 74 72 75 63 74 5f 65 6e  RAM_construct_en
0a30: 64 28 29 3b 0a 0a 20 20 20 20 69 66 20 28 74 79  d();..    if (ty
0a40: 70 65 20 3d 3d 20 54 59 50 45 5f 45 4e 43 52 59  pe == TYPE_ENCRY
0a50: 50 54 29 20 7b 0a 09 72 65 73 20 3d 20 45 56 50  PT) {..res = EVP
0a60: 5f 45 6e 63 72 79 70 74 49 6e 69 74 5f 65 78 32  _EncryptInit_ex2
0a70: 28 63 74 78 2c 20 63 69 70 68 65 72 2c 20 6b 65  (ctx, cipher, ke
0a80: 79 2c 20 69 76 2c 20 70 61 72 61 6d 73 29 3b 0a  y, iv, params);.
0a90: 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 72 65      } else {..re
0aa0: 73 20 3d 20 45 56 50 5f 44 65 63 72 79 70 74 49  s = EVP_DecryptI
0ab0: 6e 69 74 5f 65 78 32 28 63 74 78 2c 20 63 69 70  nit_ex2(ctx, cip
0ac0: 68 65 72 2c 20 6b 65 79 2c 20 69 76 2c 20 70 61  her, key, iv, pa
0ad0: 72 61 6d 73 29 3b 0a 20 20 20 20 7d 0a 23 65 6e  rams);.    }.#en
0ae0: 64 69 66 0a 0a 20 20 20 20 69 66 28 21 72 65 73  dif..    if(!res
0af0: 29 20 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52  ) {..Tcl_AppendR
0b00: 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 49  esult(interp, "I
0b10: 6e 69 74 69 61 6c 69 7a 65 20 66 61 69 6c 65 64  nitialize failed
0b20: 3a 20 22 2c 20 52 45 41 53 4f 4e 28 29 2c 20 4e  : ", REASON(), N
0b30: 55 4c 4c 29 3b 0a 09 72 65 74 75 72 6e 20 54 43  ULL);..return TC
0b40: 4c 5f 45 52 52 4f 52 3b 0a 20 20 20 20 7d 0a 20  L_ERROR;.    }. 
0b50: 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b     return TCL_OK
0b60: 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  ;.}../*. *------
0b70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
0bb0: 0a 20 2a 20 45 6e 63 72 79 70 74 55 70 64 61 74  . * EncryptUpdat
0bc0: 65 20 2d 2d 0a 20 2a 0a 20 2a 09 55 70 64 61 74  e --. *. *.Updat
0bd0: 65 20 61 6e 20 65 6e 63 72 79 70 74 69 6f 6e 20  e an encryption 
0be0: 66 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 64 61  function with da
0bf0: 74 61 0a 20 2a 0a 20 2a 20 52 65 74 75 72 6e 73  ta. *. * Returns
0c00: 3a 0a 20 2a 09 31 20 69 66 20 73 75 63 63 65 73  :. *.1 if succes
0c10: 73 66 75 6c 20 6f 72 20 30 20 66 6f 72 20 66 61  sful or 0 for fa
0c20: 69 6c 75 72 65 0a 20 2a 0a 20 2a 20 53 69 64 65  ilure. *. * Side
0c30: 20 65 66 66 65 63 74 73 3a 0a 20 2a 09 41 64 64   effects:. *.Add
0c40: 73 20 65 6e 63 72 79 70 74 65 64 20 64 61 74 61  s encrypted data
0c50: 20 74 6f 20 62 75 66 66 65 72 20 6f 72 20 73 65   to buffer or se
0c60: 74 73 20 72 65 73 75 6c 74 20 74 6f 20 65 72 72  ts result to err
0c70: 6f 72 20 6d 65 73 73 61 67 65 0a 20 2a 0a 20 2a  or message. *. *
0c80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0cc0: 2d 2d 2d 0a 20 2a 2f 0a 69 6e 74 20 45 6e 63 72  ---. */.int Encr
0cd0: 79 70 74 55 70 64 61 74 65 28 54 63 6c 5f 49 6e  yptUpdate(Tcl_In
0ce0: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 69 6e  terp *interp, in
0cf0: 74 20 74 79 70 65 2c 20 45 56 50 5f 43 49 50 48  t type, EVP_CIPH
0d00: 45 52 5f 43 54 58 20 2a 63 74 78 2c 20 75 6e 73  ER_CTX *ctx, uns
0d10: 69 67 6e 65 64 20 63 68 61 72 20 2a 6f 75 74 62  igned char *outb
0d20: 75 66 2c 0a 09 69 6e 74 20 2a 6f 75 74 5f 6c 65  uf,..int *out_le
0d30: 6e 2c 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  n, unsigned char
0d40: 20 2a 64 61 74 61 2c 20 69 6e 74 20 64 61 74 61   *data, int data
0d50: 5f 6c 65 6e 29 20 7b 0a 20 20 20 20 69 6e 74 20  _len) {.    int 
0d60: 72 65 73 2c 20 6c 65 6e 20 3d 20 30 3b 0a 0a 20  res, len = 0;.. 
0d70: 20 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c     dprintf("Call
0d80: 65 64 22 29 3b 0a 0a 20 20 20 20 2f 2a 20 45 6e  ed");..    /* En
0d90: 63 72 79 70 74 2f 64 65 63 72 79 70 74 20 64 61  crypt/decrypt da
0da0: 74 61 20 2a 2f 0a 20 20 20 20 69 66 20 28 74 79  ta */.    if (ty
0db0: 70 65 20 3d 3d 20 54 59 50 45 5f 45 4e 43 52 59  pe == TYPE_ENCRY
0dc0: 50 54 29 20 7b 0a 09 72 65 73 20 3d 20 45 56 50  PT) {..res = EVP
0dd0: 5f 45 6e 63 72 79 70 74 55 70 64 61 74 65 28 63  _EncryptUpdate(c
0de0: 74 78 2c 20 6f 75 74 62 75 66 2c 20 6f 75 74 5f  tx, outbuf, out_
0df0: 6c 65 6e 2c 20 64 61 74 61 2c 20 64 61 74 61 5f  len, data, data_
0e00: 6c 65 6e 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65  len);.    } else
0e10: 20 7b 0a 09 72 65 73 20 3d 20 45 56 50 5f 44 65   {..res = EVP_De
0e20: 63 72 79 70 74 55 70 64 61 74 65 28 63 74 78 2c  cryptUpdate(ctx,
0e30: 20 6f 75 74 62 75 66 2c 20 6f 75 74 5f 6c 65 6e   outbuf, out_len
0e40: 2c 20 64 61 74 61 2c 20 64 61 74 61 5f 6c 65 6e  , data, data_len
0e50: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66  );.    }..    if
0e60: 20 28 72 65 73 29 20 7b 0a 09 2a 6f 75 74 5f 6c   (res) {..*out_l
0e70: 65 6e 20 2b 3d 20 6c 65 6e 3b 0a 09 72 65 74 75  en += len;..retu
0e80: 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 20 20 20 20 7d  rn TCL_OK;.    }
0e90: 20 65 6c 73 65 20 7b 0a 09 54 63 6c 5f 41 70 70   else {..Tcl_App
0ea0: 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70  endResult(interp
0eb0: 2c 20 22 55 70 64 61 74 65 20 66 61 69 6c 65 64  , "Update failed
0ec0: 3a 20 22 2c 20 52 45 41 53 4f 4e 28 29 2c 20 4e  : ", REASON(), N
0ed0: 55 4c 4c 29 3b 0a 09 72 65 74 75 72 6e 20 54 43  ULL);..return TC
0ee0: 4c 5f 45 52 52 4f 52 3b 0a 20 20 20 20 7d 0a 7d  L_ERROR;.    }.}
0ef0: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
0f00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
0f40: 20 45 6e 63 72 79 70 74 46 69 6e 61 6c 69 7a 65   EncryptFinalize
0f50: 20 2d 2d 0a 20 2a 0a 20 2a 09 46 69 6e 61 6c 69   --. *. *.Finali
0f60: 7a 65 20 61 6e 20 65 6e 63 72 79 70 74 69 6f 6e  ze an encryption
0f70: 20 66 75 6e 63 74 69 6f 6e 0a 20 2a 0a 20 2a 20   function. *. * 
0f80: 52 65 74 75 72 6e 73 3a 0a 20 2a 09 54 43 4c 5f  Returns:. *.TCL_
0f90: 4f 4b 20 69 66 20 73 75 63 63 65 73 73 66 75 6c  OK if successful
0fa0: 20 6f 72 20 54 43 4c 5f 45 52 52 4f 52 20 66 6f   or TCL_ERROR fo
0fb0: 72 20 66 61 69 6c 75 72 65 20 77 69 74 68 20 72  r failure with r
0fc0: 65 73 75 6c 74 20 73 65 74 0a 20 2a 09 74 6f 20  esult set. *.to 
0fd0: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 2e 0a 20  error message.. 
0fe0: 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74  *. * Side effect
0ff0: 73 3a 0a 20 2a 09 41 64 64 73 20 65 6e 63 72 79  s:. *.Adds encry
1000: 70 74 65 64 20 64 61 74 61 20 74 6f 20 62 75 66  pted data to buf
1010: 66 65 72 20 6f 72 20 73 65 74 73 20 72 65 73 75  fer or sets resu
1020: 6c 74 20 74 6f 20 65 72 72 6f 72 20 6d 65 73 73  lt to error mess
1030: 61 67 65 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  age. *. *-------
1040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1050: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1060: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1070: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f  ------------. */
1080: 0a 69 6e 74 20 45 6e 63 72 79 70 74 46 69 6e 61  .int EncryptFina
1090: 6c 69 7a 65 28 54 63 6c 5f 49 6e 74 65 72 70 20  lize(Tcl_Interp 
10a0: 2a 69 6e 74 65 72 70 2c 20 69 6e 74 20 74 79 70  *interp, int typ
10b0: 65 2c 20 45 56 50 5f 43 49 50 48 45 52 5f 43 54  e, EVP_CIPHER_CT
10c0: 58 20 2a 63 74 78 2c 20 75 6e 73 69 67 6e 65 64  X *ctx, unsigned
10d0: 20 63 68 61 72 20 2a 6f 75 74 62 75 66 2c 0a 09   char *outbuf,..
10e0: 69 6e 74 20 2a 6f 75 74 5f 6c 65 6e 29 20 7b 0a  int *out_len) {.
10f0: 20 20 20 20 69 6e 74 20 72 65 73 2c 20 6c 65 6e      int res, len
1100: 20 3d 20 30 3b 0a 0a 20 20 20 20 64 70 72 69 6e   = 0;..    dprin
1110: 74 66 28 22 43 61 6c 6c 65 64 22 29 3b 0a 0a 20  tf("Called");.. 
1120: 20 20 20 2f 2a 20 46 69 6e 61 6c 69 7a 65 20 64     /* Finalize d
1130: 61 74 61 20 2a 2f 0a 20 20 20 20 69 66 20 28 74  ata */.    if (t
1140: 79 70 65 20 3d 3d 20 54 59 50 45 5f 45 4e 43 52  ype == TYPE_ENCR
1150: 59 50 54 29 20 7b 0a 09 72 65 73 20 3d 20 45 56  YPT) {..res = EV
1160: 50 5f 45 6e 63 72 79 70 74 46 69 6e 61 6c 5f 65  P_EncryptFinal_e
1170: 78 28 63 74 78 2c 20 6f 75 74 62 75 66 2c 20 6f  x(ctx, outbuf, o
1180: 75 74 5f 6c 65 6e 29 3b 0a 20 20 20 20 7d 20 65  ut_len);.    } e
1190: 6c 73 65 20 7b 0a 09 72 65 73 20 3d 20 45 56 50  lse {..res = EVP
11a0: 5f 44 65 63 72 79 70 74 46 69 6e 61 6c 5f 65 78  _DecryptFinal_ex
11b0: 28 63 74 78 2c 20 6f 75 74 62 75 66 2c 20 6f 75  (ctx, outbuf, ou
11c0: 74 5f 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20  t_len);.    }.. 
11d0: 20 20 20 69 66 20 28 72 65 73 29 20 7b 0a 09 2a     if (res) {..*
11e0: 6f 75 74 5f 6c 65 6e 20 2b 3d 20 6c 65 6e 3b 0a  out_len += len;.
11f0: 09 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a  .return TCL_OK;.
1200: 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09 54 63      } else {..Tc
1210: 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69  l_AppendResult(i
1220: 6e 74 65 72 70 2c 20 22 46 69 6e 61 6c 69 7a 65  nterp, "Finalize
1230: 20 66 61 69 6c 65 64 3a 20 22 2c 20 52 45 41 53   failed: ", REAS
1240: 4f 4e 28 29 2c 20 4e 55 4c 4c 29 3b 0a 09 72 65  ON(), NULL);..re
1250: 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a  turn TCL_ERROR;.
1260: 20 20 20 20 7d 0a 7d 0a 0a 2f 2a 2a 2a 2a 2a 2a      }.}../******
1270: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1280: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1290: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
12a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 0a  *************/..
12b0: 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  /*. *-----------
12c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12f0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 45  --------. *. * E
1300: 6e 63 72 79 70 74 44 61 74 61 48 61 6e 64 6c 65  ncryptDataHandle
1310: 72 20 2d 2d 0a 20 2a 0a 20 2a 09 50 65 72 66 6f  r --. *. *.Perfo
1320: 72 6d 20 65 6e 63 72 79 70 74 69 6f 6e 20 66 75  rm encryption fu
1330: 6e 63 74 69 6f 6e 20 6f 6e 20 61 20 62 6c 6f 63  nction on a bloc
1340: 6b 20 6f 66 20 64 61 74 61 20 61 6e 64 20 72 65  k of data and re
1350: 74 75 72 6e 20 72 65 73 75 6c 74 2e 0a 20 2a 0a  turn result.. *.
1360: 20 2a 20 52 65 74 75 72 6e 73 3a 0a 20 2a 09 54   * Returns:. *.T
1370: 43 4c 5f 4f 4b 20 6f 72 20 54 43 4c 5f 45 52 52  CL_OK or TCL_ERR
1380: 4f 52 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  OR. *. * Side ef
1390: 66 65 63 74 73 3a 0a 20 2a 09 53 65 74 73 20 72  fects:. *.Sets r
13a0: 65 73 75 6c 74 20 6f 72 20 65 72 72 6f 72 20 6d  esult or error m
13b0: 65 73 73 61 67 65 0a 20 2a 0a 20 2a 2d 2d 2d 2d  essage. *. *----
13c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
13d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
13e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
13f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
1400: 20 2a 2f 0a 69 6e 74 20 45 6e 63 72 79 70 74 44   */.int EncryptD
1410: 61 74 61 48 61 6e 64 6c 65 72 28 54 63 6c 5f 49  ataHandler(Tcl_I
1420: 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 69  nterp *interp, i
1430: 6e 74 20 74 79 70 65 2c 20 54 63 6c 5f 4f 62 6a  nt type, Tcl_Obj
1440: 20 2a 64 61 74 61 4f 62 6a 2c 20 54 63 6c 5f 4f   *dataObj, Tcl_O
1450: 62 6a 20 2a 63 69 70 68 65 72 4f 62 6a 2c 0a 09  bj *cipherObj,..
1460: 54 63 6c 5f 4f 62 6a 20 2a 64 69 67 65 73 74 4f  Tcl_Obj *digestO
1470: 62 6a 2c 20 54 63 6c 5f 4f 62 6a 20 2a 6b 65 79  bj, Tcl_Obj *key
1480: 4f 62 6a 2c 20 54 63 6c 5f 4f 62 6a 20 2a 69 76  Obj, Tcl_Obj *iv
1490: 4f 62 6a 29 20 7b 0a 20 20 20 20 45 56 50 5f 43  Obj) {.    EVP_C
14a0: 49 50 48 45 52 5f 43 54 58 20 2a 63 74 78 20 3d  IPHER_CTX *ctx =
14b0: 20 4e 55 4c 4c 3b 0a 20 20 20 20 69 6e 74 20 64   NULL;.    int d
14c0: 61 74 61 5f 6c 65 6e 20 3d 20 30 2c 20 6f 75 74  ata_len = 0, out
14d0: 5f 6c 65 6e 20 3d 20 30 2c 20 72 65 73 3b 0a 20  _len = 0, res;. 
14e0: 20 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72     unsigned char
14f0: 20 2a 64 61 74 61 2c 20 2a 6f 75 74 62 75 66 3b   *data, *outbuf;
1500: 0a 20 20 20 20 54 63 6c 5f 4f 62 6a 20 2a 72 65  .    Tcl_Obj *re
1510: 73 75 6c 74 4f 62 6a 3b 0a 0a 20 20 20 20 64 70  sultObj;..    dp
1520: 72 69 6e 74 66 28 22 43 61 6c 6c 65 64 22 29 3b  rintf("Called");
1530: 0a 0a 20 20 20 20 2f 2a 20 47 65 74 20 64 61 74  ..    /* Get dat
1540: 61 20 2a 2f 0a 20 20 20 20 69 66 20 28 64 61 74  a */.    if (dat
1550: 61 4f 62 6a 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a  aObj != NULL) {.
1560: 09 64 61 74 61 20 3d 20 54 63 6c 5f 47 65 74 42  .data = Tcl_GetB
1570: 79 74 65 41 72 72 61 79 46 72 6f 6d 4f 62 6a 28  yteArrayFromObj(
1580: 64 61 74 61 4f 62 6a 2c 20 26 64 61 74 61 5f 6c  dataObj, &data_l
1590: 65 6e 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20  en);.    } else 
15a0: 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73  {..Tcl_AppendRes
15b0: 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 4e 6f 20  ult(interp, "No 
15c0: 64 61 74 61 22 2c 20 4e 55 4c 4c 29 3b 0a 09 72  data", NULL);..r
15d0: 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b  eturn TCL_ERROR;
15e0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 41  .    }..    /* A
15f0: 6c 6c 6f 63 61 74 65 20 73 74 6f 72 61 67 65 20  llocate storage 
1600: 66 6f 72 20 65 6e 63 72 79 70 74 65 64 20 64 61  for encrypted da
1610: 74 61 2e 20 53 69 7a 65 20 73 68 6f 75 6c 64 20  ta. Size should 
1620: 62 65 20 64 61 74 61 20 73 69 7a 65 20 2b 20 62  be data size + b
1630: 6c 6f 63 6b 20 73 69 7a 65 2e 20 2a 2f 0a 20 20  lock size. */.  
1640: 20 20 72 65 73 75 6c 74 4f 62 6a 20 3d 20 54 63    resultObj = Tc
1650: 6c 5f 4e 65 77 4f 62 6a 28 29 3b 0a 20 20 20 20  l_NewObj();.    
1660: 6f 75 74 62 75 66 20 3d 20 54 63 6c 5f 53 65 74  outbuf = Tcl_Set
1670: 42 79 74 65 41 72 72 61 79 4c 65 6e 67 74 68 28  ByteArrayLength(
1680: 72 65 73 75 6c 74 4f 62 6a 2c 20 64 61 74 61 5f  resultObj, data_
1690: 6c 65 6e 2b 31 30 32 34 29 3b 0a 20 20 20 20 69  len+1024);.    i
16a0: 66 20 28 72 65 73 75 6c 74 4f 62 6a 20 3d 3d 20  f (resultObj == 
16b0: 4e 55 4c 4c 20 7c 7c 20 6f 75 74 62 75 66 20 3d  NULL || outbuf =
16c0: 3d 20 4e 55 4c 4c 29 20 7b 0a 09 54 63 6c 5f 41  = NULL) {..Tcl_A
16d0: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
16e0: 72 70 2c 20 22 4d 65 6d 6f 72 79 20 61 6c 6c 6f  rp, "Memory allo
16f0: 63 61 74 69 6f 6e 20 65 72 72 6f 72 22 2c 20 28  cation error", (
1700: 63 68 61 72 20 2a 29 20 4e 55 4c 4c 29 3b 0a 09  char *) NULL);..
1710: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
1720: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
1730: 50 65 72 66 6f 72 6d 20 6f 70 65 72 61 74 69 6f  Perform operatio
1740: 6e 20 2a 2f 0a 20 20 20 20 69 66 20 28 45 6e 63  n */.    if (Enc
1750: 72 79 70 74 49 6e 69 74 69 61 6c 69 7a 65 28 69  ryptInitialize(i
1760: 6e 74 65 72 70 2c 20 74 79 70 65 2c 20 26 63 74  nterp, type, &ct
1770: 78 2c 20 63 69 70 68 65 72 4f 62 6a 2c 20 6b 65  x, cipherObj, ke
1780: 79 4f 62 6a 2c 20 69 76 4f 62 6a 29 20 21 3d 20  yObj, ivObj) != 
1790: 54 43 4c 5f 4f 4b 20 7c 7c 0a 09 45 6e 63 72 79  TCL_OK ||..Encry
17a0: 70 74 55 70 64 61 74 65 28 69 6e 74 65 72 70 2c  ptUpdate(interp,
17b0: 20 74 79 70 65 2c 20 63 74 78 2c 20 6f 75 74 62   type, ctx, outb
17c0: 75 66 2c 20 26 6f 75 74 5f 6c 65 6e 2c 20 64 61  uf, &out_len, da
17d0: 74 61 2c 20 64 61 74 61 5f 6c 65 6e 29 20 21 3d  ta, data_len) !=
17e0: 20 54 43 4c 5f 4f 4b 20 7c 7c 0a 09 45 6e 63 72   TCL_OK ||..Encr
17f0: 79 70 74 46 69 6e 61 6c 69 7a 65 28 69 6e 74 65  yptFinalize(inte
1800: 72 70 2c 20 74 79 70 65 2c 20 63 74 78 2c 20 6f  rp, type, ctx, o
1810: 75 74 62 75 66 2b 6f 75 74 5f 6c 65 6e 2c 20 26  utbuf+out_len, &
1820: 6f 75 74 5f 6c 65 6e 29 20 21 3d 20 54 43 4c 5f  out_len) != TCL_
1830: 4f 4b 29 20 7b 0a 09 72 65 73 20 3d 20 54 43 4c  OK) {..res = TCL
1840: 5f 45 52 52 4f 52 3b 0a 09 67 6f 74 6f 20 64 6f  _ERROR;..goto do
1850: 6e 65 3b 0a 20 20 20 20 7d 0a 0a 64 6f 6e 65 3a  ne;.    }..done:
1860: 0a 20 20 20 20 2f 2a 20 53 65 74 20 6f 75 74 70  .    /* Set outp
1870: 75 74 20 72 65 73 75 6c 74 20 2a 2f 0a 20 20 20  ut result */.   
1880: 20 69 66 20 28 72 65 73 20 3d 3d 20 54 43 4c 5f   if (res == TCL_
1890: 4f 4b 29 20 7b 0a 09 6f 75 74 62 75 66 20 3d 20  OK) {..outbuf = 
18a0: 54 63 6c 5f 53 65 74 42 79 74 65 41 72 72 61 79  Tcl_SetByteArray
18b0: 4c 65 6e 67 74 68 28 72 65 73 75 6c 74 4f 62 6a  Length(resultObj
18c0: 2c 20 6f 75 74 5f 6c 65 6e 29 3b 0a 09 54 63 6c  , out_len);..Tcl
18d0: 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74 28 69 6e  _SetObjResult(in
18e0: 74 65 72 70 2c 20 72 65 73 75 6c 74 4f 62 6a 29  terp, resultObj)
18f0: 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 09  ;.    } else {..
1900: 54 63 6c 5f 44 65 63 72 52 65 66 43 6f 75 6e 74  Tcl_DecrRefCount
1910: 28 72 65 73 75 6c 74 4f 62 6a 29 3b 0a 09 2f 2a  (resultObj);../*
1920: 20 52 65 73 75 6c 74 20 69 73 20 65 72 72 6f 72   Result is error
1930: 20 6d 65 73 73 61 67 65 20 2a 2f 0a 20 20 20 20   message */.    
1940: 7d 0a 0a 20 20 20 20 2f 2a 20 43 6c 65 61 6e 20  }..    /* Clean 
1950: 75 70 20 2a 2f 0a 20 20 20 20 69 66 20 28 63 74  up */.    if (ct
1960: 78 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a 09 45 56  x != NULL) {..EV
1970: 50 5f 43 49 50 48 45 52 5f 43 54 58 5f 66 72 65  P_CIPHER_CTX_fre
1980: 65 28 63 74 78 29 3b 0a 20 20 20 20 7d 0a 20 20  e(ctx);.    }.  
1990: 20 20 72 65 74 75 72 6e 20 72 65 73 3b 0a 7d 0a    return res;.}.
19a0: 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ./**************
19b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
19c0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
19d0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
19e0: 2a 2a 2a 2a 2a 2f 0a 0a 2f 2a 0a 20 2a 2d 2d 2d  *****/../*. *---
19f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1a00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1a10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1a20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1a30: 0a 20 2a 0a 20 2a 20 45 6e 63 72 79 70 74 4d 61  . *. * EncryptMa
1a40: 69 6e 20 2d 2d 0a 20 2a 0a 20 2a 09 50 65 72 66  in --. *. *.Perf
1a50: 6f 72 6d 20 65 6e 63 72 79 70 74 69 6f 6e 20 66  orm encryption f
1a60: 75 6e 63 74 69 6f 6e 20 61 6e 64 20 72 65 74 75  unction and retu
1a70: 72 6e 20 72 65 73 75 6c 74 2e 0a 20 2a 0a 20 2a  rn result.. *. *
1a80: 20 52 65 74 75 72 6e 73 3a 0a 20 2a 09 54 43 4c   Returns:. *.TCL
1a90: 5f 4f 4b 20 6f 72 20 54 43 4c 5f 45 52 52 4f 52  _OK or TCL_ERROR
1aa0: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
1ab0: 63 74 73 3a 0a 20 2a 09 53 65 74 73 20 72 65 73  cts:. *.Sets res
1ac0: 75 6c 74 20 6f 72 20 65 72 72 6f 72 20 6d 65 73  ult or error mes
1ad0: 73 61 67 65 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d  sage. *. *------
1ae0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1af0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1b00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1b10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a  -------------. *
1b20: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 45 6e 63  /.static int Enc
1b30: 72 79 70 74 4d 61 69 6e 28 69 6e 74 20 74 79 70  ryptMain(int typ
1b40: 65 2c 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69  e, Tcl_Interp *i
1b50: 6e 74 65 72 70 2c 20 69 6e 74 20 6f 62 6a 63 2c  nterp, int objc,
1b60: 20 54 63 6c 5f 4f 62 6a 20 2a 63 6f 6e 73 74 20   Tcl_Obj *const 
1b70: 6f 62 6a 76 5b 5d 29 20 7b 0a 20 20 20 20 69 6e  objv[]) {.    in
1b80: 74 20 72 65 73 20 3d 20 54 43 4c 5f 4f 4b 3b 0a  t res = TCL_OK;.
1b90: 20 20 20 20 54 63 6c 5f 4f 62 6a 20 2a 63 69 70      Tcl_Obj *cip
1ba0: 68 65 72 4f 62 6a 20 3d 20 4e 55 4c 4c 2c 20 2a  herObj = NULL, *
1bb0: 63 6d 64 4f 62 6a 20 3d 20 4e 55 4c 4c 2c 20 2a  cmdObj = NULL, *
1bc0: 64 61 74 61 4f 62 6a 20 3d 20 4e 55 4c 4c 2c 20  dataObj = NULL, 
1bd0: 2a 64 69 67 65 73 74 4f 62 6a 20 3d 20 4e 55 4c  *digestObj = NUL
1be0: 4c 3b 0a 20 20 20 20 54 63 6c 5f 4f 62 6a 20 2a  L;.    Tcl_Obj *
1bf0: 69 6e 46 69 6c 65 4f 62 6a 20 3d 20 4e 55 4c 4c  inFileObj = NULL
1c00: 2c 20 2a 6f 75 74 46 69 6c 65 4f 62 6a 20 3d 20  , *outFileObj = 
1c10: 4e 55 4c 4c 2c 20 2a 6b 65 79 4f 62 6a 20 3d 20  NULL, *keyObj = 
1c20: 4e 55 4c 4c 2c 20 2a 69 76 4f 62 6a 20 3d 20 4e  NULL, *ivObj = N
1c30: 55 4c 4c 2c 20 2a 6d 61 63 4f 62 6a 20 3d 20 4e  ULL, *macObj = N
1c40: 55 4c 4c 3b 0a 20 20 20 20 63 6f 6e 73 74 20 63  ULL;.    const c
1c50: 68 61 72 20 2a 63 68 61 6e 6e 65 6c 20 3d 20 4e  har *channel = N
1c60: 55 4c 4c 2c 20 2a 6f 70 74 3b 0a 20 20 20 20 63  ULL, *opt;.    c
1c70: 6f 6e 73 74 20 45 56 50 5f 4d 44 20 2a 6d 64 20  onst EVP_MD *md 
1c80: 3d 20 4e 55 4c 4c 3b 0a 20 20 20 20 63 6f 6e 73  = NULL;.    cons
1c90: 74 20 45 56 50 5f 43 49 50 48 45 52 20 2a 63 69  t EVP_CIPHER *ci
1ca0: 70 68 65 72 20 3d 20 4e 55 4c 4c 3b 0a 0a 20 20  pher = NULL;..  
1cb0: 20 20 64 70 72 69 6e 74 66 28 22 43 61 6c 6c 65    dprintf("Calle
1cc0: 64 22 29 3b 0a 0a 20 20 20 20 2f 2a 20 43 6c 65  d");..    /* Cle
1cd0: 61 72 20 69 6e 74 65 72 70 20 72 65 73 75 6c 74  ar interp result
1ce0: 20 2a 2f 0a 20 20 20 20 54 63 6c 5f 52 65 73 65   */.    Tcl_Rese
1cf0: 74 52 65 73 75 6c 74 28 69 6e 74 65 72 70 29 3b  tResult(interp);
1d00: 0a 0a 20 20 20 20 2f 2a 20 56 61 6c 69 64 61 74  ..    /* Validat
1d10: 65 20 61 72 67 20 63 6f 75 6e 74 20 2a 2f 0a 20  e arg count */. 
1d20: 20 20 20 69 66 20 28 6f 62 6a 63 20 3c 20 33 20     if (objc < 3 
1d30: 7c 7c 20 6f 62 6a 63 20 3e 20 31 32 29 20 7b 0a  || objc > 12) {.
1d40: 09 54 63 6c 5f 57 72 6f 6e 67 4e 75 6d 41 72 67  .Tcl_WrongNumArg
1d50: 73 28 69 6e 74 65 72 70 2c 20 31 2c 20 6f 62 6a  s(interp, 1, obj
1d60: 76 2c 20 22 2d 63 69 70 68 65 72 20 6e 61 6d 65  v, "-cipher name
1d70: 20 3f 2d 64 69 67 65 73 74 20 6e 61 6d 65 3f 20   ?-digest name? 
1d80: 3f 2d 6b 65 79 20 6b 65 79 3f 20 3f 2d 69 76 20  ?-key key? ?-iv 
1d90: 73 74 72 69 6e 67 3f 20 5b 2d 64 61 74 61 20 64  string? [-data d
1da0: 61 74 61 5d 22 29 3b 0a 09 72 65 74 75 72 6e 20  ata]");..return 
1db0: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 20 20 7d  TCL_ERROR;.    }
1dc0: 0a 0a 20 20 20 20 2f 2a 20 47 65 74 20 6f 70 74  ..    /* Get opt
1dd0: 69 6f 6e 73 20 2a 2f 0a 20 20 20 20 66 6f 72 20  ions */.    for 
1de0: 28 69 6e 74 20 69 64 78 20 3d 20 31 3b 20 69 64  (int idx = 1; id
1df0: 78 20 3c 20 6f 62 6a 63 3b 20 69 64 78 2b 2b 29  x < objc; idx++)
1e00: 20 7b 0a 09 6f 70 74 20 3d 20 54 63 6c 5f 47 65   {..opt = Tcl_Ge
1e10: 74 53 74 72 69 6e 67 46 72 6f 6d 4f 62 6a 28 6f  tStringFromObj(o
1e20: 62 6a 76 5b 69 64 78 5d 2c 20 4e 55 4c 4c 29 3b  bjv[idx], NULL);
1e30: 0a 0a 09 69 66 20 28 6f 70 74 5b 30 5d 20 21 3d  ...if (opt[0] !=
1e40: 20 27 2d 27 29 20 7b 0a 09 20 20 20 20 62 72 65   '-') {..    bre
1e50: 61 6b 3b 0a 09 7d 0a 0a 09 4f 50 54 4f 42 4a 28  ak;..}...OPTOBJ(
1e60: 22 2d 63 69 70 68 65 72 22 2c 20 63 69 70 68 65  "-cipher", ciphe
1e70: 72 4f 62 6a 29 3b 0a 09 4f 50 54 4f 42 4a 28 22  rObj);..OPTOBJ("
1e80: 2d 64 61 74 61 22 2c 20 64 61 74 61 4f 62 6a 29  -data", dataObj)
1e90: 3b 0a 09 4f 50 54 4f 42 4a 28 22 2d 64 69 67 65  ;..OPTOBJ("-dige
1ea0: 73 74 22 2c 20 64 69 67 65 73 74 4f 62 6a 29 3b  st", digestObj);
1eb0: 0a 09 4f 50 54 4f 42 4a 28 22 2d 6b 65 79 22 2c  ..OPTOBJ("-key",
1ec0: 20 6b 65 79 4f 62 6a 29 3b 0a 09 4f 50 54 4f 42   keyObj);..OPTOB
1ed0: 4a 28 22 2d 69 76 22 2c 20 69 76 4f 62 6a 29 3b  J("-iv", ivObj);
1ee0: 0a 0a 09 4f 50 54 42 41 44 28 22 6f 70 74 69 6f  ...OPTBAD("optio
1ef0: 6e 22 2c 20 22 2d 63 69 70 68 65 72 2c 20 2d 64  n", "-cipher, -d
1f00: 61 74 61 2c 20 2d 64 69 67 65 73 74 2c 20 2d 6b  ata, -digest, -k
1f10: 65 79 2c 20 6f 72 20 2d 69 76 22 29 3b 0a 09 72  ey, or -iv");..r
1f20: 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b  eturn TCL_ERROR;
1f30: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 43  .    }..    /* C
1f40: 68 65 63 6b 20 66 6f 72 20 72 65 71 75 69 72 65  heck for require
1f50: 64 20 6f 70 74 69 6f 6e 73 20 2a 2f 0a 20 20 20  d options */.   
1f60: 20 69 66 20 28 63 69 70 68 65 72 4f 62 6a 20 3d   if (cipherObj =
1f70: 3d 20 4e 55 4c 4c 29 20 7b 0a 09 54 63 6c 5f 41  = NULL) {..Tcl_A
1f80: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
1f90: 72 70 2c 20 22 4e 6f 20 63 69 70 68 65 72 22 2c  rp, "No cipher",
1fa0: 20 4e 55 4c 4c 29 3b 0a 20 20 20 20 7d 20 65 6c   NULL);.    } el
1fb0: 73 65 20 69 66 20 28 6b 65 79 4f 62 6a 20 3d 3d  se if (keyObj ==
1fc0: 20 4e 55 4c 4c 29 20 7b 0a 09 54 63 6c 5f 41 70   NULL) {..Tcl_Ap
1fd0: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
1fe0: 70 2c 20 22 4e 6f 20 6b 65 79 22 2c 20 4e 55 4c  p, "No key", NUL
1ff0: 4c 29 3b 0a 09 72 65 74 75 72 6e 20 54 43 4c 5f  L);..return TCL_
2000: 45 52 52 4f 52 3b 0a 20 20 20 20 7d 0a 0a 20 20  ERROR;.    }..  
2010: 20 20 2f 2a 20 50 65 72 66 6f 72 6d 20 65 6e 63    /* Perform enc
2020: 72 79 70 74 69 6f 6e 20 66 75 6e 63 74 69 6f 6e  ryption function
2030: 20 6f 6e 20 66 69 6c 65 2c 20 73 74 61 63 6b 65   on file, stacke
2040: 64 20 63 68 61 6e 6e 65 6c 2c 20 75 73 69 6e 67  d channel, using
2050: 20 69 6e 73 74 61 6e 63 65 20 63 6f 6d 6d 61 6e   instance comman
2060: 64 2c 20 6f 72 20 64 61 74 61 20 62 6c 6f 62 20  d, or data blob 
2070: 2a 2f 0a 20 20 20 20 69 66 20 28 64 61 74 61 4f  */.    if (dataO
2080: 62 6a 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a 09 72  bj != NULL) {..r
2090: 65 73 20 3d 20 45 6e 63 72 79 70 74 44 61 74 61  es = EncryptData
20a0: 48 61 6e 64 6c 65 72 28 69 6e 74 65 72 70 2c 20  Handler(interp, 
20b0: 74 79 70 65 2c 20 64 61 74 61 4f 62 6a 2c 20 63  type, dataObj, c
20c0: 69 70 68 65 72 4f 62 6a 2c 20 64 69 67 65 73 74  ipherObj, digest
20d0: 4f 62 6a 2c 20 6b 65 79 4f 62 6a 2c 20 69 76 4f  Obj, keyObj, ivO
20e0: 62 6a 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20  bj);.    } else 
20f0: 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73  {..Tcl_AppendRes
2100: 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 4e 6f 20  ult(interp, "No 
2110: 6f 70 65 72 61 74 69 6f 6e 20 73 70 65 63 69 66  operation specif
2120: 69 65 64 3a 20 55 73 65 20 2d 64 61 74 61 20 6f  ied: Use -data o
2130: 70 74 69 6f 6e 22 2c 20 4e 55 4c 4c 29 3b 0a 09  ption", NULL);..
2140: 72 65 73 20 3d 20 54 43 4c 5f 45 52 52 4f 52 3b  res = TCL_ERROR;
2150: 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72  .    }.    retur
2160: 6e 20 72 65 73 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d  n res;.}../*. *-
2170: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
21a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
21b0: 2d 2d 0a 20 2a 0a 20 2a 20 45 6e 63 72 79 70 74  --. *. * Encrypt
21c0: 69 6f 6e 20 43 6f 6d 6d 61 6e 64 73 20 2d 2d 0a  ion Commands --.
21d0: 20 2a 0a 20 2a 09 50 65 72 66 6f 72 6d 20 65 6e   *. *.Perform en
21e0: 63 72 79 70 74 69 6f 6e 20 66 75 6e 63 74 69 6f  cryption functio
21f0: 6e 20 61 6e 64 20 72 65 74 75 72 6e 20 72 65 73  n and return res
2200: 75 6c 74 73 0a 20 2a 0a 20 2a 20 52 65 74 75 72  ults. *. * Retur
2210: 6e 73 3a 0a 20 2a 09 54 43 4c 5f 4f 4b 20 6f 72  ns:. *.TCL_OK or
2220: 20 54 43 4c 5f 45 52 52 4f 52 0a 20 2a 0a 20 2a   TCL_ERROR. *. *
2230: 20 53 69 64 65 20 65 66 66 65 63 74 73 3a 0a 20   Side effects:. 
2240: 2a 09 43 6f 6d 6d 61 6e 64 20 64 65 70 65 6e 64  *.Command depend
2250: 65 6e 74 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  ent. *. *-------
2260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2290: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f  ------------. */
22a0: 0a 73 74 61 74 69 63 20 69 6e 74 20 45 6e 63 72  .static int Encr
22b0: 79 70 74 4f 62 6a 43 6d 64 28 43 6c 69 65 6e 74  yptObjCmd(Client
22c0: 44 61 74 61 20 63 6c 69 65 6e 74 44 61 74 61 2c  Data clientData,
22d0: 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74   Tcl_Interp *int
22e0: 65 72 70 2c 20 69 6e 74 20 6f 62 6a 63 2c 20 54  erp, int objc, T
22f0: 63 6c 5f 4f 62 6a 20 2a 63 6f 6e 73 74 20 6f 62  cl_Obj *const ob
2300: 6a 76 5b 5d 29 20 7b 0a 20 20 20 20 72 65 74 75  jv[]) {.    retu
2310: 72 6e 20 45 6e 63 72 79 70 74 4d 61 69 6e 28 54  rn EncryptMain(T
2320: 59 50 45 5f 45 4e 43 52 59 50 54 2c 20 69 6e 74  YPE_ENCRYPT, int
2330: 65 72 70 2c 20 6f 62 6a 63 2c 20 6f 62 6a 76 29  erp, objc, objv)
2340: 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  ;.}..static int 
2350: 44 65 63 72 79 70 74 4f 62 6a 43 6d 64 28 43 6c  DecryptObjCmd(Cl
2360: 69 65 6e 74 44 61 74 61 20 63 6c 69 65 6e 74 44  ientData clientD
2370: 61 74 61 2c 20 54 63 6c 5f 49 6e 74 65 72 70 20  ata, Tcl_Interp 
2380: 2a 69 6e 74 65 72 70 2c 20 69 6e 74 20 6f 62 6a  *interp, int obj
2390: 63 2c 20 54 63 6c 5f 4f 62 6a 20 2a 63 6f 6e 73  c, Tcl_Obj *cons
23a0: 74 20 6f 62 6a 76 5b 5d 29 20 7b 0a 20 20 20 20  t objv[]) {.    
23b0: 72 65 74 75 72 6e 20 45 6e 63 72 79 70 74 4d 61  return EncryptMa
23c0: 69 6e 28 54 59 50 45 5f 44 45 43 52 59 50 54 2c  in(TYPE_DECRYPT,
23d0: 20 69 6e 74 65 72 70 2c 20 6f 62 6a 63 2c 20 6f   interp, objc, o
23e0: 62 6a 76 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d  bjv);.}../*. *--
23f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2400: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2430: 2d 0a 20 2a 0a 20 2a 20 45 6e 63 72 79 70 74 5f  -. *. * Encrypt_
2440: 49 6e 69 74 69 61 6c 69 7a 65 20 2d 2d 0a 20 2a  Initialize --. *
2450: 0a 20 2a 09 43 72 65 61 74 65 20 6e 61 6d 65 73  . *.Create names
2460: 70 61 63 65 2c 20 63 6f 6d 6d 61 6e 64 73 2c 20  pace, commands, 
2470: 61 6e 64 20 72 65 67 69 73 74 65 72 20 70 61 63  and register pac
2480: 6b 61 67 65 20 76 65 72 73 69 6f 6e 0a 20 2a 0a  kage version. *.
2490: 20 2a 20 52 65 74 75 72 6e 73 3a 0a 20 2a 09 54   * Returns:. *.T
24a0: 43 4c 5f 4f 4b 20 6f 72 20 54 43 4c 5f 45 52 52  CL_OK or TCL_ERR
24b0: 4f 52 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  OR. *. * Side ef
24c0: 66 65 63 74 73 3a 0a 20 2a 09 43 72 65 61 74 65  fects:. *.Create
24d0: 73 20 63 6f 6d 6d 61 6e 64 73 0a 20 2a 0a 20 2a  s commands. *. *
24e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
24f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2500: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2510: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2520: 2d 2d 2d 0a 20 2a 2f 0a 69 6e 74 20 54 6c 73 5f  ---. */.int Tls_
2530: 45 6e 63 72 79 70 74 43 6f 6d 6d 61 6e 64 73 28  EncryptCommands(
2540: 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65  Tcl_Interp *inte
2550: 72 70 29 20 7b 0a 20 20 20 20 54 63 6c 5f 43 72  rp) {.    Tcl_Cr
2560: 65 61 74 65 4f 62 6a 43 6f 6d 6d 61 6e 64 28 69  eateObjCommand(i
2570: 6e 74 65 72 70 2c 20 22 74 6c 73 3a 3a 65 6e 63  nterp, "tls::enc
2580: 72 79 70 74 22 2c 20 45 6e 63 72 79 70 74 4f 62  rypt", EncryptOb
2590: 6a 43 6d 64 2c 20 28 43 6c 69 65 6e 74 44 61 74  jCmd, (ClientDat
25a0: 61 29 20 30 2c 20 28 54 63 6c 5f 43 6d 64 44 65  a) 0, (Tcl_CmdDe
25b0: 6c 65 74 65 50 72 6f 63 20 2a 29 20 4e 55 4c 4c  leteProc *) NULL
25c0: 29 3b 0a 20 20 20 20 54 63 6c 5f 43 72 65 61 74  );.    Tcl_Creat
25d0: 65 4f 62 6a 43 6f 6d 6d 61 6e 64 28 69 6e 74 65  eObjCommand(inte
25e0: 72 70 2c 20 22 74 6c 73 3a 3a 64 65 63 72 79 70  rp, "tls::decryp
25f0: 74 22 2c 20 44 65 63 72 79 70 74 4f 62 6a 43 6d  t", DecryptObjCm
2600: 64 2c 20 28 43 6c 69 65 6e 74 44 61 74 61 29 20  d, (ClientData) 
2610: 30 2c 20 28 54 63 6c 5f 43 6d 64 44 65 6c 65 74  0, (Tcl_CmdDelet
2620: 65 50 72 6f 63 20 2a 29 20 4e 55 4c 4c 29 3b 0a  eProc *) NULL);.
2630: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f      return TCL_O
2640: 4b 3b 0a 7d 0a 0a                                K;.}..