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;.}..