package com.ibm.ram.extension.demo.policy;
import java.io.*;
import java.util.Locale;
import org.eclipse.core.runtime.NullProgressMonitor;
import com.ibm.ram.client.*;
import com.ibm.ram.common.data.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;
}
La méthode suivante renvoie un ID unique pour cette stratégie :
public String getID() {
return "WSDL_000001";
}
La méthode suivante renvoie le nom tel qu'il sera affiché pour l'utilisateur :
public String getName(Locale locale) {
return "Services Web interopérables (WS-I)";
}
public String getDescription(Locale locale) {
return "Vérification de l'interopérabilité des services Web - DEMO";
}
La méthode suivante renvoie le gouverneur de la stratégie :
public PolicyGovernor getPolicyGovernor() {
return fGovernor;
}
Vous pouvez utiliser le code suivant pour définir la logique qui décrit par rapport à quels critères contrôler la validité des actifs lorsque cette stratégie personnalisée est en vigueur :
public Result test() {
Statut du résultat = new Result(this)
Vous pouvez utiliser la méthode GetRAMAsset de contexte de stratégie puis les API client pour accéder à toutes les parties d'un actif. L'objet artifacts est une liste de tous les artefacts de l'actif :
RAMAsset asset = this.getPolicyContext().getRAMAsset();
RAMFolderArtifact folderArtifact = (RAMFolderArtifact)asset.getArtifactsRoot();
Artifact[] artifacts = folderArtifact.computeArtifactsAsFlatList(new NullProgressMonitor());
Le code suivant contrôle la validité des artefacts :
if (artifacts != null) {
validateArtifacts(status, artifacts);
}
if(status.getReturnCode() != ResultDetail.ERROR){
status.setMessage("Vous vous conformez aux standards WS-I");
}
else{
status.setMessage("<font color=\"red\">Vous ne respectez pas les
standards WS-I</font> Pour en savoir plus, consultez notre <a
href=\"www.google.com\">guide de référence des standards.</a>");
}
return status;
}
private void validateWSDL(Result status, InputStream is, Artifact artifact) {
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\">Tous les WSDL doivent être conformes WS-I </a>: ");
message.append (artifact.getName());
message.append ("["+lineNo+"]");
status.addDetail(new ArtifactResultDetail(
artifact,
ResultDetail.ERROR,
message.toString()));
}
}
idx+=WSDL_MATCH3.length();
}
}
}
}
}
}
catch (Throwable e) {}
finally {
if (reader!=null) {
try {
reader.close();
} catch (IOException e) {}
}
}
}
/**
* Exécute la validation sur tous les artefacts de l'actif
*/
private void validateArtifacts(Result status, Artifact[] artifacts) {
for (int i = 0; i < artifacts.length; i++) {
Artifact artifact = artifacts[i];
// Valider un artefact XML - s'assurer que le nom de fichier se termine par XML
if (artifact.getName() != null
&& artifact.getName().endsWith(".wsdl")) {
InputStream is = null;
BufferedReader reader = null;
try {
if (artifact instanceof RAMArtifact) {
// Utiliser l'artifactAccessor pour lire le contenu d'un artefact
is = ((RAMArtifact)artifact).downloadContents();
if (is != null) {
validateWSDL(status, is, artifact);
}
}
} catch (Throwable e) {
//imprimer l'exception s'il y en a une
e.printStackTrace();
} finally {
Le code suivant ferme le flux d'entrée :
try {
if (reader != null)
reader.close();
if (is != null)
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
public ConfigurationDetails[] getConfigurationDetails(Locale locale) {
return null;
}
}