Nuprl Lemma : ses-flow-implies'

s:SES. ∀es:EO+(Info).
  ∀[P:E ─→ E ─→ Atom1 ─→ ℙ]
    ((∀e1,e2:E. ∀a:Atom1.  (((e1 has a) ∧ (e2 has a) ∧ e1 ≤loc e2  P[e1;e2;a]))
     (∀e1,e2:E. ∀snd:E(Send). ∀rcv:E(Rcv). ∀a:Atom1.
          ((e1 c≤ snd
          ∧ rcv c≤ e2
          ∧ (snd < rcv)
          ∧ (Send(snd) Rcv(rcv) ∈ SecurityData)
          ∧ (P[e1;snd;a] ∧ ses-flow(s;es;a;e1;snd))
          ∧ P[rcv;e2;a]
          ∧ ses-flow(s;es;a;rcv;e2))
           P[e1;e2;a]))
     (∀e1,e2:E. ∀encr:E(Encrypt). ∀decr:E(Decrypt). ∀a:Atom1.
          (((e1 <loc encr)
          ∧ decr c≤ e2
          ∧ (encr < decr)
          ∧ ((plainText(decr) plainText(encr) ∈ SecurityData)
            ∧ (cipherText(decr) cipherText(encr) ∈ Atom1)
            ∧ MatchingKeys(key(decr);key(encr)))
          ∧ (key(decr) symmetric-key(a) ∈ Key))
          ∧ (P[e1;encr;a] ∧ ses-flow(s;es;a;e1;encr))
          ∧ (P[encr;decr;cipherText(encr)] ∧ ses-flow(s;es;cipherText(encr);encr;decr))
          ∧ P[decr;e2;a]
          ∧ ses-flow(s;es;a;decr;e2))
           P[e1;e2;a]))
     {∀e1,e2:E. ∀a:Atom1.  (ses-flow(s;es;a;e1;e2)  P[e1;e2;a])})


Proof




Definitions occuring in Statement :  ses-flow: ses-flow(s;es;a;e1;e2) event-has: (e has a) ses-key-rel: MatchingKeys(k1;k2) ses-cipher: cipherText(e) ses-decryption-key: key(e) ses-decrypted: plainText(e) ses-decrypt: Decrypt ses-crypt: cipherText(e) ses-encryption-key: key(e) ses-encrypted: plainText(e) ses-encrypt: Encrypt ses-rcv: Rcv ses-send: Send ses-info: Info security-event-structure: SES symmetric-key: symmetric-key(a) encryption-key: Key sdata: SecurityData es-E-interface: E(X) eclass-val: X(e) event-ordering+: EO+(Info) es-causle: c≤ e' es-le: e ≤loc e'  es-locl: (e <loc e') es-causl: (e < e') es-E: E atom: Atom$n uall: [x:A]. B[x] prop: guard: {T} so_apply: x[s1;s2;s3] all: x:A. B[x] not: ¬A implies:  Q and: P ∧ Q function: x:A ─→ B[x] equal: t ∈ T
Lemmas :  ses-flow-induction ses-flow_wf all_wf es-causle_wf or_wf es-causl_wf es-E_wf event-ordering+_subtype ses-info_wf es-E-interface_wf ses-encrypt_wf es-interface-subtype_rel2 event-ordering+_wf top_wf subtype_top sdata_wf encryption-key_wf ses-decrypt_wf es-locl_wf ses-decrypted_wf ses-encrypted_wf ses-cipher_wf ses-crypt_wf ses-key-rel_wf ses-decryption-key_wf ses-encryption-key_wf not_wf equal-wf-T-base atom1_subtype_base ses-send_wf ses-rcv_wf eclass-val_wf assert_elim in-eclass_wf subtype_base_sq bool_wf bool_subtype_base event-has_wf es-le_wf security-event-structure_wf es-causle_weakening_eq es-causl_transitivity2 es-causle_weakening es-causl_transitivity1 es-causle_weakening_locl es-le_weakening es-causl_weakening

Latex:
\mforall{}s:SES.  \mforall{}es:EO+(Info).
    \mforall{}[P:E  {}\mrightarrow{}  E  {}\mrightarrow{}  Atom1  {}\mrightarrow{}  \mBbbP{}]
        ((\mforall{}e1,e2:E.  \mforall{}a:Atom1.    (((e1  has  a)  \mwedge{}  (e2  has  a)  \mwedge{}  e1  \mleq{}loc  e2  )  {}\mRightarrow{}  P[e1;e2;a]))
        {}\mRightarrow{}  (\mforall{}e1,e2:E.  \mforall{}snd:E(Send).  \mforall{}rcv:E(Rcv).  \mforall{}a:Atom1.
                    ((e1  c\mleq{}  snd
                    \mwedge{}  rcv  c\mleq{}  e2
                    \mwedge{}  (snd  <  rcv)
                    \mwedge{}  (Send(snd)  =  Rcv(rcv))
                    \mwedge{}  (P[e1;snd;a]  \mwedge{}  ses-flow(s;es;a;e1;snd))
                    \mwedge{}  P[rcv;e2;a]
                    \mwedge{}  ses-flow(s;es;a;rcv;e2))
                    {}\mRightarrow{}  P[e1;e2;a]))
        {}\mRightarrow{}  (\mforall{}e1,e2:E.  \mforall{}encr:E(Encrypt).  \mforall{}decr:E(Decrypt).  \mforall{}a:Atom1.
                    (((e1  <loc  encr)
                    \mwedge{}  decr  c\mleq{}  e2
                    \mwedge{}  (encr  <  decr)
                    \mwedge{}  ((plainText(decr)  =  plainText(encr))
                        \mwedge{}  (cipherText(decr)  =  cipherText(encr))
                        \mwedge{}  MatchingKeys(key(decr);key(encr)))
                    \mwedge{}  (\mneg{}(key(decr)  =  symmetric-key(a)))
                    \mwedge{}  (P[e1;encr;a]  \mwedge{}  ses-flow(s;es;a;e1;encr))
                    \mwedge{}  (P[encr;decr;cipherText(encr)]  \mwedge{}  ses-flow(s;es;cipherText(encr);encr;decr))
                    \mwedge{}  P[decr;e2;a]
                    \mwedge{}  ses-flow(s;es;a;decr;e2))
                    {}\mRightarrow{}  P[e1;e2;a]))
        {}\mRightarrow{}  \{\mforall{}e1,e2:E.  \mforall{}a:Atom1.    (ses-flow(s;es;a;e1;e2)  {}\mRightarrow{}  P[e1;e2;a])\})



Date html generated: 2015_07_23-PM-00_05_12
Last ObjectModification: 2015_01_29-AM-07_49_09

Home Index