LCOV - code coverage report
Current view: top level - source4/kdc - sdb.c (source / functions) Hit Total Coverage
Test: coverage report for master 98b443d9 Lines: 70 78 89.7 %
Date: 2024-05-31 13:13:24 Functions: 5 5 100.0 %

          Line data    Source code
       1             : /*
       2             :    Unix SMB/CIFS implementation.
       3             : 
       4             :    Database Glue between Samba and the KDC
       5             : 
       6             :    Copyright (C) Guenther Deschner <gd@samba.org> 2014
       7             :    Copyright (C) Andreas Schneider <asn@samba.org> 2014
       8             : 
       9             :    This program is free software; you can redistribute it and/or modify
      10             :    it under the terms of the GNU General Public License as published by
      11             :    the Free Software Foundation; either version 3 of the License, or
      12             :    (at your option) any later version.
      13             : 
      14             :    This program is distributed in the hope that it will be useful,
      15             :    but WITHOUT ANY WARRANTY; without even the implied warranty of
      16             :    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      17             :    GNU General Public License for more details.
      18             : 
      19             : 
      20             :    You should have received a copy of the GNU General Public License
      21             :    along with this program.  If not, see <http://www.gnu.org/licenses/>.
      22             : */
      23             : 
      24             : #include "includes.h"
      25             : #include "system/kerberos.h"
      26             : #include "sdb.h"
      27             : #include "samba_kdc.h"
      28             : #include "lib/krb5_wrap/krb5_samba.h"
      29             : 
      30             : #undef DBGC_CLASS
      31             : #define DBGC_CLASS DBGC_KERBEROS
      32             : 
      33      537580 : void sdb_key_free(struct sdb_key *k)
      34             : {
      35      537580 :         if (k == NULL) {
      36           0 :                 return;
      37             :         }
      38             : 
      39             :         /*
      40             :          * Passing NULL as the Kerberos context is intentional here, as
      41             :          * both Heimdal and MIT libraries don't use the context when
      42             :          * clearing the keyblocks.
      43             :          */
      44      537580 :         krb5_free_keyblock_contents(NULL, &k->key);
      45             : 
      46      537580 :         if (k->salt) {
      47      399293 :                 smb_krb5_free_data_contents(NULL, &k->salt->salt);
      48      399293 :                 SAFE_FREE(k->salt);
      49             :         }
      50             : 
      51      537580 :         ZERO_STRUCTP(k);
      52             : }
      53             : 
      54      986697 : void sdb_keys_free(struct sdb_keys *keys)
      55             : {
      56       31137 :         unsigned int i;
      57             : 
      58      986697 :         if (keys == NULL) {
      59           0 :                 return;
      60             :         }
      61             : 
      62     1524277 :         for (i=0; i < keys->len; i++) {
      63      537580 :                 sdb_key_free(&keys->val[i]);
      64             :         }
      65             : 
      66      986697 :         SAFE_FREE(keys->val);
      67      986697 :         ZERO_STRUCTP(keys);
      68             : }
      69             : 
      70      328899 : void sdb_entry_free(struct sdb_entry *s)
      71             : {
      72      328899 :         if (s->skdc_entry != NULL) {
      73      308354 :                 s->skdc_entry->db_entry = NULL;
      74      308354 :                 TALLOC_FREE(s->skdc_entry);
      75             :         }
      76             : 
      77             :         /*
      78             :          * Passing NULL as the Kerberos context is intentional here, as both
      79             :          * Heimdal and MIT libraries don't use the context when clearing the
      80             :          * principals.
      81             :          */
      82      328899 :         krb5_free_principal(NULL, s->principal);
      83             : 
      84      328899 :         sdb_keys_free(&s->keys);
      85      328899 :         SAFE_FREE(s->etypes);
      86      328899 :         sdb_keys_free(&s->old_keys);
      87      328899 :         sdb_keys_free(&s->older_keys);
      88      328899 :         if (s->session_etypes != NULL) {
      89      224595 :                 SAFE_FREE(s->session_etypes->val);
      90             :         }
      91      328899 :         SAFE_FREE(s->session_etypes);
      92      328899 :         krb5_free_principal(NULL, s->created_by.principal);
      93      328899 :         if (s->modified_by) {
      94         264 :                 krb5_free_principal(NULL, s->modified_by->principal);
      95             :         }
      96      328899 :         SAFE_FREE(s->valid_start);
      97      328899 :         SAFE_FREE(s->valid_end);
      98      328899 :         SAFE_FREE(s->pw_end);
      99      328899 :         SAFE_FREE(s->max_life);
     100      328899 :         SAFE_FREE(s->max_renew);
     101             : 
     102      328899 :         ZERO_STRUCTP(s);
     103      328899 : }
     104             : 
     105             : /* Set the etypes of an sdb_entry based on its available current keys. */
     106      307679 : krb5_error_code sdb_entry_set_etypes(struct sdb_entry *s)
     107             : {
     108      307679 :         if (s->keys.val != NULL) {
     109       10240 :                 unsigned i;
     110             : 
     111      307679 :                 s->etypes = malloc(sizeof(*s->etypes));
     112      307679 :                 if (s->etypes == NULL) {
     113           0 :                         return ENOMEM;
     114             :                 }
     115             : 
     116      307679 :                 s->etypes->len = s->keys.len;
     117             : 
     118      307679 :                 s->etypes->val = calloc(s->etypes->len, sizeof(*s->etypes->val));
     119      307679 :                 if (s->etypes->val == NULL) {
     120           0 :                         SAFE_FREE(s->etypes);
     121           0 :                         return ENOMEM;
     122             :                 }
     123             : 
     124     1160412 :                 for (i = 0; i < s->etypes->len; i++) {
     125      852733 :                         const struct sdb_key *k = &s->keys.val[i];
     126             : 
     127      852733 :                         s->etypes->val[i] = KRB5_KEY_TYPE(&(k->key));
     128             :                 }
     129             :         }
     130             : 
     131      297439 :         return 0;
     132             : }
     133             : 
     134             : /*
     135             :  * Set the session etypes of a server sdb_entry based on its etypes, forcing in
     136             :  * strong etypes as desired.
     137             :  */
     138      224655 : krb5_error_code sdb_entry_set_session_etypes(struct sdb_entry *s,
     139             :                                              bool add_aes256,
     140             :                                              bool add_aes128,
     141             :                                              bool add_rc4)
     142             : {
     143      224655 :         unsigned len = 0;
     144             : 
     145      224655 :         if (add_aes256) {
     146             :                 /* Reserve space for AES256 */
     147      212004 :                 len += 1;
     148             :         }
     149             : 
     150      224655 :         if (add_aes128) {
     151             :                 /* Reserve space for AES128 */
     152      209829 :                 len += 1;
     153             :         }
     154             : 
     155      224655 :         if (add_rc4) {
     156             :                 /* Reserve space for RC4. */
     157      222150 :                 len += 1;
     158             :         }
     159             : 
     160      224655 :         if (len != 0) {
     161      224595 :                 unsigned j = 0;
     162             : 
     163      224595 :                 s->session_etypes = malloc(sizeof(*s->session_etypes));
     164      224595 :                 if (s->session_etypes == NULL) {
     165           0 :                         return ENOMEM;
     166             :                 }
     167             : 
     168             :                 /* session_etypes must be sorted in order of strength, with preferred etype first. */
     169             : 
     170      224595 :                 s->session_etypes->val = calloc(len, sizeof(*s->session_etypes->val));
     171      224595 :                 if (s->session_etypes->val == NULL) {
     172           0 :                         SAFE_FREE(s->session_etypes);
     173           0 :                         return ENOMEM;
     174             :                 }
     175             : 
     176      224595 :                 if (add_aes256) {
     177             :                         /* Add AES256 */
     178      212004 :                         s->session_etypes->val[j++] = ENCTYPE_AES256_CTS_HMAC_SHA1_96;
     179             :                 }
     180             : 
     181      224595 :                 if (add_aes128) {
     182             :                         /* Add AES128. */
     183      209829 :                         s->session_etypes->val[j++] = ENCTYPE_AES128_CTS_HMAC_SHA1_96;
     184             :                 }
     185             : 
     186      224595 :                 if (add_rc4) {
     187             :                         /* Add RC4. */
     188      222150 :                         s->session_etypes->val[j++] = ENCTYPE_ARCFOUR_HMAC;
     189             :                 }
     190             : 
     191      224595 :                 s->session_etypes->len = j;
     192             :         }
     193             : 
     194      217260 :         return 0;
     195             : }

Generated by: LCOV version 1.14