Clover Coverage Report
Coverage timestamp: Sun Mar 23 2008 08:24:39 GMT
3   86   1   1.5
0   13   0.67   2
2     1  
1    
 
 
  SimpleEntry       Line # 65 3 1 100% 1.0
 
  (1)
 
1    /*
2    * Copyright (c) 2006, University of Kent
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions are met:
7    *
8    * Redistributions of source code must retain the above copyright notice, this
9    * list of conditions and the following disclaimer.
10    *
11    * Redistributions in binary form must reproduce the above copyright notice,
12    * this list of conditions and the following disclaimer in the documentation
13    * and/or other materials provided with the distribution.
14    *
15    * 1. Neither the name of the University of Kent nor the names of its
16    * contributors may be used to endorse or promote products derived from this
17    * software without specific prior written permission.
18    *
19    * 2. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
20    * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21    * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22    * PURPOSE ARE DISCLAIMED.
23    *
24    * 3. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
25    * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26    * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27    * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28    * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29    * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30    * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31    * POSSIBILITY OF SUCH DAMAGE.
32    *
33    * 4. YOU AGREE THAT THE EXCLUSIONS IN PARAGRAPHS 2 AND 3 ABOVE ARE REASONABLE
34    * IN THE CIRCUMSTANCES. IN PARTICULAR, YOU ACKNOWLEDGE (1) THAT THIS
35    * SOFTWARE HAS BEEN MADE AVAILABLE TO YOU FREE OF CHARGE, (2) THAT THIS
36    * SOFTWARE IS NOT "PRODUCT" QUALITY, BUT HAS BEEN PRODUCED BY A RESEARCH
37    * GROUP WHO DESIRE TO MAKE THIS SOFTWARE FREELY AVAILABLE TO PEOPLE WHO WISH
38    * TO USE IT, AND (3) THAT BECAUSE THIS SOFTWARE IS NOT OF "PRODUCT" QUALITY
39    * IT IS INEVITABLE THAT THERE WILL BE BUGS AND ERRORS, AND POSSIBLY MORE
40    * SERIOUS FAULTS, IN THIS SOFTWARE.
41    *
42    * 5. This license is governed, except to the extent that local laws
43    * necessarily apply, by the laws of England and Wales.
44    */
45    package issrg.pba.rbac.policies;
46   
47    import issrg.pba.repository.EntryLocator;
48    import java.security.Principal;
49    import issrg.utils.repository.Entry;
50   
51    /**
52    * This class is a simple implementation of an Entry that locates the tokens
53    * in the entry named by the Principal. More complex implementations may
54    * separate TokenLocator from Entry Name.
55    *
56    * <p>Entry name is used to match domains
57    * in the policy, whilst the TokenLocator is used to retrieve Authorisation
58    * Tokens from
59    * repositories. There is only one Entry per Authorisation entity, but there
60    * may be multiple TokenLocators.
61    *
62    * @author A.Otenko
63    */
64   
 
65    public class SimpleEntry extends EntryLocator implements Entry {
66    /**
67    * This constructor builds a SimpleEntry that uses the same Principal to
68    * match the policy and locate tokens in the repository.
69    *
70    * @param entryName - the name of the Entry, and the locator of the
71    * authorisation tokens.
72    */
 
73  3029 toggle public SimpleEntry(Principal entryName){
74  3029 super(null, entryName, null, null);
75  3029 e=this;
76    }
77   
78    /**
79    * This method uses the primary Token Locator as the Entry name. It is
80    * equivalent to calling getLocator() on this object, so careful when
81    * overriding the method.
82    */
 
83  5672 toggle public Principal getEntryName(){
84  5672 return getLocator();
85    }
86    }