• No se han encontrado resultados

Descripción de procedimiento

INSTANCIA DE CONTROL (OIC, UR) Área de Responsabilidades

Let us first briefly explain how the ghost state mechanism works before formally describing it. A ghost state is a state extended to allow expres- sions of the form ghostpmq in the intruder’s knowledge, where m is a super-lazy term. When, during the backwards reachability analysis, we detect a state St having a super lazy term t in an expression tPI in the intruder’s knowledge, we replace the intruder fact tPI in St by ghostptq and keep the ghost version of St in the history of states used by the transition subsumption of Section 4.4.3.

Example 4.21 The statep6q of Example 4.18 with a super-lazy intruder term K would be represented as follows, where we have just replaced KPI by ghostpKq:

4.5. The Super-Lazy Intruder 89

r nil | pKq, pepK, SRqq, pSRq s & :: r1 ::

r pA; B; E1q, pB; A; exppg, npB, r1qqq |

pepexppE1, npB, r1qq, SRqq s &

pghostpKq, epexppE1, npB, r1qq, SRqPI,

epK, SRqqPI, SRRIq

p6q

Similarly, the statep6 q of Example 4.19 would be represented as follows, where we have just added the expression ghostpexppX, npa, r1qqq to the

intruder knowledge:

r nil | pexppX, npa, r1qqq, pepexppX, npa, r1qq, secpa, r2qqq,

psecpa, r2qq s &

:: r1 ::

r pA; B; E1q, pB; A; exppg, npB, r1qqq |

pepexppE1, npB, r1qq, secpa, r2qqq s &

:: r1, r2::

r pa; B; exppg, npa, r1qqq, pB; a; Xq |

pepexppX, npa, r1qq, secpa, r2qqqs &

pghostpexppX, npa, r1qqq, epexppE1, npB, r1qq, secpa, r2qqPI,

exppX, npa, r1qqPI, pepexppX, npa, r1qq, secpa, r2qqqRI, secpa, r2qRIq

p6 q

 Suppose that later in the backwards search tree we find a descendant state St1 in which ghostpuq has been instantiated to ghostptq, where t is not a super lazy intruder term as in the state p6 q of Example 4.21. For the intruder to learn such a term t, it may be necessary for certain actions to occur before St1 was produced. That is, we must “roll back” and replace the current state St1, containing expression ghostptq, by an instantiated version of its ancestor state St, namely Stθ, where tEP uθ.

This is explained in detail in Definition 4.28 below.

A complication is introduced if the substitution θ binding variables in u includes variables of sort Fresh. These must have been introduced by strands indexed by these fresh variables. If the strand indexed by a fresh

variable in t already appears in St, then there is no problem. However, if the strand was introduced later in the backwards narrowing process, and we do not include them in St, then this will result in difficulties. If such a strand is not in the reactivated version of St, it will not be re-introduced in the backwards narrowing search, because the fresh variables in newly introduced strands are non-unifiable with any of the fresh variables al- ready present. Therefore, the strands indexed by these fresh variables must also be included in the “rolled back” state, even if they were not there originally. Moreover, they must have the bar at the place where it was when the strands were originally introduced. We show below how this is accomplished. Furthermore, if any of the strands thus introduced have other variables of sort Fresh as subterms, then the strands indexed by those variables must be included too, and so on. That is, when a state St1 properly instantiating a ghost expression ghostptq is found, the procedure of rolling back to the original state St that gave rise to that ghost expression implies not only applying the bindings for the variables of t to St, but also introducing in St all the strands from St1 that pro- duced fresh variables and that either appear in the variables of t or are recursively connected with them.

Example 4.22 Consider the statesp6q and p6 q of Example 4.21. After the tool finds an instantiation for variable K in the narrowing step from state p6q to state p6 q, the tool rolls back to the state (6), originating the super-lazy term K, as follows; where we have transformed statep6 q by moving the vertical bar of Alice’s strand at the rightmost position because it is the strand generating the Fresh variable r2:

r nil | pexppX, npa, r1qqq, pepexppX, npa, r1qq, secpa, r2qqq,

psecpa, r2qq s & :: r1 :: r pA; B; E1q, pB; A; exppg, npB, r1qqq | pepexppE1, npB, r1qq, secpa, r 2qqq s & :: r1, r2 ::

r pa; B; exppg, npa, r1qqq, pB; a; Xq,

pepexppX, npa, r1qq, secpa, r2qqq | nils &

pepexppE1, npB, r1qq, secpa, r

2qqPI, exppX, npa, r1qqPI,

epexppX, npa, r1qq, secpa, r2qqPI, secpa, r2qRIq

4.5. The Super-Lazy Intruder 91

 In order for the super-lazy intruder mechanism to be able to tell where the bar was when a strand was introduced, we must modify the set of rules of type (3.4) introducing new strands:

t r l1| u s & tuRI, Ku Ñ tuPI, Ku | r l1, u , l2s P SPu (4.2)

Note that rules of type (3.4) introduce strandsr l1 | u , l2s, whereas here

rules of type (4.2) introduce strands r l1 | u s. This slight modification

makes it possible to safely move the position of the bar back to the place where the strand was introduced. However, now the strands added may be partial, since the whole sequence of actions performed by the principal is not directly recorded in the strand. Therefore, the set of rewrite rules used by narrowing in reverse are now ‚RBP  t(4.1), (3.2), (3.3)uYt(4.2)u;

note that (4.2) represents a set of rules.

First, we define a new relation „EP between states, which is similar

to„EP of Definition 4.7 but considers partial strands.

Definition 4.23 (Partial Inclusion) Given two states St1, St2, we

abuse notation and write St1 „EP St2 to denote that every intruder fact

