LCOV - code coverage report
Current view: top level - source4/kdc - sdb.c (source / functions) Hit Total Coverage
Test: coverage report for support-claim-type-attributes 6b5c566e Lines: 70 78 89.7 %
Date: 2023-11-21 12:31:41 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      524439 : void sdb_key_free(struct sdb_key *k)
      34             : {
      35      524439 :         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      524439 :         krb5_free_keyblock_contents(NULL, &k->key);
      45             : 
      46      524439 :         if (k->salt) {
      47      387737 :                 smb_krb5_free_data_contents(NULL, &k->salt->salt);
      48      387737 :                 SAFE_FREE(k->salt);
      49             :         }
      50             : 
      51      524439 :         ZERO_STRUCTP(k);
      52             : }
      53             : 
      54      962973 : void sdb_keys_free(struct sdb_keys *keys)
      55             : {
      56       30843 :         unsigned int i;
      57             : 
      58      962973 :         if (keys == NULL) {
      59           0 :                 return;
      60             :         }
      61             : 
      62     1487412 :         for (i=0; i < keys->len; i++) {
      63      524439 :                 sdb_key_free(&keys->val[i]);
      64             :         }
      65             : 
      66      962973 :         SAFE_FREE(keys->val);
      67      962973 :         ZERO_STRUCTP(keys);
      68             : }
      69             : 
      70      320991 : void sdb_entry_free(struct sdb_entry *s)
      71             : {
      72      320991 :         if (s->skdc_entry != NULL) {
      73      301489 :                 s->skdc_entry->db_entry = NULL;
      74      301489 :                 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      320991 :         krb5_free_principal(NULL, s->principal);
      83             : 
      84      320991 :         sdb_keys_free(&s->keys);
      85      320991 :         SAFE_FREE(s->etypes);
      86      320991 :         sdb_keys_free(&s->old_keys);
      87      320991 :         sdb_keys_free(&s->older_keys);
      88      320991 :         if (s->session_etypes != NULL) {
      89      220112 :                 SAFE_FREE(s->session_etypes->val);
      90             :         }
      91      320991 :         SAFE_FREE(s->session_etypes);
      92      320991 :         krb5_free_principal(NULL, s->created_by.principal);
      93      320991 :         if (s->modified_by) {
      94         162 :                 krb5_free_principal(NULL, s->modified_by->principal);
      95             :         }
      96      320991 :         SAFE_FREE(s->valid_start);
      97      320991 :         SAFE_FREE(s->valid_end);
      98      320991 :         SAFE_FREE(s->pw_end);
      99      320991 :         SAFE_FREE(s->max_life);
     100      320991 :         SAFE_FREE(s->max_renew);
     101             : 
     102      320991 :         ZERO_STRUCTP(s);
     103      320991 : }
     104             : 
     105             : /* Set the etypes of an sdb_entry based on its available current keys. */
     106      300814 : krb5_error_code sdb_entry_set_etypes(struct sdb_entry *s)
     107             : {
     108      300814 :         if (s->keys.val != NULL) {
     109       10142 :                 unsigned i;
     110             : 
     111      300814 :                 s->etypes = malloc(sizeof(*s->etypes));
     112      300814 :                 if (s->etypes == NULL) {
     113           0 :                         return ENOMEM;
     114             :                 }
     115             : 
     116      300814 :                 s->etypes->len = s->keys.len;
     117             : 
     118      300814 :                 s->etypes->val = calloc(s->etypes->len, sizeof(*s->etypes->val));
     119      300814 :                 if (s->etypes->val == NULL) {
     120           0 :                         SAFE_FREE(s->etypes);
     121           0 :                         return ENOMEM;
     122             :                 }
     123             : 
     124     1135206 :                 for (i = 0; i < s->etypes->len; i++) {
     125      834392 :                         const struct sdb_key *k = &s->keys.val[i];
     126             : 
     127      834392 :                         s->etypes->val[i] = KRB5_KEY_TYPE(&(k->key));
     128             :                 }
     129             :         }
     130             : 
     131      290672 :         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      220172 : 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      220172 :         unsigned len = 0;
     144             : 
     145      220172 :         if (add_aes256) {
     146             :                 /* Reserve space for AES256 */
     147      207493 :                 len += 1;
     148             :         }
     149             : 
     150      220172 :         if (add_aes128) {
     151             :                 /* Reserve space for AES128 */
     152      206254 :                 len += 1;
     153             :         }
     154             : 
     155      220172 :         if (add_rc4) {
     156             :                 /* Reserve space for RC4. */
     157      218615 :                 len += 1;
     158             :         }
     159             : 
     160      220172 :         if (len != 0) {
     161      220112 :                 unsigned j = 0;
     162             : 
     163      220112 :                 s->session_etypes = malloc(sizeof(*s->session_etypes));
     164      220112 :                 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      220112 :                 s->session_etypes->val = calloc(len, sizeof(*s->session_etypes->val));
     171      220112 :                 if (s->session_etypes->val == NULL) {
     172           0 :                         SAFE_FREE(s->session_etypes);
     173           0 :                         return ENOMEM;
     174             :                 }
     175             : 
     176      220112 :                 if (add_aes256) {
     177             :                         /* Add AES256 */
     178      207493 :                         s->session_etypes->val[j++] = ENCTYPE_AES256_CTS_HMAC_SHA1_96;
     179             :                 }
     180             : 
     181      220112 :                 if (add_aes128) {
     182             :                         /* Add AES128. */
     183      206254 :                         s->session_etypes->val[j++] = ENCTYPE_AES128_CTS_HMAC_SHA1_96;
     184             :                 }
     185             : 
     186      220112 :                 if (add_rc4) {
     187             :                         /* Add RC4. */
     188      218615 :                         s->session_etypes->val[j++] = ENCTYPE_ARCFOUR_HMAC;
     189             :                 }
     190             : 
     191      220112 :                 s->session_etypes->len = j;
     192             :         }
     193             : 
     194      212840 :         return 0;
     195             : }

Generated by: LCOV version 1.14