Re: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL

Russ Housley <housley@vigilsec.com> Wed, 13 October 2021 16:08 UTC

Return-Path: <housley@vigilsec.com>
X-Original-To: spasm@ietfa.amsl.com
Delivered-To: spasm@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 996263A0BD5 for <spasm@ietfa.amsl.com>; Wed, 13 Oct 2021 09:08:33 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.796
X-Spam-Level:
X-Spam-Status: No, score=-1.796 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, HTML_MESSAGE=0.001, HTTPS_HTTP_MISMATCH=0.1, SPF_HELO_NONE=0.001, SPF_NONE=0.001, URIBL_BLOCKED=0.001] autolearn=no autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id jCGnsr61jhk1 for <spasm@ietfa.amsl.com>; Wed, 13 Oct 2021 09:08:28 -0700 (PDT)
Received: from mail.smeinc.net (mail.smeinc.net [209.135.209.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 73D153A0BD6 for <spasm@ietf.org>; Wed, 13 Oct 2021 09:08:28 -0700 (PDT)
Received: from localhost (localhost [127.0.0.1]) by mail.smeinc.net (Postfix) with ESMTP id 372AA300BCA for <spasm@ietf.org>; Wed, 13 Oct 2021 12:08:29 -0400 (EDT)
X-Virus-Scanned: amavisd-new at mail.smeinc.net
Received: from mail.smeinc.net ([127.0.0.1]) by localhost (mail.smeinc.net [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id 8tNbBnX57TIz for <spasm@ietf.org>; Wed, 13 Oct 2021 12:08:20 -0400 (EDT)
Received: from a860b60074bd.fios-router.home (pool-141-156-161-153.washdc.fios.verizon.net [141.156.161.153]) by mail.smeinc.net (Postfix) with ESMTPSA id DD1DE3001A8; Wed, 13 Oct 2021 12:08:19 -0400 (EDT)
From: Russ Housley <housley@vigilsec.com>
Message-Id: <4221E1CA-7345-4DA2-BBA9-3B52C1102690@vigilsec.com>
Content-Type: multipart/alternative; boundary="Apple-Mail=_F27C377F-60EB-4DCA-9D65-854AE5A2E469"
Mime-Version: 1.0 (Mac OS X Mail 12.4 \(3445.104.21\))
Date: Wed, 13 Oct 2021 12:08:17 -0400
In-Reply-To: <VI1PR10MB2429045512EF000D0ADA8B64FEB79@VI1PR10MB2429.EURPRD10.PROD.OUTLOOK.COM>
Cc: Lijun Liao <lijun.liao@gmail.com>, John Gray <John.Gray@entrust.com>, LAMPS WG <spasm@ietf.org>, David von Oheimb <david.von.oheimb@siemens.com>
To: "Brockhaus, Hendrik" <hendrik.brockhaus@siemens.com>
References: <AM0PR10MB24181E0CB7F13C5969337F56FEB09@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <EDA2ACBF-E745-430A-A13F-A144B08125AC@vigilsec.com> <AM0PR10MB241887D39072B393C56FB28AFEB29@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <8D6D333A-14A3-4487-967F-CFCAC22D856C@vigilsec.com> <AM0PR10MB241865E9784CC03F81AA9D39FEB29@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <B92F36D2-605F-4E60-A654-AA0F89E310CA@vigilsec.com> <CANNx7D8AaT3+7Ah7tZHXUYRkcgx7CW_ExgciJ4nB90WAuP6tzw@mail.gmail.com> <E5F845E3-4281-4409-9085-28CC68751DB3@vigilsec.com> <AM0PR10MB241822FCF1E83E6444FDFAE5FEB59@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <0b24c287-a6ac-593e-e0e4-3fd0b9373208@von-Oheimb.de> <B48AB092-BE17-42AE-BBA8-7ACDBDBF75D7@vigilsec.com> <AM0PR10MB2418B4A2D6498C6E4A7CC6D9FEB59@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <C5546F9B-8AF0-48FA-9B9E-FE10C9B700F9@vigilsec.com> <CANNx7D-y4Sju8DN8=AmOQnq+GhrPAbmgZnhwYoDoSy_iB6gfpQ@mail.gmail.com> <29024D4D-A638-44AA-855A-6081F66D4A24@vigilsec.com> <93dd2d1d-3e82-36de-280a-365d3b1c388c@von-Oheimb.de> <AM0PR10MB2418F810110FDE2E11BCF8BBFEB69@AM0PR10MB2418.EURPRD10.PROD.OUTLOOK.COM> <DM6PR11MB2585CC2BC632716E78587668EAB69@DM6PR11MB2585.namprd11.prod.outlook.com> <4B13DEB3-A384-4559-8AF2-4ECCDDC4ED7F@vigilsec.com> <VI1PR10MB2429045512EF000D0ADA8B64FEB79@VI1PR10MB2429.EURPRD10.PROD.OUTLOOK.COM>
X-Mailer: Apple Mail (2.3445.104.21)
Archived-At: <https://mailarchive.ietf.org/arch/msg/spasm/sVPHet8WnCn2kSQCY_xQaTP33v0>
Subject: Re: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL
X-BeenThere: spasm@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "This is a venue for discussion of doing Some Pkix And SMime \(spasm\) work." <spasm.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/spasm>, <mailto:spasm-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/spasm/>
List-Post: <mailto:spasm@ietf.org>
List-Help: <mailto:spasm-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/spasm>, <mailto:spasm-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 13 Oct 2021 16:08:34 -0000

This is a nit, but I think it is more readable ...

CRLSource ::= CHOICE {
   dpn          [0] DistributionPointName,
   issuer      [1] GeneralNames }

CRLStatus ::= SEQUENCE {
   source    CRLSource,
   thisUpdate    Time }

Russ

> On Oct 13, 2021, at 12:02 PM, Brockhaus, Hendrik <hendrik.brockhaus@siemens.com> wrote:
> 
> Russ
>  
> Thank you for this suggestion. I like it.
>  
> While you were sending that email John, David and I were having a meeting discussing the different scenarios we would like to cover.
>  
> We see theses two situations:
> The client knows a crldpn from its configuration or from a certificates CRLDistributionPoints field. It can use this for all the special cases like Delta CRLs, Indirect CRLs, etc.
> If no crldpn is available, the client will know the CA that issues the CRL and would like to get a full CRL covering all certificates issued by this CA.
>  
> There are also two additional situations:
> The client already has a CRL and knows its thisUpdate time.
> The client does not so fare has any CRL from a specific crldpn or CA and therefore does not know any thisUpdate Time.
>  
> To be able to also address these situations we suggest his syntax:
>  
> CRLStatus ::= SEQUENCE {
>    crlSource     CHOICE {
>       crldpn          [0] DistributionPointName,
>       crlIssuer      [1] GeneralNames
>    },
>    thisUpdate    Time  OPTIONAL
> }
>  
> id-it-crlStatusList  OBJECT IDENTIFIER ::= {id-it TBD1}
> CRLStatusList ::= SEQUENCE SIZE (1..MAX) OF CRLStatus
>  
> id-it-crls  OBJECT IDENTIFIER ::= {id-it TBD2}
> CRLs ::= SEQUENCE OF CertificateList
>  
>    GenMsg:    {id-it TBD1}, CRLStatusList
>    GenRep:    {id-it TBD2}, CRLs  |  < absent >
>  
> We also discussed if CRLNumber, but we did not find a case where thisUpdate and a reference to a concrete CRL source is not precise enough.
>  
> Hendrik
>  
> Von: Russ Housley <housley@vigilsec.com <mailto:housley@vigilsec.com>> 
> Gesendet: Mittwoch, 13. Oktober 2021 16:52
> 
>  
> RFC 5280 defines CRLNumber, and it does not allow negative INTEGER values.
>  
> So, I suggest:
>  
> CRLStatusList ::= SEQUENCE OF CRLStatus
>  
> CRLStatus ::= SEQUENCE {
>    crldpn    DistributionPointName,
>    crlnum    CRLNumber,
>    thisUpdate    Time }
>  
> CRLs ::= SEQUENCE OF CertificateList
>  
>    GenMsg:    {id-it TBD}, CRLStatusList
>    GenRep:    {id-it TBD}, CRLs  |  < absent >
>  
> Russ
> 
> 
> On Oct 12, 2021, at 2:06 PM, John Gray <John.Gray=40entrust.com@dmarc.ietf.org <mailto:John.Gray=40entrust.com@dmarc.ietf.org>> wrote:
>  
> I think we should only need the DistributionPointName, as we need a way to give the CA the information it needs to be able to lookup the CRL from its internal list of issued CRL’s.   I hope this should be enough information for a CA to distinguish which CRL is being requested.  Is this an assumption we should be able to make (that a CA would easily be able to determine a CRL by its DistributionPointName)?
>  
>    IssuingDistributionPoint ::= SEQUENCE {
>         distributionPoint          [0] DistributionPointName OPTIONAL,
>         onlyContainsUserCerts      [1] BOOLEAN DEFAULT FALSE,
>         onlyContainsCACerts        [2] BOOLEAN DEFAULT FALSE,
>         onlySomeReasons            [3] ReasonFlags OPTIONAL,
>         indirectCRL                [4] BOOLEAN DEFAULT FALSE,
>         onlyContainsAttributeCerts [5] BOOLEAN DEFAULT FALSE }
>  
>  
> DistributionPointName ::= CHOICE {
>         fullName                [0]     GeneralNames,
>         nameRelativeToCRLIssuer [1]     RelativeDistinguishedName }
>  
>  
> So is this good enough?
>  
> CRLStatus ::= SEQUENCE {
>    crldpn    DistributionPointName,
>    cRLNumber  INTEGER,
>    thisUpdate    Time }
>  
>  
> In David’s (2):
> CRLStatus ::= SEQUENCE {
>    issuer            Name,
>    cRLNumber  INTEGER,
>    scope             IssuingDistributionPoint OPTIONAL }
>  
> Isn’t the Issuer name redundant because we would be making the request to a specific CA (our CMP server), so that should not be needed as we are making a request to the issuer (or an RA acting on behalf of the issuer).   ThisUpdate is needed to indicate to the server to only send a CRL that is newer than the given thisUpdate time (otherwise send nothing).  This should gains the network efficiency we are looking to achieve.  The CRL number is to request specific CRL numbers when all other information is identical.  
>  
> I like Russ’s proposal of supporting multiple CRL’s in a CRLStatusList as well (at the expense of a little more complexity).   Supporting CRLStatusList makes it more flexible in case there is a need to request multiple at once.  So I am fine with that flexibility.
>  
> CRLStatusList ::= SEQUENCE OF CRLStatus
>   
> CRLs ::= SEQUENCE OF CertificateList
>    
>    GenMsg:    {id-it TBD}, CRLStatusList
>    GenRep:    {id-it TBD}, CRLs  |  < absent >
>  
>  
> Cheers,
>  
> John Gray
>   
>  
> From: Brockhaus, Hendrik <hendrik.brockhaus@siemens.com <mailto:hendrik.brockhaus@siemens.com>> 
> Sent: Tuesday, October 12, 2021 9:35 AM
> To: David von Oheimb <nl0@von-Oheimb.de <mailto:nl0@von-Oheimb.de>>; Russ Housley <housley@vigilsec.com <mailto:housley@vigilsec.com>>; Lijun Liao <lijun.liao@gmail.com <mailto:lijun.liao@gmail.com>>
> Cc: LAMPS WG <spasm@ietf.org <mailto:spasm@ietf.org>>; John Gray <John.Gray@entrust.com <mailto:John.Gray@entrust.com>>
> Subject: AW: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL
>  
> Do we really need the whole IssuingDistributionPoint, or is the DistributionPointName sufficient?
>  
> Hendrik
>  
> Von: Spasm <spasm-bounces@ietf.org <mailto:spasm-bounces@ietf.org>> Im Auftrag von David von Oheimb
> Gesendet: Dienstag, 12. Oktober 2021 10:12
> An: Russ Housley <housley@vigilsec.com <mailto:housley@vigilsec.com>>; Lijun Liao <lijun.liao@gmail.com <mailto:lijun.liao@gmail.com>>
> Cc: LAMPS WG <spasm@ietf.org <mailto:spasm@ietf.org>>; Brockhaus, Hendrik (T RDA CST SEA-DE) <hendrik.brockhaus@siemens.com <mailto:hendrik.brockhaus@siemens.com>>; John Gray <John.Gray@entrust.com <mailto:John.Gray@entrust.com>>
> Betreff: Re: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL
>  
> Thanks for the clarifications.
> So how about adapting the CRLStatus part of Russ' below proposal from
> CRLStatus ::= SEQUENCE {
>    crldpn    DistributionPointName,
>    thisUpdate    Time }
> 
> to (1):
> CRLStatus ::= SEQUENCE {
>    scope             IssuingDistributionPoint OPTIONAL,
>    thisUpdate    Time }
> or to (2):
> CRLStatus ::= SEQUENCE {
>    issuer            Name,
>    cRLNumber  INTEGER,
>    scope             IssuingDistributionPoint OPTIONAL }
> ?
> In this way the full scope information can be given if needed, while
> for the typical (simple) cases, it should be sufficient to give either the thisUpdate value or the CRL issuer and number.
>  
>     David
>  
> On 11.10.21 23:42, David von Oheimb wrote:
> So in the end the whole IssuingDistributionPoint
> structure determines the scope.
>  
>   David
>  
> On 11.10.21 21:45, Russ Housley wrote:
> Lijun: 
>  
> Yes, I agree.  That us the reason for crldpn in the syntax that I suggested.
>  
> Russ
>  
> 
> On Oct 11, 2021, at 3:26 PM, Lijun Liao <lijun.liao@gmail.com <mailto:lijun.liao@gmail.com>> wrote:
>  
> The URL specified in the extension CRL DP, should be able to identify the scope.
>  
>  
> Russ Housley <housley@vigilsec.com <mailto:housley@vigilsec.com>> schrieb am Mo., 11. Okt. 2021, 20:11:
> Hendrik: 
>  
> As the introduction to Section 5 od RFC 5280 says, the scope can be based on "arbitrary local information".  Consider the example that I gave in my earlier response, where a CA uses multiple CRL distribution points.  One distribution point could be associated with NIST employees located in Boulder and a separate distribution point could be for NIST employees in Gaithersburg.  There are certainly other ways to do this, including indirect CRLs, but this is one straightforward approach. 
>  
> Russ 
>  
> 
> On Oct 11, 2021, at 12:20 PM, Brockhaus, Hendrik <hendrik.brockhaus@siemens.com <mailto:hendrik.brockhaus@siemens.com>> wrote:
>  
> Russ
>  
> The introduction to Section 5 gives some examples on different scopes.
> I du understand how to express theses scopes by using the flags David mentioned.
> "all certificates issued by CA X"
> "all CA certificates issued by CA X"
> "all certificates issued by CA X that have been revoked for reasons of key compromise and CA compromise",
>  
> But I have issues to understand how "all certificates issued to the NIST employees located in Boulder" would be expressed.
> Can you give an example?
>  
> Hendrik
>  
> Von: Russ Housley <housley@vigilsec.com <mailto:housley@vigilsec.com>> 
> Gesendet: Montag, 11. Oktober 2021 17:26
> An: David von Oheimb <nl0@von-Oheimb.de <mailto:nl0@von-Oheimb.de>>
> Cc: Lijun Liao <lijun.liao@gmail.com <mailto:lijun.liao@gmail.com>>; spasm@ietf.org <mailto:spasm@ietf.org>; Brockhaus, Hendrik (T RDA CST SEA-DE) <hendrik.brockhaus@siemens.com <mailto:hendrik.brockhaus@siemens.com>>; John Gray <John.Gray@entrust.com <mailto:John.Gray@entrust.com>>
> Betreff: Re: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL
>  
> David:
>  
> These flags are clearly part of the scope.  The use of CRL distribution points in certificates can be used to divide the population of certificates across many different CRLs.
>  
> Russ
>  
> 
> On Oct 11, 2021, at 11:16 AM, David von Oheimb <nl0@von-Oheimb.de <mailto:nl0@von-Oheimb.de>> wrote:
>  
> Interesting discussion!
> It looks to me that the currently open issue boils down to uniquely identifying the (latest) CRL information currently known to the client.
> Even when scoped, indirect, and delta CRLs need to be taken into account, 
> according to https://datatracker.ietf.org/doc/html/rfc5280#section-5.2.3 <https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Furldefense.com%2Fv3%2F__https%3A%2Feur01.safelinks.protection.outlook.com%2F%3Furl%3Dhttps*3A*2F*2Fdatatracker.ietf.org*2Fdoc*2Fhtml*2Frfc5280*23section-5.2.3%26data%3D04*7C01*7Chendrik.brockhaus*40siemens.com*7C4ad01b5d9113414a477f08d98d580223*7C38ae3bcd95794fd4addab42e1495d55a*7C1*7C0*7C637696232756680209*7CUnknown*7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0*3D*7C3000%26sdata%3DKqGxNtGOOfOJukKWAIWwBhiljMUJMIwKvLEd9zzefcA*3D%26reserved%3D0__%3BJSUlJSUlJSUlJSUlJSUlJSUlJSU!!FJ-Y8qCqXTj2!I9hCPwvpYvYsKczRCM_y70-117Xe4Yvw5aB2pzCAZ768NKnbCwz8aaL09vCbUq19%24&data=04%7C01%7Chendrik.brockhaus%40siemens.com%7Cd0bd97b437a54f3fbfc208d98e590086%7C38ae3bcd95794fd4addab42e1495d55a%7C1%7C0%7C637697336668427835%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=sfMsp2j3U%2BX%2FUOGWCPSNQswKBgOI7jriqbM19%2FPUmXI%3D&reserved=0>
> apparently the following data should be sufficient for unique identification: 
>     CRL issuer, scope, and CRL Number,
> or am I missing something?
> And how is the scope defined/encoded?
> I'm having a hard time getting this nailed down from RFC 5280 and other sources, 
> but according to https://datatracker.ietf.org/doc/html/rfc5280#section-5.2.5
>  <https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Furldefense.com%2Fv3%2F__https%3A%2Feur01.safelinks.protection.outlook.com%2F%3Furl%3Dhttps*3A*2F*2Fdatatracker.ietf.org*2Fdoc*2Fhtml*2Frfc5280*23section-5.2.5%26data%3D04*7C01*7Chendrik.brockhaus*40siemens.com*7C4ad01b5d9113414a477f08d98d580223*7C38ae3bcd95794fd4addab42e1495d55a*7C1*7C0*7C637696232756690198*7CUnknown*7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0*3D*7C3000%26sdata%3DXi1FhU*2BLZ45xBsdwSQPlUPvwF3zIrv0*2F*2FMHy4nr7sm0*3D%26reserved%3D0__%3BJSUlJSUlJSUlJSUlJSUlJSUlJSUlJSU!!FJ-Y8qCqXTj2!I9hCPwvpYvYsKczRCM_y70-117Xe4Yvw5aB2pzCAZ768NKnbCwz8aaL09sF5N2-s%24&data=04%7C01%7Chendrik.brockhaus%40siemens.com%7Cd0bd97b437a54f3fbfc208d98e590086%7C38ae3bcd95794fd4addab42e1495d55a%7C1%7C0%7C637697336668437830%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=mOb2M5dUfnSAM1%2BXCqhNdx%2Fzeg3NVIRQpnmKMqQUCNw%3D&reserved=0>it looks like the scope is the combination of the following fields:
>         onlyContainsUserCerts      [1] BOOLEAN DEFAULT FALSE,
>         onlyContainsCACerts        [2] BOOLEAN DEFAULT FALSE,
>         onlySomeReasons            [3] ReasonFlags OPTIONAL,
>         indirectCRL                [4] BOOLEAN DEFAULT FALSE,
>         onlyContainsAttributeCerts [5] BOOLEAN DEFAULT FALSE }
> right?
>     David
>  
> On 11.10.21 08:28, Brockhaus, Hendrik wrote:
> Russ
>  
> Thank you for this proposal. It looks straight forward.
> I will need to dig a little deeper into the partitioning of CRLs and check the requirements of our use case for CRL retrieval via CMP to better understand the complexity needed.
>  
> Hendrik
>  
> Von: Russ Housley <housley@vigilsec.com> <mailto:housley@vigilsec.com> 
> Gesendet: Samstag, 9. Oktober 2021 21:07
> An: Lijun Liao <lijun.liao@gmail.com> <mailto:lijun.liao@gmail.com>
> Cc: Brockhaus, Hendrik (T RDA CST SEA-DE) <hendrik.brockhaus@siemens.com> <mailto:hendrik.brockhaus@siemens.com>; spasm@ietf.org <mailto:spasm@ietf.org>; von Oheimb, David (T RDA CST SEA-DE) <david.von.oheimb@siemens.com> <mailto:david.von.oheimb@siemens.com>; John Gray <John.Gray@entrust.com> <mailto:John.Gray@entrust.com>
> Betreff: Re: [lamps] [EXTERNAL] Re: [CMP Updates] Requesting a current CRL
>  
> This is an interesting observation, but it does not seem to cover a certificate with multiple CRL distribution points, indirect CRLs, and delta CRLs.  I'm not sure we want all of that complexity here.  That said, it does make sense to me to list a distribution point name and the thisUpdate for each one.
>  
> CRLStatusList ::= SEQUENCE OF CRLStatus
>  
> CRLStatus ::= SEQUENCE {
>    crldpn    DistributionPointName,
>    thisUpdate    Time }
>  
> CRLs ::= SEQUENCE OF CertificateList
>  
>    GenMsg:    {id-it TBD}, CRLStatusList
>    GenRep:    {id-it TBD}, CRLs  |  < absent >
>  
> Russ
>  
>  
> Any email and files/attachments transmitted with it are confidential and are intended solely for the use of the individual or entity to whom they are addressed. If this message has been sent to you in error, you must not copy, distribute or disclose of the information it contains. Please notify Entrust immediately and delete the message from your system. _______________________________________________
> Spasm mailing list
> Spasm@ietf.org <mailto:Spasm@ietf.org>
> https://www.ietf.org/mailman/listinfo/spasm <https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Fspasm&data=04%7C01%7Chendrik.brockhaus%40siemens.com%7Cd0bd97b437a54f3fbfc208d98e590086%7C38ae3bcd95794fd4addab42e1495d55a%7C1%7C0%7C637697336668447824%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=IEmnM2dzkxU2dFpFUI%2Fvp4ZnWoI6vadrn27%2FHhhP84g%3D&reserved=0>