package com.ibm.ram.extension.demo.policy; import java.io.*; import java.util.List; import com.ibm.ram.common.emf.ArtifactDetail; import com.ibm.ram.common.emf.ArtifactDetails; import com.ibm.ram.defaultprofile.Artifact; import com.ibm.ram.extension.ConfigurationDetails; import com.ibm.ram.extension.PolicyGovernor; import com.ibm.ram.policy.*;
public class WSIPolicy extends AssetPolicy {
private MyGovernor fGovernor;
private static String WSDL_MATCH0 = "<wsdl:input";
private static String WSDL_MATCH1 = "<wsdl:message";
private static String WSDL_MATCH2 = "name=¥"";
private static String WSDL_MATCH3 = "XX";
public WSIPolicy(MyGovernor governor) {
fGovernor = governor;
}
以下のメソッドは、このポリシーの固有 ID を返します。
public String getID() {
return "WSDL_000001";
}
以下のメソッドは、ユーザーに対して表示される名前を返します。
public String getName() {
return "Interoperable Web Services (WS-I)";
}
public String getDescription() {
return "Ensuring Interoperable Web Services - DEMO";
}
以下のメソッドは、ポリシーの管理プログラムを返します。
public PolicyGovernor getPolicyGovernor() {
return fGovernor;
}
以下のコードを使用すると、このカスタム・ポリシーを使用する際にアセットを検証する際の基準を示すロジックを入力することができます。
public Result test() {
Result status = new Result(this)
マニフェスト・アクセサーを使用すると、アセットのマニフェストのすべての部分にアクセスできます。 成果物の詳細は、アセットにあるすべての成果物のリストです。
ArtifactDetails artifactDetails = getManifestAccessor().getArtifactDetails();
if (artifactDetails != null) {
List artifacts = artifactDetails.getArtifactDetails();
以下のコードは、成果物を検証します。
validateArtifacts(status, artifacts); }
どの成果物にもエラーがない場合に表示する、全体的に準拠していることを示すメッセージを設定します。
if(status.getReturnCode() != ResultDetail.ERROR){
status.setMessage("You comply with the WS-I standards");
}
成果物にエラーがある場合は、障害メッセージを表示します。
else{
status.setMessage("<font color=¥"red¥">You do not comply with the WS-I standards</font> To find out more check out our <a href=¥"www.google.com¥">corporate standard guidlines handbook.</a>");
}
return status;
}
private void validateWSDL(Result status, InputStream is, ArtifactDetail detail) {
BufferedReader reader = null;
try {
if (is!=null) {
int lineNo = 0;
reader = new BufferedReader(new InputStreamReader(is));
String line;
StringBuffer message = new StringBuffer();
while ((line = reader.readLine())!=null) {
lineNo++;
int idx = 0;
while (idx>=0 && idx<line.length()) {
int ori = idx;
idx = line.indexOf(WSDL_MATCH0, idx);
if (idx<0) {
idx = line.indexOf(WSDL_MATCH1, ori);
}
if (idx>=0) {
idx = line.indexOf(WSDL_MATCH2, idx);
if (idx>=0) {
idx+=WSDL_MATCH2.length();
if (idx+WSDL_MATCH3.length()<line.length()) {
if (line.substring(idx, idx+WSDL_MATCH3.length()).equalsIgnoreCase(WSDL_MATCH3)) {
message.append("<a href=¥"http://www.ws-i.org/Profiles/BasicProfile-1.0-2004-04-16.html¥">
All WSDLs must be WS-I Compliant </a>: ");
message.append (detail.getName());
message.append ("["+lineNo+"]");
status.addDetail(new ArtifactResultDetail(
detail,
ResultDetail.ERROR,
message.toString()));
}
}
idx+=WSDL_MATCH3.length();
}
}
}
}
}
}
catch (Throwable e) {}
finally {
if (reader!=null) {
try {
reader.close();
} catch (IOException e) {}
}
}
}
以下のコードは、アセットにあるすべての成果物について検証テストを実行します。
private void validateArtifacts(Result status, List artifacts) {
for (int i = 0; i < artifacts.size(); i++) {
ArtifactDetail artifactDetail = (ArtifactDetail) artifacts.get(i);
以下のコードは成果物を検証し、ファイル名の末尾が wsdl になるようにします。
if (artifactDetail.getName() != null
&& artifactDetail.getName().endsWith(".wsdl")) {
InputStream is = null;
BufferedReader reader = null;
try {
以下のコードは、成果物のコンテンツの検証を試行します。
Artifact artifact = getManifestAccessor().getArtifact( artifactDetail.getPath(), artifactDetail.getName());
以下のコードは、artifactAccessor を使用して成果物のコンテンツを読み取ります。
is = getArtifactAccessor().getArtifactContent(artifact);
if (is != null) {
validateWSDL(status, is, artifactDetail);
}
} catch (Throwable e) {
//print out any exception
e.printStackTrace();
} finally {
以下のコードは、入力ストリームを閉じます。
try {
if (reader != null)
reader.close();
if (is != null)
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
public ConfigurationDetails[] getConfigurationDetails() {
return null;
}
}