in St1 appears in St2 (modulo EP) and that every strand rm1, . . . , mks

in St1, either appears in St2 (modulo EP) or there is i P t1, . . . , ku s.t.

mi  mi and rm1, . . . , mi s appears in St2 (modulo EP).

The following result ensures that if a state is reachable via backwards reachability analysis using RBP, then it is also reachable using ‚RBP. Its

proof is straightforward, and we omit it.

Proposition 4.24 Let RP  pΣP, EP, RBPq be a topmost rewrite the-

ory representing protocol P. Let St  ss & SS & pik, IKq where ss is a term representing a set of strands, ik is a term representing a set of in- truder facts, SS is a variable for strands, and IK is a variable for intruder knowledge. If there is an initial state Stini and a substitution σ such that

St ;

σ,R1BP,EP Stini, then there is an initial state St

1

ini and two sub-

stitutions σ1, ρ such that St ;

σ1, ‚RBP1,EP

St1ini, σ EP σ1  ρ, and

pSt1

iniqρ „EP Stini.

Now, we describe how to reactivate a state. First, we formally define a ghost state.

Definition 4.25 (Ghost State) Given a topmost rewrite theory RP  pΣP, EP, RBPq representing protocol P and a state St contain-

ing an intruder fact tPI such that t is a super-lazy term, we define the ghost version of St, written St, by replacing tPI in St by ghostptq in St. Now, in order to resuscitate a state, we need to formally compute the strands that are generating Fresh variables relevant to the instantiation found for the super-lazy term.

Definition 4.26 (Strand Reset) Given a strand s of the form :: r1, . . . , rk :: rm1, . . . | . . . , mns, when we want to move the bar to the

rightmost position (denoting a final strand), we write s" :: r1, . . . , rk ::

rm

1, . . . , mn | nils.

Definition 4.27 (Fresh Generating Strands) Given a state St con- taining an intruder fact ghostptq for some term t with variables, we define the set of strands associated to t, denoted strandsStptq, as the least set

satisfying the following two conditions:

• for each strand s in St of the form :: r1, . . . , rk :: rm1, . . . |

. . . , mns, if there is i P t1, . . . , ku s.t. ri P Varptq, then s" is

included into strandsStptq; or

• for each strand s in St of the form :: r1, . . . , rk :: rm1, . . . |

. . . , mns, if there is another strand s1 of the form :: r11, . . . , rk11 ::

rw

1, . . . | . . . , wn1s in strandsStptq, and there are i P t1, . . . , ku

and j P t1, . . . , n1u s.t. ri P Varpwjq, then s" is included into

strandsStptq.

Now, we formally define how to resuscitate a state.

Definition 4.28 (Resuscitation) Given a topmost rewrite theory RP  pΣP, EP, ‚RBPq representing protocol P and a state St contain-

ing an intruder fact tPI such that t is a super-lazy term, i.e., St  ss &ptPI, ikq where ss is a term denoting a set of strands and ik is a term denoting the rest of the intruder knowledge. Let St be the ghost version of St. Let St1 be a state such that St ;

σ, ‚RBP1,EP

St1 and tσ is not a super-lazy term. Let σt  σ|Varptq. The reactivated (or resus-

citated) version of St w.r.t. state St1 and substitution σt is defined as

x

4.5. The Super-Lazy Intruder 93

Example 4.29 Consider the statep6öq in Example 4.22. We can check that state p6öq is the resuscitated version of state p6q w.r.t. state p6 q and the substitution tK ÞÑ exppX, npa, r1qq, A ÞÑ au. 

Let us now prove the completeness of this state space reduction tech- nique.

Theorem 4.30 Given a topmost rewrite theory RP  pΣP, EP, ‚RBPq

representing protocol P and a state St containing an intruder fact tPI such that t is a super-lazy term, if there exist an initial state Stini and

substitution θ such that St;

θ, ‚RBP1,EP

Stini, then (i) there exist a state

St1 and substitutions τ, τ1 such that St;

τ, ‚RBP 1

,EP

St1, θEP ττ1, and

tτ is not a super-lazy term, and (ii) there exist a reactivated version xSt of St w.r.t. St1 and τ , an initial state St1ini, and substitutions θ1, ρ such that xSt;

θ1, ‚RBP 1

,EP

St1ini, θEP θ1 ρ, and pSt1iniqρ „EP Stini.

Proof. The sequence from St to Stini can be decomposed into two frag-

ments, computing substitutions τ and τ1, respectively, such that there is a state St1 and substitutions τ , τ1 such that tτ is not a super-lazy term, θ  τ  τ1, St ; τ, ‚RBP 1 ,EP St1 ; τ1, ‚RBP 1 ,EP

Stini, and the se-

quence St ; τ, ‚RBP1,EP St1 can be viewed as St  St0 ;τ 1, ‚RBP 1 ,EP    ;τ k, ‚RBP 1 ,EP Stk  St

1 such that for all i P t1, . . . , k  1u, tτ i is

a super-lazy term. However, using the completeness results of narrow- ing, Theorem 2.5, there must be a narrowing sequence from St com- puting such substitution τ . That is, there is a state St2 such that St ;

τ, ‚RBP1,EP

St2 and St2 differs from St1 (modulo EP-equivalence

and variable renaming) only in that tτPI is replaced by ghostptτq. Let τt  τ|Varptq, there exists a substitution τ2 s.t. τ EP τt τ2. Let xSt be

the resuscitated version of St w.r.t. state St2 and substitution τt. Then,

by narrowing completeness, i.e., Theorem 2.5, there exist a state St1ini and substitutions σ, ρ such that xSt ;

σ, ‚RBP1,EP

St1ini, τ2 τ1 EP σ ρ,