LCOV - code coverage report
Current view: top level - libcli/security - access_check.c (source / functions) Hit Total Coverage
Test: coverage report for vadcx-master-patch-75612 fe003de8 Lines: 323 413 78.2 %
Date: 2024-02-29 22:57:05 Functions: 13 13 100.0 %

          Line data    Source code
       1             : /*
       2             :    Unix SMB/CIFS implementation.
       3             : 
       4             :    Copyright (C) Andrew Tridgell 2004
       5             :    Copyright (C) Gerald Carter 2005
       6             :    Copyright (C) Volker Lendecke 2007
       7             :    Copyright (C) Jeremy Allison 2008
       8             :    Copyright (C) Andrew Bartlett 2010
       9             : 
      10             :    This program is free software; you can redistribute it and/or modify
      11             :    it under the terms of the GNU General Public License as published by
      12             :    the Free Software Foundation; either version 3 of the License, or
      13             :    (at your option) any later version.
      14             : 
      15             :    This program is distributed in the hope that it will be useful,
      16             :    but WITHOUT ANY WARRANTY; without even the implied warranty of
      17             :    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      18             :    GNU General Public License for more details.
      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 "replace.h"
      25             : #include "lib/util/debug.h"
      26             : #include "libcli/security/security.h"
      27             : #include "librpc/gen_ndr/conditional_ace.h"
      28             : #include "libcli/security/conditional_ace.h"
      29             : 
      30             : /* Map generic access rights to object specific rights.  This technique is
      31             :    used to give meaning to assigning read, write, execute and all access to
      32             :    objects.  Each type of object has its own mapping of generic to object
      33             :    specific access rights. */
      34             : 
      35      694122 : void se_map_generic(uint32_t *access_mask, const struct generic_mapping *mapping)
      36             : {
      37      694122 :         uint32_t old_mask = *access_mask;
      38             : 
      39      694122 :         if (*access_mask & GENERIC_READ_ACCESS) {
      40        4511 :                 *access_mask &= ~GENERIC_READ_ACCESS;
      41        4511 :                 *access_mask |= mapping->generic_read;
      42             :         }
      43             : 
      44      694122 :         if (*access_mask & GENERIC_WRITE_ACCESS) {
      45         164 :                 *access_mask &= ~GENERIC_WRITE_ACCESS;
      46         164 :                 *access_mask |= mapping->generic_write;
      47             :         }
      48             : 
      49      694122 :         if (*access_mask & GENERIC_EXECUTE_ACCESS) {
      50       11539 :                 *access_mask &= ~GENERIC_EXECUTE_ACCESS;
      51       11539 :                 *access_mask |= mapping->generic_execute;
      52             :         }
      53             : 
      54      694122 :         if (*access_mask & GENERIC_ALL_ACCESS) {
      55        4153 :                 *access_mask &= ~GENERIC_ALL_ACCESS;
      56        4153 :                 *access_mask |= mapping->generic_all;
      57             :         }
      58             : 
      59      694122 :         if (old_mask != *access_mask) {
      60       12511 :                 DEBUG(10, ("se_map_generic(): mapped mask 0x%08x to 0x%08x\n",
      61             :                            old_mask, *access_mask));
      62             :         }
      63      694122 : }
      64             : 
      65             : /* Map generic access rights to object specific rights for all the ACE's
      66             :  * in a security_acl.
      67             :  */
      68             : 
      69       15333 : void security_acl_map_generic(struct security_acl *sa,
      70             :                                 const struct generic_mapping *mapping)
      71             : {
      72         149 :         unsigned int i;
      73             : 
      74       15333 :         if (!sa) {
      75           0 :                 return;
      76             :         }
      77             : 
      78       77139 :         for (i = 0; i < sa->num_aces; i++) {
      79       61806 :                 se_map_generic(&sa->aces[i].access_mask, mapping);
      80             :         }
      81             : }
      82             : 
      83             : /* Map standard access rights to object specific rights.  This technique is
      84             :    used to give meaning to assigning read, write, execute and all access to
      85             :    objects.  Each type of object has its own mapping of standard to object
      86             :    specific access rights. */
      87             : 
      88         624 : void se_map_standard(uint32_t *access_mask, const struct standard_mapping *mapping)
      89             : {
      90         624 :         uint32_t old_mask = *access_mask;
      91             : 
      92         624 :         if (*access_mask & SEC_STD_READ_CONTROL) {
      93          16 :                 *access_mask &= ~SEC_STD_READ_CONTROL;
      94          16 :                 *access_mask |= mapping->std_read;
      95             :         }
      96             : 
      97         624 :         if (*access_mask & (SEC_STD_DELETE|SEC_STD_WRITE_DAC|SEC_STD_WRITE_OWNER|SEC_STD_SYNCHRONIZE)) {
      98           8 :                 *access_mask &= ~(SEC_STD_DELETE|SEC_STD_WRITE_DAC|SEC_STD_WRITE_OWNER|SEC_STD_SYNCHRONIZE);
      99           8 :                 *access_mask |= mapping->std_all;
     100             :         }
     101             : 
     102         624 :         if (old_mask != *access_mask) {
     103           4 :                 DEBUG(10, ("se_map_standard(): mapped mask 0x%08x to 0x%08x\n",
     104             :                            old_mask, *access_mask));
     105             :         }
     106         624 : }
     107             : 
     108             : enum ace_callback_result {
     109             :         ACE_CALLBACK_DENY,
     110             :         ACE_CALLBACK_ALLOW,
     111             :         ACE_CALLBACK_SKIP,      /* do not apply this ACE */
     112             :         ACE_CALLBACK_INVALID    /* we don't want to process the conditional ACE */
     113             : };
     114             : 
     115             : 
     116         529 : static enum ace_callback_result check_callback_ace_allow(
     117             :         const struct security_ace *ace,
     118             :         const struct security_token *token,
     119             :         const struct security_descriptor *sd)
     120             : {
     121         135 :         bool ok;
     122         135 :         int result;
     123             : 
     124         529 :         switch (token->evaluate_claims) {
     125         394 :         case CLAIMS_EVALUATION_ALWAYS:
     126         529 :                 break;
     127             : 
     128           0 :         case CLAIMS_EVALUATION_INVALID_STATE:
     129           0 :                 DBG_WARNING("Refusing to evaluate ACL with "
     130             :                             "conditional ACE against security "
     131             :                             "token with CLAIMS_EVALUATION_INVALID_STATE\n");
     132           0 :                 return ACE_CALLBACK_INVALID;
     133           0 :         case CLAIMS_EVALUATION_NEVER:
     134             :         default:
     135             :                 /*
     136             :                  * We are asked to pretend we never understood this
     137             :                  * ACE type.
     138             :                  *
     139             :                  * By returning SKIP, this ACE will not adjust any
     140             :                  * permission bits making it an effective no-op, which
     141             :                  * was the default behaviour up to Samba 4.19.
     142             :                  */
     143           0 :                 return ACE_CALLBACK_SKIP;
     144             :         }
     145             : 
     146         529 :         if (ace->type != SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK &&
     147           0 :             ace->type != SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK_OBJECT) {
     148             :                 /* This indicates a programming error */
     149           0 :                 DBG_ERR("bad conditional allow ACE type: %u\n", ace->type);
     150           0 :                 return ACE_CALLBACK_INVALID;
     151             :         }
     152             : 
     153             :         /*
     154             :          * Until we discover otherwise, we assume all callback ACEs
     155             :          * are conditional ACEs.
     156             :          */
     157         529 :         ok = access_check_conditional_ace(ace, token, sd, &result);
     158         529 :         if (!ok) {
     159             :                 /*
     160             :                  * An error in processing the conditional ACE is
     161             :                  * treated as UNKNOWN, which amounts to a DENY/SKIP
     162             :                  * result.
     163             :                  *
     164             :                  * This is different from the INVALID result which
     165             :                  * means we should not be thinking about conditional
     166             :                  * ACES at all, and will abort the whole access check.
     167             :                  */
     168           0 :                 DBG_WARNING("callback ACE was not a valid conditional ACE\n");
     169           0 :                 return ACE_CALLBACK_SKIP;
     170             :         }
     171         529 :         if (result == ACE_CONDITION_TRUE) {
     172         284 :                 return ACE_CALLBACK_ALLOW;
     173             :         }
     174             :         /* UNKNOWN means do not allow */
     175         196 :         return ACE_CALLBACK_SKIP;
     176             : }
     177             : 
     178             : 
     179         142 : static enum ace_callback_result check_callback_ace_deny(
     180             :         const struct security_ace *ace,
     181             :         const struct security_token *token,
     182             :         const struct security_descriptor *sd)
     183             : {
     184           4 :         bool ok;
     185           4 :         int result;
     186             : 
     187         142 :         switch (token->evaluate_claims) {
     188         138 :         case CLAIMS_EVALUATION_ALWAYS:
     189         142 :                 break;
     190             : 
     191           0 :         case CLAIMS_EVALUATION_INVALID_STATE:
     192           0 :                 DBG_WARNING("Refusing to evaluate ACL with "
     193             :                             "conditional ACE against security "
     194             :                             "token with CLAIMS_EVALUATION_INVALID_STATE\n");
     195           0 :                 return ACE_CALLBACK_INVALID;
     196           0 :         case CLAIMS_EVALUATION_NEVER:
     197             :         default:
     198             :                 /*
     199             :                  * We are asked to pretend we never understood this
     200             :                  * ACE type.
     201             :                  */
     202           0 :                 return ACE_CALLBACK_SKIP;
     203             :         }
     204             : 
     205         142 :         if (ace->type != SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK &&
     206           0 :             ace->type != SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK_OBJECT) {
     207           0 :                 DBG_ERR("bad conditional deny ACE type: %u\n", ace->type);
     208           0 :                 return ACE_CALLBACK_INVALID;
     209             :         }
     210             : 
     211             :         /*
     212             :          * Until we discover otherwise, we assume all callback ACEs
     213             :          * are conditional ACEs.
     214             :          */
     215         142 :         ok = access_check_conditional_ace(ace, token, sd, &result);
     216         142 :         if (!ok) {
     217             :                 /*
     218             :                  * An error in processing the conditional ACE is
     219             :                  * treated as UNKNOWN, which means DENY.
     220             :                  */
     221           0 :                 DBG_WARNING("callback ACE was not a valid conditional ACE\n");
     222           0 :                 return ACE_CALLBACK_DENY;
     223             :         }
     224         142 :         if (result != ACE_CONDITION_FALSE) {
     225             :                 /* UNKNOWN means deny */
     226         120 :                 return ACE_CALLBACK_DENY;
     227             :         }
     228          22 :         return ACE_CALLBACK_SKIP;
     229             : }
     230             : 
     231             : 
     232             : /*
     233             :   perform a SEC_FLAG_MAXIMUM_ALLOWED access check
     234             : */
     235      110597 : static uint32_t access_check_max_allowed(const struct security_descriptor *sd,
     236             :                                          const struct security_token *token,
     237             :                                          enum implicit_owner_rights implicit_owner_rights)
     238             : {
     239      110597 :         uint32_t denied = 0, granted = 0;
     240      110597 :         bool am_owner = false;
     241      110597 :         bool have_owner_rights_ace = false;
     242        1774 :         unsigned i;
     243             : 
     244      110597 :         if (sd->dacl == NULL) {
     245           0 :                 if (security_token_has_sid(token, sd->owner_sid)) {
     246           0 :                         switch (implicit_owner_rights) {
     247           0 :                         case IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS:
     248           0 :                                 granted |= SEC_STD_WRITE_DAC;
     249           0 :                                 FALL_THROUGH;
     250           0 :                         case IMPLICIT_OWNER_READ_CONTROL_RIGHTS:
     251           0 :                                 granted |= SEC_STD_READ_CONTROL;
     252           0 :                                 break;
     253             :                         }
     254             :                 }
     255           0 :                 return granted;
     256             :         }
     257             : 
     258      110597 :         if (security_token_has_sid(token, sd->owner_sid)) {
     259             :                 /*
     260             :                  * Check for explicit owner rights: if there are none, we remove
     261             :                  * the default owner right SEC_STD_WRITE_DAC|SEC_STD_READ_CONTROL
     262             :                  * from remaining_access. Otherwise we just process the
     263             :                  * explicitly granted rights when processing the ACEs.
     264             :                  */
     265        5325 :                 am_owner = true;
     266             : 
     267       36261 :                 for (i=0; i < sd->dacl->num_aces; i++) {
     268       31826 :                         struct security_ace *ace = &sd->dacl->aces[i];
     269             : 
     270       31826 :                         if (ace->flags & SEC_ACE_FLAG_INHERIT_ONLY) {
     271        1507 :                                 continue;
     272             :                         }
     273             : 
     274       31183 :                         have_owner_rights_ace = dom_sid_equal(
     275       30319 :                                 &ace->trustee, &global_sid_Owner_Rights);
     276       30319 :                         if (have_owner_rights_ace) {
     277          12 :                                 break;
     278             :                         }
     279             :                 }
     280             :         }
     281             : 
     282      110597 :         if (am_owner && !have_owner_rights_ace) {
     283        4435 :                 switch (implicit_owner_rights) {
     284        4435 :                 case IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS:
     285        4435 :                         granted |= SEC_STD_WRITE_DAC;
     286         114 :                         FALL_THROUGH;
     287        4435 :                 case IMPLICIT_OWNER_READ_CONTROL_RIGHTS:
     288        4435 :                         granted |= SEC_STD_READ_CONTROL;
     289        4435 :                         break;
     290             :                 }
     291             :         }
     292             : 
     293      249265 :         for (i = 0;i<sd->dacl->num_aces; i++) {
     294      138668 :                 struct security_ace *ace = &sd->dacl->aces[i];
     295      138668 :                 bool is_owner_rights_ace = false;
     296             : 
     297      138668 :                 if (ace->flags & SEC_ACE_FLAG_INHERIT_ONLY) {
     298        1507 :                         continue;
     299             :                 }
     300             : 
     301      137161 :                 if (am_owner) {
     302       30327 :                         is_owner_rights_ace = dom_sid_equal(
     303       30327 :                                 &ace->trustee, &global_sid_Owner_Rights);
     304             :                 }
     305             : 
     306      138025 :                 if (!is_owner_rights_ace &&
     307      137145 :                     !security_token_has_sid(token, &ace->trustee))
     308             :                 {
     309       23293 :                         continue;
     310             :                 }
     311             : 
     312      113868 :                 switch (ace->type) {
     313      113829 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED:
     314      113829 :                         granted |= ace->access_mask;
     315      113829 :                         break;
     316          18 :                 case SEC_ACE_TYPE_ACCESS_DENIED:
     317             :                 case SEC_ACE_TYPE_ACCESS_DENIED_OBJECT:
     318          18 :                         denied |= ~granted & ace->access_mask;
     319          18 :                         break;
     320             : 
     321           0 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK:
     322             :                 {
     323           0 :                         enum ace_callback_result allow =
     324           0 :                                 check_callback_ace_allow(ace, token, sd);
     325           0 :                         if (allow == ACE_CALLBACK_INVALID) {
     326           0 :                                 return 0;
     327             :                         }
     328           0 :                         if (allow == ACE_CALLBACK_ALLOW) {
     329           0 :                                 granted |= ace->access_mask;
     330             :                         }
     331           0 :                         break;
     332             :                 }
     333             : 
     334           0 :                 case SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK:
     335             :                 {
     336           0 :                         enum ace_callback_result deny =
     337           0 :                                 check_callback_ace_deny(ace, token, sd);
     338           0 :                         if (deny == ACE_CALLBACK_INVALID) {
     339           0 :                                 return 0;
     340             :                         }
     341           0 :                         if (deny == ACE_CALLBACK_DENY) {
     342           0 :                                 denied |= ~granted & ace->access_mask;
     343             :                         }
     344           0 :                         break;
     345             :                 }
     346             : 
     347          21 :                 default:        /* Other ACE types not handled/supported */
     348          21 :                         break;
     349             :                 }
     350             :         }
     351             : 
     352      110597 :         return granted & ~denied;
     353             : }
     354             : 
     355             : 
     356             : 
     357      869730 : static NTSTATUS se_access_check_implicit_owner(const struct security_descriptor *sd,
     358             :                                                const struct security_token *token,
     359             :                                                uint32_t access_desired,
     360             :                                                uint32_t *access_granted,
     361             :                                                enum implicit_owner_rights implicit_owner_rights)
     362             : {
     363        3127 :         uint32_t i;
     364        3127 :         uint32_t bits_remaining;
     365      869730 :         uint32_t explicitly_denied_bits = 0;
     366      869730 :         bool am_owner = false;
     367      869730 :         bool have_owner_rights_ace = false;
     368             : 
     369      869730 :         switch (token->evaluate_claims) {
     370      199093 :         case CLAIMS_EVALUATION_INVALID_STATE:
     371      199093 :                 if (token->num_local_claims > 0 ||
     372      199093 :                     token->num_user_claims > 0 ||
     373      199093 :                     token->num_device_claims > 0 ||
     374      199093 :                     token->num_device_sids > 0) {
     375           0 :                         DBG_WARNING("Refusing to evaluate token with claims or device SIDs but also "
     376             :                                     "with CLAIMS_EVALUATION_INVALID_STATE\n");
     377           0 :                         return NT_STATUS_INVALID_TOKEN;
     378             :                 }
     379      199021 :                 break;
     380      667582 :         case CLAIMS_EVALUATION_ALWAYS:
     381             :         case CLAIMS_EVALUATION_NEVER:
     382      667582 :                 break;
     383             :         }
     384             : 
     385      869730 :         *access_granted = access_desired;
     386      869730 :         bits_remaining = access_desired;
     387             : 
     388             :         /* handle the maximum allowed flag */
     389      869730 :         if (access_desired & SEC_FLAG_MAXIMUM_ALLOWED) {
     390        4655 :                 uint32_t orig_access_desired = access_desired;
     391             : 
     392        4655 :                 access_desired |= access_check_max_allowed(sd, token, implicit_owner_rights);
     393        4655 :                 access_desired &= ~SEC_FLAG_MAXIMUM_ALLOWED;
     394        4655 :                 *access_granted = access_desired;
     395        4655 :                 bits_remaining = access_desired;
     396             : 
     397        4655 :                 DEBUG(10,("se_access_check: MAX desired = 0x%x, granted = 0x%x, remaining = 0x%x\n",
     398             :                         orig_access_desired,
     399             :                         *access_granted,
     400             :                         bits_remaining));
     401             :         }
     402             : 
     403             :         /* a NULL dacl allows access */
     404      869730 :         if ((sd->type & SEC_DESC_DACL_PRESENT) && sd->dacl == NULL) {
     405          77 :                 *access_granted = access_desired;
     406          77 :                 return NT_STATUS_OK;
     407             :         }
     408             : 
     409      869653 :         if (sd->dacl == NULL) {
     410           1 :                 goto done;
     411             :         }
     412             : 
     413      869652 :         if (security_token_has_sid(token, sd->owner_sid)) {
     414             :                 /*
     415             :                  * Check for explicit owner rights: if there are none, we remove
     416             :                  * the default owner right SEC_STD_WRITE_DAC|SEC_STD_READ_CONTROL
     417             :                  * from remaining_access. Otherwise we just process the
     418             :                  * explicitly granted rights when processing the ACEs.
     419             :                  */
     420      387447 :                 am_owner = true;
     421             : 
     422     1659935 :                 for (i=0; i < sd->dacl->num_aces; i++) {
     423     1276486 :                         struct security_ace *ace = &sd->dacl->aces[i];
     424             : 
     425     1276486 :                         if (ace->flags & SEC_ACE_FLAG_INHERIT_ONLY) {
     426       81655 :                                 continue;
     427             :                         }
     428             : 
     429     1198071 :                         have_owner_rights_ace = dom_sid_equal(
     430     1194831 :                                 &ace->trustee, &global_sid_Owner_Rights);
     431     1194831 :                         if (have_owner_rights_ace) {
     432          80 :                                 break;
     433             :                         }
     434             :                 }
     435             :         }
     436      869652 :         if (am_owner && !have_owner_rights_ace) {
     437      383449 :                 switch (implicit_owner_rights) {
     438      383449 :                 case IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS:
     439      383449 :                         bits_remaining &= ~SEC_STD_WRITE_DAC;
     440         906 :                         FALL_THROUGH;
     441      383449 :                 case IMPLICIT_OWNER_READ_CONTROL_RIGHTS:
     442      383449 :                         bits_remaining &= ~SEC_STD_READ_CONTROL;
     443      383449 :                         break;
     444             :                 }
     445             :         }
     446             : 
     447             :         /* check each ace in turn. */
     448     1775630 :         for (i=0; bits_remaining && i < sd->dacl->num_aces; i++) {
     449      905978 :                 struct security_ace *ace = &sd->dacl->aces[i];
     450      905978 :                 bool is_owner_rights_ace = false;
     451             : 
     452      905978 :                 if (ace->flags & SEC_ACE_FLAG_INHERIT_ONLY) {
     453        4233 :                         continue;
     454             :                 }
     455             : 
     456      901745 :                 if (am_owner) {
     457      391499 :                         is_owner_rights_ace = dom_sid_equal(
     458      391499 :                                 &ace->trustee, &global_sid_Owner_Rights);
     459             :                 }
     460             : 
     461      902804 :                 if (!is_owner_rights_ace &&
     462      901641 :                     !security_token_has_sid(token, &ace->trustee))
     463             :                 {
     464       39989 :                         continue;
     465             :                 }
     466             : 
     467      861756 :                 switch (ace->type) {
     468      861262 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED:
     469      861262 :                         bits_remaining &= ~ace->access_mask;
     470      861262 :                         break;
     471         107 :                 case SEC_ACE_TYPE_ACCESS_DENIED:
     472             :                 case SEC_ACE_TYPE_ACCESS_DENIED_OBJECT:
     473         107 :                         explicitly_denied_bits |= (bits_remaining & ace->access_mask);
     474         107 :                         break;
     475             : 
     476         135 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK:
     477             :                 {
     478         135 :                         enum ace_callback_result allow =
     479         135 :                                 check_callback_ace_allow(ace, token, sd);
     480         135 :                         if (allow == ACE_CALLBACK_INVALID) {
     481           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     482             :                         }
     483         135 :                         if (allow == ACE_CALLBACK_ALLOW) {
     484          86 :                                 bits_remaining &= ~ace->access_mask;
     485             :                         }
     486           0 :                         break;
     487             :                 }
     488             : 
     489           4 :                 case SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK:
     490             :                 case SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK_OBJECT:
     491             :                 {
     492           4 :                         enum ace_callback_result deny =
     493           4 :                                 check_callback_ace_deny(ace, token, sd);
     494           4 :                         if (deny == ACE_CALLBACK_INVALID) {
     495           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     496             :                         }
     497           4 :                         if (deny == ACE_CALLBACK_DENY) {
     498           4 :                                 explicitly_denied_bits |= (bits_remaining & ace->access_mask);
     499             :                         }
     500           0 :                         break;
     501             :                 }
     502             : 
     503         248 :                 default:        /* Other ACE types not handled/supported */
     504         248 :                         break;
     505             :                 }
     506             :         }
     507             : 
     508             :         /* Explicitly denied bits always override */
     509      869652 :         bits_remaining |= explicitly_denied_bits;
     510             : 
     511             :         /*
     512             :          * We check privileges here because they override even DENY entries.
     513             :          */
     514             : 
     515             :         /* Does the user have the privilege to gain SEC_PRIV_SECURITY? */
     516      869652 :         if (bits_remaining & SEC_FLAG_SYSTEM_SECURITY) {
     517       21387 :                 if (security_token_has_privilege(token, SEC_PRIV_SECURITY)) {
     518       19906 :                         bits_remaining &= ~SEC_FLAG_SYSTEM_SECURITY;
     519             :                 } else {
     520        1481 :                         return NT_STATUS_PRIVILEGE_NOT_HELD;
     521             :                 }
     522             :         }
     523             : 
     524      872454 :         if ((bits_remaining & SEC_STD_WRITE_OWNER) &&
     525        4283 :              security_token_has_privilege(token, SEC_PRIV_TAKE_OWNERSHIP)) {
     526        2917 :                 bits_remaining &= ~(SEC_STD_WRITE_OWNER);
     527             :         }
     528             : 
     529      865254 : done:
     530      868172 :         if (bits_remaining != 0) {
     531       13090 :                 *access_granted = bits_remaining;
     532       13090 :                 return NT_STATUS_ACCESS_DENIED;
     533             :         }
     534             : 
     535      855082 :         return NT_STATUS_OK;
     536             : }
     537             : 
     538             : /*
     539             :   The main entry point for access checking. If returning ACCESS_DENIED
     540             :   this function returns the denied bits in the uint32_t pointed
     541             :   to by the access_granted pointer.
     542             : */
     543      210558 : NTSTATUS se_access_check(const struct security_descriptor *sd,
     544             :                          const struct security_token *token,
     545             :                          uint32_t access_desired,
     546             :                          uint32_t *access_granted)
     547             : {
     548      210558 :         return se_access_check_implicit_owner(sd,
     549             :                                               token,
     550             :                                               access_desired,
     551             :                                               access_granted,
     552             :                                               IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS);
     553             : }
     554             : 
     555             : /*
     556             :   The main entry point for access checking FOR THE FILE SERVER ONLY !
     557             :   If returning ACCESS_DENIED this function returns the denied bits in
     558             :   the uint32_t pointed to by the access_granted pointer.
     559             : */
     560      659172 : NTSTATUS se_file_access_check(const struct security_descriptor *sd,
     561             :                           const struct security_token *token,
     562             :                           bool priv_open_requested,
     563             :                           uint32_t access_desired,
     564             :                           uint32_t *access_granted)
     565             : {
     566        2770 :         uint32_t bits_remaining;
     567        2770 :         NTSTATUS status;
     568             : 
     569      659172 :         if (!priv_open_requested) {
     570             :                 /* Fall back to generic se_access_check(). */
     571      553200 :                 return se_access_check_implicit_owner(sd,
     572             :                                                       token,
     573             :                                                       access_desired,
     574             :                                                       access_granted,
     575             :                                                       IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS);
     576             :         }
     577             : 
     578             :         /*
     579             :          * We need to handle the maximum allowed flag
     580             :          * outside of se_access_check(), as we need to
     581             :          * add in the access allowed by the privileges
     582             :          * as well.
     583             :          */
     584             : 
     585      105972 :         if (access_desired & SEC_FLAG_MAXIMUM_ALLOWED) {
     586      105942 :                 uint32_t orig_access_desired = access_desired;
     587             : 
     588      105942 :                 access_desired |= access_check_max_allowed(sd, token, true);
     589      105942 :                 access_desired &= ~SEC_FLAG_MAXIMUM_ALLOWED;
     590             : 
     591      105942 :                 if (security_token_has_privilege(token, SEC_PRIV_BACKUP)) {
     592       19396 :                         access_desired |= SEC_RIGHTS_PRIV_BACKUP;
     593             :                 }
     594             : 
     595      105942 :                 if (security_token_has_privilege(token, SEC_PRIV_RESTORE)) {
     596       20876 :                         access_desired |= SEC_RIGHTS_PRIV_RESTORE;
     597             :                 }
     598             : 
     599      105942 :                 DEBUG(10,("se_file_access_check: MAX desired = 0x%x "
     600             :                         "mapped to 0x%x\n",
     601             :                         orig_access_desired,
     602             :                         access_desired));
     603             :         }
     604             : 
     605      105972 :         status = se_access_check_implicit_owner(sd,
     606             :                                                 token,
     607             :                                                 access_desired,
     608             :                                                 access_granted,
     609             :                                                 IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS);
     610             : 
     611      105972 :         if (!NT_STATUS_EQUAL(status, NT_STATUS_ACCESS_DENIED)) {
     612      103474 :                 return status;
     613             :         }
     614             : 
     615        2498 :         bits_remaining = *access_granted;
     616             : 
     617             :         /* Check if we should override with privileges. */
     618        4996 :         if ((bits_remaining & SEC_RIGHTS_PRIV_BACKUP) &&
     619        2498 :             security_token_has_privilege(token, SEC_PRIV_BACKUP)) {
     620        2498 :                 bits_remaining &= ~(SEC_RIGHTS_PRIV_BACKUP);
     621             :         }
     622        4996 :         if ((bits_remaining & SEC_RIGHTS_PRIV_RESTORE) &&
     623        2498 :             security_token_has_privilege(token, SEC_PRIV_RESTORE)) {
     624        2498 :                 bits_remaining &= ~(SEC_RIGHTS_PRIV_RESTORE);
     625             :         }
     626        2498 :         if (bits_remaining != 0) {
     627           0 :                 *access_granted = bits_remaining;
     628           0 :                 return NT_STATUS_ACCESS_DENIED;
     629             :         }
     630             : 
     631        2498 :         return NT_STATUS_OK;
     632             : }
     633             : 
     634     5673178 : static const struct GUID *get_ace_object_type(const struct security_ace *ace)
     635             : {
     636     5673178 :         if (ace->object.object.flags & SEC_ACE_OBJECT_TYPE_PRESENT) {
     637     5397972 :                 return &ace->object.object.type.type;
     638             :         }
     639             : 
     640      275206 :         return NULL;
     641             : }
     642             : 
     643             : /**
     644             :  * Evaluates access rights specified in a object-specific ACE for an AD object.
     645             :  * This logic corresponds to MS-ADTS 5.1.3.3.3 Checking Object-Specific Access.
     646             :  * @param[in] ace - the ACE being processed
     647             :  * @param[in/out] tree - remaining_access gets updated for the tree
     648             :  * @param[out] grant_access - set to true if the ACE grants sufficient access
     649             :  *                            rights to the object/attribute
     650             :  * @returns NT_STATUS_OK, unless access was denied
     651             :  */
     652     6594232 : static NTSTATUS check_object_specific_access(const struct security_ace *ace,
     653             :                                              struct object_tree *tree,
     654             :                                              bool *grant_access)
     655             : {
     656     6594232 :         struct object_tree *node = NULL;
     657     6594232 :         const struct GUID *type = NULL;
     658             : 
     659     6594232 :         *grant_access = false;
     660             : 
     661             :         /* if no tree was supplied, we can't do object-specific access checks */
     662     6594232 :         if (!tree) {
     663      921054 :                 return NT_STATUS_OK;
     664             :         }
     665             : 
     666             :         /* Get the ObjectType GUID this ACE applies to */
     667     5673178 :         type = get_ace_object_type(ace);
     668             : 
     669             :         /*
     670             :          * If the ACE doesn't have a type, then apply it to the whole tree, i.e.
     671             :          * treat 'OA' ACEs as 'A' and 'OD' as 'D'
     672             :          */
     673     5673178 :         if (!type) {
     674      275206 :                 node = tree;
     675             :         } else {
     676             : 
     677             :                 /* skip it if the ACE's ObjectType GUID is not in the tree */
     678     5397972 :                 node = get_object_tree_by_GUID(tree, type);
     679     5397972 :                 if (!node) {
     680     4721909 :                         return NT_STATUS_OK;
     681             :                 }
     682             :         }
     683             : 
     684      951269 :         if (ace->type == SEC_ACE_TYPE_ACCESS_ALLOWED_OBJECT ||
     685         590 :             ace->type == SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK_OBJECT) {
     686             :                 /* apply the access rights to this node, and any children */
     687      950679 :                 object_tree_modify_access(node, ace->access_mask);
     688             : 
     689             :                 /*
     690             :                  * Currently all nodes in the tree request the same access mask,
     691             :                  * so we can use any node to check if processing this ACE now
     692             :                  * means the requested access has been granted
     693             :                  */
     694      950679 :                 if (node->remaining_access == 0) {
     695      935873 :                         *grant_access = true;
     696      935873 :                         return NT_STATUS_OK;
     697             :                 }
     698             : 
     699             :                 /*
     700             :                  * As per 5.1.3.3.4 Checking Control Access Right-Based Access,
     701             :                  * if the CONTROL_ACCESS right is present, then we can grant
     702             :                  * access and stop any further access checks
     703             :                  */
     704       14806 :                 if (ace->access_mask & SEC_ADS_CONTROL_ACCESS) {
     705         894 :                         *grant_access = true;
     706         894 :                         return NT_STATUS_OK;
     707             :                 }
     708             :         } else {
     709             : 
     710             :                 /* this ACE denies access to the requested object/attribute */
     711         590 :                 if (node->remaining_access & ace->access_mask){
     712         554 :                         return NT_STATUS_ACCESS_DENIED;
     713             :                 }
     714             :         }
     715       13948 :         return NT_STATUS_OK;
     716             : }
     717             : 
     718             : 
     719     8669769 : NTSTATUS sec_access_check_ds_implicit_owner(const struct security_descriptor *sd,
     720             :                                             const struct security_token *token,
     721             :                                             uint32_t access_desired,
     722             :                                             uint32_t *access_granted,
     723             :                                             struct object_tree *tree,
     724             :                                             const struct dom_sid *replace_sid,
     725             :                                             enum implicit_owner_rights implicit_owner_rights)
     726             : {
     727       89110 :         uint32_t i;
     728       89110 :         uint32_t bits_remaining;
     729             : 
     730     8669769 :         *access_granted = access_desired;
     731     8669769 :         bits_remaining = access_desired;
     732             : 
     733             :         /* handle the maximum allowed flag */
     734     8669769 :         if (access_desired & SEC_FLAG_MAXIMUM_ALLOWED) {
     735           0 :                 access_desired |= access_check_max_allowed(sd, token, implicit_owner_rights);
     736           0 :                 access_desired &= ~SEC_FLAG_MAXIMUM_ALLOWED;
     737           0 :                 *access_granted = access_desired;
     738           0 :                 bits_remaining = access_desired;
     739             :         }
     740             : 
     741     8669769 :         if (access_desired & SEC_FLAG_SYSTEM_SECURITY) {
     742       35673 :                 if (security_token_has_privilege(token, SEC_PRIV_SECURITY)) {
     743       34729 :                         bits_remaining &= ~SEC_FLAG_SYSTEM_SECURITY;
     744             :                 } else {
     745         944 :                         return NT_STATUS_PRIVILEGE_NOT_HELD;
     746             :                 }
     747             :         }
     748             : 
     749             :         /* the owner always gets SEC_STD_WRITE_DAC and SEC_STD_READ_CONTROL */
     750     8720701 :         if ((bits_remaining & (SEC_STD_WRITE_DAC|SEC_STD_READ_CONTROL)) &&
     751       51876 :             security_token_has_sid(token, sd->owner_sid)) {
     752       49462 :                 switch (implicit_owner_rights) {
     753       27049 :                 case IMPLICIT_OWNER_READ_CONTROL_AND_WRITE_DAC_RIGHTS:
     754       27049 :                         bits_remaining &= ~SEC_STD_WRITE_DAC;
     755          88 :                         FALL_THROUGH;
     756       49462 :                 case IMPLICIT_OWNER_READ_CONTROL_RIGHTS:
     757       49462 :                         bits_remaining &= ~SEC_STD_READ_CONTROL;
     758       49462 :                         break;
     759             :                 }
     760             :         }
     761             : 
     762             :         /* SEC_PRIV_TAKE_OWNERSHIP grants SEC_STD_WRITE_OWNER */
     763     8682077 :         if ((bits_remaining & (SEC_STD_WRITE_OWNER)) &&
     764       13252 :             security_token_has_privilege(token, SEC_PRIV_TAKE_OWNERSHIP)) {
     765       12880 :                 bits_remaining &= ~(SEC_STD_WRITE_OWNER);
     766             :         }
     767             : 
     768             :         /* a NULL dacl allows access */
     769     8668825 :         if ((sd->type & SEC_DESC_DACL_PRESENT) && sd->dacl == NULL) {
     770           0 :                 *access_granted = access_desired;
     771           0 :                 return NT_STATUS_OK;
     772             :         }
     773             : 
     774     8668825 :         if (sd->dacl == NULL) {
     775           2 :                 goto done;
     776             :         }
     777             : 
     778             :         /* check each ace in turn. */
     779    47112812 :         for (i=0; bits_remaining && i < sd->dacl->num_aces; i++) {
     780      511408 :                 const struct dom_sid *trustee;
     781    39396949 :                 const struct security_ace *ace = &sd->dacl->aces[i];
     782      511408 :                 NTSTATUS status;
     783    39396949 :                 bool grant_access = false;
     784             : 
     785    39396949 :                 if (ace->flags & SEC_ACE_FLAG_INHERIT_ONLY) {
     786    23939433 :                         continue;
     787             :                 }
     788             : 
     789    33465890 :                 if (dom_sid_equal(&ace->trustee, &global_sid_Self) && replace_sid) {
     790     6508931 :                         trustee = replace_sid;
     791             :                 } else {
     792    26955468 :                         trustee = &ace->trustee;
     793             :                 }
     794             : 
     795    33465890 :                 if (!security_token_has_sid(token, trustee)) {
     796    18008374 :                         continue;
     797             :                 }
     798             : 
     799    15457516 :                 switch (ace->type) {
     800     8827763 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED:
     801     8827763 :                         if (tree) {
     802     7906565 :                                 object_tree_modify_access(tree, ace->access_mask);
     803             :                         }
     804             : 
     805     8827763 :                         bits_remaining &= ~ace->access_mask;
     806     8827763 :                         break;
     807       34989 :                 case SEC_ACE_TYPE_ACCESS_DENIED:
     808       34989 :                         if (bits_remaining & ace->access_mask) {
     809       15523 :                                 return NT_STATUS_ACCESS_DENIED;
     810             :                         }
     811       19466 :                         break;
     812         394 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK:
     813             :                 {
     814           0 :                         enum ace_callback_result allow =
     815         394 :                                 check_callback_ace_allow(ace, token, sd);
     816         394 :                         if (allow == ACE_CALLBACK_INVALID) {
     817           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     818             :                         }
     819         394 :                         if (allow == ACE_CALLBACK_ALLOW) {
     820         198 :                                 bits_remaining &= ~ace->access_mask;
     821             :                         }
     822         394 :                         break;
     823             :                 }
     824             : 
     825         138 :                 case SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK:
     826             :                 {
     827           0 :                         enum ace_callback_result deny =
     828         138 :                                 check_callback_ace_deny(ace, token, sd);
     829         138 :                         if (deny == ACE_CALLBACK_INVALID) {
     830           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     831             :                         }
     832         138 :                         if (deny == ACE_CALLBACK_DENY) {
     833         116 :                                 if (bits_remaining & ace->access_mask) {
     834         116 :                                         return NT_STATUS_ACCESS_DENIED;
     835             :                                 }
     836             :                         }
     837          22 :                         break;
     838             :                 }
     839             : 
     840     6594232 :                 case SEC_ACE_TYPE_ACCESS_DENIED_OBJECT:
     841             :                 case SEC_ACE_TYPE_ACCESS_ALLOWED_OBJECT:
     842     6594232 :                         status = check_object_specific_access(ace, tree,
     843             :                                                               &grant_access);
     844             : 
     845     6594232 :                         if (!NT_STATUS_IS_OK(status)) {
     846         554 :                                 return status;
     847             :                         }
     848             : 
     849     6593678 :                         if (grant_access) {
     850      936767 :                                 return NT_STATUS_OK;
     851             :                         }
     852     5480037 :                         break;
     853           0 :                 case SEC_ACE_TYPE_ACCESS_ALLOWED_CALLBACK_OBJECT:
     854             :                 {
     855             :                         /*
     856             :                          * if the callback says ALLOW, we treat this as a
     857             :                          * SEC_ACE_TYPE_ACCESS_ALLOWED_OBJECT.
     858             :                          *
     859             :                          * Otherwise we act as if this ACE does not exist.
     860             :                          */
     861           0 :                         enum ace_callback_result allow =
     862           0 :                                 check_callback_ace_allow(ace, token, sd);
     863           0 :                         if (allow == ACE_CALLBACK_INVALID) {
     864           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     865             :                         }
     866           0 :                         if (allow != ACE_CALLBACK_ALLOW) {
     867           0 :                                 break;
     868             :                         }
     869             : 
     870           0 :                         status = check_object_specific_access(ace, tree,
     871             :                                                               &grant_access);
     872             : 
     873           0 :                         if (!NT_STATUS_IS_OK(status)) {
     874           0 :                                 return status;
     875             :                         }
     876             : 
     877           0 :                         if (grant_access) {
     878           0 :                                 return NT_STATUS_OK;
     879             :                         }
     880           0 :                         break;
     881             :                 }
     882           0 :                 case SEC_ACE_TYPE_ACCESS_DENIED_CALLBACK_OBJECT:
     883             :                 {
     884             :                         /*
     885             :                          * ACCESS_DENIED_OBJECT ACEs can't grant access --
     886             :                          * they either don't match the object and slide
     887             :                          * harmlessly past or they return
     888             :                          * NT_STATUS_ACCESS_DENIED.
     889             :                          *
     890             :                          * ACCESS_DENIED_CALLBACK_OBJECT ACEs add another way
     891             :                          * of not applying, and another way of failing.
     892             :                          */
     893           0 :                         enum ace_callback_result deny =
     894           0 :                                 check_callback_ace_deny(ace, token, sd);
     895           0 :                         if (deny == ACE_CALLBACK_INVALID) {
     896           0 :                                 return NT_STATUS_INVALID_ACE_CONDITION;
     897             :                         }
     898           0 :                         if (deny != ACE_CALLBACK_DENY) {
     899           0 :                                 break;
     900             :                         }
     901           0 :                         status = check_object_specific_access(ace, tree,
     902             :                                                               &grant_access);
     903             : 
     904           0 :                         if (!NT_STATUS_IS_OK(status)) {
     905           0 :                                 return status;
     906             :                         }
     907           0 :                         break;
     908             :                 }
     909           0 :                 default:        /* Other ACE types not handled/supported */
     910           0 :                         break;
     911             :                 }
     912             :         }
     913             : 
     914     7715863 : done:
     915     7715865 :         if (bits_remaining != 0) {
     916       65574 :                 return NT_STATUS_ACCESS_DENIED;
     917             :         }
     918             : 
     919     7650291 :         return NT_STATUS_OK;
     920             : }
     921             : 
     922             : /**
     923             :  * @brief Perform directoryservice (DS) related access checks for a given user
     924             :  *
     925             :  * Perform DS access checks for the user represented by its security_token, on
     926             :  * the provided security descriptor. If an tree associating GUID and access
     927             :  * required is provided then object access (OA) are checked as well. *
     928             :  * @param[in]   sd             The security descriptor against which the required
     929             :  *                             access are requested
     930             :  *
     931             :  * @param[in]   token          The security_token associated with the user to
     932             :  *                             test
     933             :  *
     934             :  * @param[in]   access_desired A bitfield of rights that must be granted for the
     935             :  *                             given user in the specified SD.
     936             :  *
     937             :  * If one
     938             :  * of the entry in the tree grants all the requested rights for the given GUID
     939             :  * FIXME
     940             :  * tree can be null if not null it's the
     941             :  * Lots of code duplication, it will be united in just one
     942             :  * function eventually */
     943             : 
     944     1566291 : NTSTATUS sec_access_check_ds(const struct security_descriptor *sd,
     945             :                              const struct security_token *token,
     946             :                              uint32_t access_desired,
     947             :                              uint32_t *access_granted,
     948             :                              struct object_tree *tree,
     949             :                              const struct dom_sid *replace_sid)
     950             : {
     951     1566291 :         return sec_access_check_ds_implicit_owner(sd,
     952             :                                                   token,
     953             :                                                   access_desired,
     954             :                                                   access_granted,
     955             :                                                   tree,
     956             :                                                   replace_sid,
     957             :                                                   IMPLICIT_OWNER_READ_CONTROL_RIGHTS);
     958             : }

Generated by: LCOV version 1.14