📄 adjustedperiodcollection.java
字号:
/*
* Copyright (c) 2000-2005, University of Salford
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of the University of Salford nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package issrg.pba.rbac;
/**
* This is a collection of periods that are applied together. This is an
* advanced implementation of intersection. Normally the
* IntersectionValidityPeriod produces the validity period that is just a set of
* the latest notBefore and the earliest notAfter, which is good for
* constraining. However, Age and Min cannot be implemented this way, because
* if the ValidityPeriod exceeds one of the margins, it is fully invalid, and
* not just constrained.
*
* @author A.Otenko
*/
public class AdjustedPeriodCollection extends AdjustedValidityPeriod {
private ValidityPeriod vp1;
private ValidityPeriod vp2;
protected AdjustedPeriodCollection(){
super();
}
/**
* This constructor builds a AdjustedPeriodCollection of two ValidityPeriods.
* More ValidityPeriods can be added to the collection by chaining multiple
* AdjustedPeriodCollection as a binary tree. Both ValidityPeriods are treated
* equally.
*
* @param vp1 - one ValidityPeriod
* @param vp2 - another ValidityPeriod
*/
public AdjustedPeriodCollection(ValidityPeriod vp1, ValidityPeriod vp2) {
super();
this.vp1=vp1;
this.vp2=vp2;
}
/**
* This method returns an adjusted ValidityPeriod, where the collection of
* ValidityPeriods provided at construction time is adjusted against the
* given ValidityPeriod.
*
* @param vp - the ValidityPeriod to adjust against
*/
public ValidityPeriod adjust(ValidityPeriod vp){
if (vp1!=null){
if (vp1 instanceof AdjustedValidityPeriod){
vp = ((AdjustedValidityPeriod)vp1).adjust(vp);
}else{
vp = new IntersectionValidityPeriod(vp1, vp);
}
}
if (vp2!=null){
if (vp2 instanceof AdjustedValidityPeriod){
vp = ((AdjustedValidityPeriod)vp2).adjust(vp);
}else{
vp = new IntersectionValidityPeriod(vp2, vp);
}
}
return vp;
}
public String toString(){
return "{rule "+vp1+" && "+vp2+"}";
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -