Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp811317imm; Mon, 21 May 2018 14:58:03 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo1PvNVxBoRLRUMtmJAdNjhASRemE+bQFcxi5JoB7v/2QYiqzMan5ZTOHPRL8paAkETPeXE X-Received: by 2002:a17:902:8d8e:: with SMTP id v14-v6mr22266335plo.387.1526939883708; Mon, 21 May 2018 14:58:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526939883; cv=none; d=google.com; s=arc-20160816; b=BHOy2akt5lrwwDC2w8rAsYIKQu1B1JTJhyZbkc8oBT9A8s8uWQu6rIlR8lIEING9Ee DNtgyNEDaYqKep2hORmcBsw+z1/Elrl/PKmjU+6Et2Td3qMyNokEgY5ZlfLkWLkEI5sR rpFO7mjuZ/eBvsHzQnx6RkG1lxAwuNPlPer4J6aO5VQee1+o8xxMlkg3NF/PCPSVfnsI MRBnKhIH7uPpJYb+GB7EvlcGcFRyqKyAwx4/d/VeULbSC1fBJast6yDvcvo59Tez6zt0 PjNe/7RvWOUc/1BXGRC9uIGczfPz+lVSCBoir9dUhMlbVUbRNBsbK+6L/GlR+4Mdp3IA 0XWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :from:references:cc:to:subject:arc-authentication-results; bh=VvONohhg6x2io24VYohY/Tj4eaEAP/ukDvtJJc0V0Y0=; b=kE5V687ymrHFwpXFTDIoRNwLV80tc6++cjif+dsB0qXk3fBUHCsnF5kBgol4h4rYTL 1RfzQJum6e35Mj99SJwzhrqlHeduU4C+lWiHAmmJ5V1TRhnojjeYmQeXYmHfCm6XrO1y Z4L/5W59jkhUrXSBACSjIA8C29in0fx+MW22LZWdzQ/C9x4HWKPTmrXOCbbSYk4LBxiG VwAgZ0uWxAEl4tfgWJ17WrETeFclBW3SdVAmgu1I3eul0IanXF+9Ke23XsdNtWPWXlOx hR9we7lyeP61+pk/q1bfwIX6yknsUBomArqlwDRNL6CtEiouz7ZGIrt67is/Te34zxS+ nbgg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g11-v6si264492pgf.297.2018.05.21.14.57.49; Mon, 21 May 2018 14:58:03 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754626AbeEUV5m (ORCPT + 99 others); Mon, 21 May 2018 17:57:42 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:43948 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1754104AbeEUV5h (ORCPT ); Mon, 21 May 2018 17:57:37 -0400 Received: from pps.filterd (m0098419.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w4LLmsdw083988 for ; Mon, 21 May 2018 17:57:36 -0400 Received: from e31.co.us.ibm.com (e31.co.us.ibm.com [32.97.110.149]) by mx0b-001b2d01.pphosted.com with ESMTP id 2j45kk1sj9-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Mon, 21 May 2018 17:57:36 -0400 Received: from localhost by e31.co.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 21 May 2018 15:57:35 -0600 Received: from b03cxnp08028.gho.boulder.ibm.com (9.17.130.20) by e31.co.us.ibm.com (192.168.1.131) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; (version=TLSv1/SSLv3 cipher=AES256-GCM-SHA384 bits=256/256) Mon, 21 May 2018 15:57:31 -0600 Received: from b03ledav001.gho.boulder.ibm.com (b03ledav001.gho.boulder.ibm.com [9.17.130.232]) by b03cxnp08028.gho.boulder.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w4LLvURJ11796986 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Mon, 21 May 2018 14:57:30 -0700 Received: from b03ledav001.gho.boulder.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 4404F6E035; Mon, 21 May 2018 15:57:30 -0600 (MDT) Received: from sbct-3.pok.ibm.com (unknown [9.47.158.153]) by b03ledav001.gho.boulder.ibm.com (Postfix) with ESMTP id 93D6D6E03A; Mon, 21 May 2018 15:57:29 -0600 (MDT) Subject: Re: [PATCH] audit: add containerid support for IMA-audit To: Steve Grubb Cc: Richard Guy Briggs , Mimi Zohar , containers@lists.linux-foundation.org, Linux-Audit Mailing List , linux-integrity , LKML , paul@paul-moore.com References: <1520257393.10396.291.camel@linux.vnet.ibm.com> <2397631.78oLu0QVqb@x2> <21646a72-e782-e33a-9e75-5cc98b241f36@linux.vnet.ibm.com> <4015765.rtofcNpGHU@x2> From: Stefan Berger Date: Mon, 21 May 2018 17:57:29 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <4015765.rtofcNpGHU@x2> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-MW X-TM-AS-GCONF: 00 x-cbid: 18052121-8235-0000-0000-00000D8AC16A X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00009062; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000261; SDB=6.01035711; UDB=6.00529775; IPR=6.00814840; MB=3.00021229; MTD=3.00000008; XFM=3.00000015; UTC=2018-05-21 21:57:33 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18052121-8236-0000-0000-00004111C787 Message-Id: X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-05-21_09:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1805210255 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/21/2018 02:30 PM, Steve Grubb wrote: > Hello Stefan, > > On Monday, May 21, 2018 1:53:04 PM EDT Stefan Berger wrote: >> On 05/21/2018 12:58 PM, Steve Grubb wrote: >>> On Thursday, May 17, 2018 10:18:13 AM EDT Stefan Berger wrote: >>>>> audit_log_container_info() then releasing the local context. This >>>>> version of the record has additional concerns covered here: >>>>> https://github.com/linux-audit/audit-kernel/issues/52 >>>> Following the discussion there and the concern with breaking user space, >>>> how can we split up the AUDIT_INTEGRITY_RULE that is used in >>>> ima_audit_measurement() and ima_parse_rule(), without 'breaking user >>>> space'? >>>> >>>> A message produced by ima_parse_rule() looks like this here: >>>> >>>> type=INTEGRITY_RULE msg=audit(1526566213.870:305): action="dont_measure" >>>> fsmagic="0x9fa0" res=1 >>> Why is action and fsmagic being logged as untrusted strings? Untrusted >>> strings are used when an unprivileged user can affect the contents of the >>> field such as creating a file with space or special characters in the >>> name. >>> >>> Also, subject and object information is missing. Who loaded this rule? >>> >>>> in contrast to that an INTEGRITY_PCR record type: >>>> >>>> type=INTEGRITY_PCR msg=audit(1526566235.193:334): pid=1615 uid=0 auid=0 >>>> ses=2 subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 >>>> op="invalid_pcr" cause="open_writers" comm="scp" >>>> name="/var/log/audit/audit.log" dev="dm-0" ino=1962625 res=1 >>> Why is op & cause being logged as an untrusted string? This also has >>> incomplete subject information. >> It's calling audit_log_string() in both cases: >> >> https://elixir.bootlin.com/linux/latest/source/security/integrity/integrity >> _audit.c#L48 > I see. Looking things over, I see that it seems like it should do the right > thing. But the original purpose for this function is here: > > https://elixir.bootlin.com/linux/latest/source/kernel/audit.c#L1944 > > This is where it is logging an untrusted string and has to decide to encode > it or just place it in quotes. If it has quotes, that means it's an untrusted > string but has no control characters in it. I think you want to use > audit_log_format() for any string that is trustworthy. Replacing all occurrences (in IMA) of audit_log_string() with audit_log_format(). > > > As an aside, I wonder why audit_log_string() is in the API when it is a > helper to audit_log_untrustedstring() ? Without understanding the rules of > untrusted strings, it can't be used correctly without re-inventing > audit_log_untrustedstring() by hand. > > >>>> Should some of the fields from INTEGRITY_PCR also appear in >>>> INTEGRITY_RULE? If so, which ones? >>> pid, uid, auid, tty, session, subj, comm, exe, res. <- these are >>> required to be searchable >>> >>>> We could probably refactor the current integrity_audit_message() and >>>> have ima_parse_rule() call into it to get those fields as well. I >>>> suppose adding new fields to it wouldn't be considered breaking user >>>> space? >>> The audit user space utilities pretty much expects those fields in that >>> order for any IMA originating events. You can add things like op or >>> cause before >> We will call into audit_log_task, which will put the parameters into >> correct order: >> >> auid uid gid ses subj pid comm exe > I'm telling you what the correct order is. :-) A long time ago, the IMA :-) Thanks. Was getting confused. > system had audit events with the order I'm mentioning. For example, here's > one from a log I collected back in 2013: > > type=INTEGRITY_PCR msg=audit(1327409021.813:21): pid=1 uid=0 auid=4294967295 > ses=4294967295 subj=kernel op="add_template_measure" cause="hash_added" > comm="init" name="01parse-kernel.sh" dev=rootfs ino=5413 res=0 > > it was missing "tty" and "exe", but the order is as I mentioned. The > expectation is that INTEGRITY events maintain this established order across > all events. I am *appending* exe= and tty= now: type=INTEGRITY_PCR msg=audit(1526939047.809:305): pid=1609 uid=0 auid=0 ses=2 subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 op="invalid_pcr" cause="open_writers" comm="ssh" name="/var/lib/sss/mc/passwd" dev="dm-0" ino=1962679 res=1 exe="/usr/bin/ssh" tty=tty2    Stefan > > Thanks, > -Steve > > >> https://elixir.bootlin.com/linux/latest/source/kernel/auditsc.c#L2433 >> >>> that. The reason why you can do that is those additional fields are not >>> required to be searchable by common criteria. >>> >>> -Steve > > >