カスタマイズの例
このセクションの例では、新しく追加した属性が ESI RPC 応答に表示されるために ESI サービスで何が行われる必要があるかについてのみ説明します。その他のカスタマイズオプションの例については、「ERP コネクタのカスタマイズの例」のセクションを参照してください。
追加属性がある部品のパブリッシング
追加属性は、モデル化属性、ソフト属性、または IBA のいずれかです。属性の名前を仮に standardPrice とします。この属性が ESI 応答で送信されるようにするには、以下の手順を実行します。
1. 「タイプおよび属性の管理」 UI を使用して standardPrice を WTPart にソフト属性として追加するか、IBA として追加します。あるいは、WTPart のソフトタイプ拡張にソフト属性として追加したり、モデル化属性として追加したりすることもできます (その場合、Windchill ESI プリファレンス「部品クラス」を編集して、WTPart 拡張クラスの完全修飾名を指定する必要があります)。
2. ESI 応答メタ情報ファイルのコピーを作成し、以下で説明するようにそのコンテンツを修正します。
<esi:Map id="ESINewPart">
<esi:attributeMapping sourceAttribute="obid">ObjectID</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="iterationInfo.identifier.iterationId">Iteration</esi:attributeMapping>
<esi:attributeMapping sourceAttribute="PreviousVersion">PreviousVersion</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="standardPrice">StandardPrice</esi:attributeMapping>
</esi:Map>
<esi:MapInformation id="ESIPartInfo">
<esi:typedef>wt.part.WTPart</esi:typedef>
<esi:elementMetaName>Part</esi:elementMetaName>
<esi:keyAttribute>Number</esi:keyAttribute>
…
<esi:mapRef>ESINewPart</esi:mapRef>
</esi:MapInformation>
上記でハイライトされている部分からわかるように、Map エレメントと MapInformation エレメント (id 属性の値として "ESIPart" と "ESIPartInfo" を持つ) に変更を加える必要があります。Map エレメントの id 属性は修正後の値に設定され、属性 standardPrice 用の新しい attributeMapping エレメントが追加されています。さらに、関連する MapInformation エレメントの mapRef エレメントの値が、Map エレメントの id 属性の修正後の値に設定されています。
|
Map エレメントに変更を加えた場合、その id 属性の値も変更する必要があります。また、新しい属性 (standardPrice など) を追加したことで WTPart の新しい拡張が作成された場合、そのタイプの完全修飾名を MapInformation エレメントの typedef エレメントの値として指定する必要があります。詳細については、 ESI 応答メタ情報ファイルの修正を参照してください。
|
3. 「配布を管理」 UI ( > または > の下に表示) を使用して、部品のパブリッシング先となる配布ターゲットの「配布ターゲットを編集」 UI を開きます。ESI Response Meta Information File Path フィールドを、手順 2 で修正したファイルに設定します。「OK」をクリックして配布ターゲットを保存します。編集後のターゲットをパブリッシング対象の部品に関連付けます (まだ関連付けられていない場合)。
(属性 standardPrice が必要な値に設定された状態で) 部品をパブリッシングすると、手順 3 で編集した配布ターゲットに対する ESI 応答で、新しく追加した属性 StandardPrice が送信されます。部品が初めてパブリッシングされた場合、応答の <AddedParts> セクションの <Part> エレメント内に子 XML エレメント <StandardPrice> が表示されます。明らかに、前述のユースケースは単に応答メタ情報ファイルの修正を必要としているだけで、その意味ではカスタマイズは必要ありません。
|
• 応答の <Part> エレメント内における <StandardPrice> エレメントの位置は、(応答メタ情報ファイルの) Map エレメントのどこに新規エントリが追加されるかによって異なります。たとえば、上記の例に示すように Map エレメントの最後のエントリとして追加された場合、<StandardPrice> は応答の <Part> エレメント内の最後の子エレメントとして表示されます。
• WTPart のソフトタイプ (モデル化された) 拡張バージョンをパブリッシングする場合、WTPart オブジェクトと比較して拡張バージョンに異なる属性セットをパブリッシングする必要がある場合にのみ、(上記の手順 ii で説明したように) ESI 応答メタ情報ファイルは変更を必要とします。詳細については、 ESI 応答情報ファイルを修正する際の注意事項のセクションを参照してください。
|
追加情報がある部品のパブリッシング
属性として WTPart オブジェクトに存在しない追加情報を ESI 応答の <Part> エレメントで送信することがあります (その部品がアセンブリであるかどうかを示す <IsAssembly> という名前の子 XML エレメントなど)。この子エレメントが ESI 応答に表示されるためには、以下の手順を実行する必要があります。
1. ESI 応答メタ情報ファイルのコピーを作成し、以下で説明するようにそのコンテンツを修正します。
<esi:Map id="ESINewPart">
<esi:attributeMapping sourceAttribute="obid">ObjectID</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="isAssembly">IsAssembly</esi:attributeMapping>
</esi:Map>
<esi:MapInformation id="ESIPartInfo">
<esi:typedef>wt.part.WTPart</esi:typedef>
<esi:elementMetaName>Part</esi:elementMetaName>
<esi:keyAttribute>Number</esi:keyAttribute>
…
<esi:mapRef>ESINewPart</esi:mapRef>
</esi:MapInformation>
2. クラス com.ptc.windchill.esi.esipart.ESIWTPartRenderer の拡張を作成し、以下の手順に従って adjustPartElement() メソッドをオーバーライドします。
protected Element adjustPartElement( Element element, String group, WTPart part, Eff[] effs, Collection targets )
throws ESIRendererException { boolean isAssem;
try {
isAssem = new BOMUtility().isBom(part);
}
catch(WTException wte) {
ESILogger.debug("Exception while invoking isBom() for part: " + part.getNumber());
throw new ESIRendererException(wte);
}
Att att = element.getAtt(“IsAssembly”);
if(att != null && (att.getValue() == null || att.getValue().toString().trim().equals(“”)))
{
att.setValue(String.valueOf(isAssem));
}
return element;
}
3. 「配布を管理」 UI ( > または > の下に表示) を使用して、部品のパブリッシング先となる配布ターゲットの「配布ターゲットを編集」 UI を開きます。ESI Response Meta Information File Path フィールドを、手順 1 で修正したファイルに設定します。「OK」をクリックして配布ターゲットを保存します。編集後のターゲットをパブリッシング対象の部品に関連付けます (まだ関連付けられていない場合)。
4. ファイル <Windchill>\codebase\com\ptc\windchill\esi\conf\esi.service.properties.xconf を開き、以下のエントリを見つけます。
<Option cardinality="duplicate" requestor="wt.part.WTPart" serviceClass="com.ptc.windchill.esi.esipart.ESIWTPartRenderer"/>
上記のエントリを編集して、serviceClass 属性の値として (手順 2 で作成した) ESIWTPartRenderer の拡張の完全修飾名を指定します。詳細については、
カスタマイズポイントを参照してください。
5. 手順 4 で行った変更が適切に反映されるように、Windchill シェルからコマンド xconfmanager –p を実行します。メソッドサーバーを再起動します。
部品をパブリッシングすると、<IsAssembly> エレメントが ESI 応答で送信されるようになります。このユースケースでは、WTPart オブジェクトの属性として存在しない情報、つまり Query-Objects Webject を使用してフェッチできない情報を送信する必要があるので、部品レンダラーをカスタマイズする必要があります。
ヘッダー部品に追加属性があるアセンブリのパブリッシング
この例では、「追加属性がある部品のパブリッシング」のセクションで説明したものと同じ手順に従う必要がありますが、手順 2 で示されている応答メタ情報ファイルの Map エレメントと MapInformation エレメントを BOM ヘッダー用の値に置き換えます。つまり、id 属性として値 BOMHeader を持つ Map エレメントは新しい attributeMapping エレメントを持ち、Map エレメントの id 属性は修正後の値 (NewBOMHeader など) を持ち、関連する MapInformation エレメントの mapRef エレメントはこの修正後の値を持ちます。また、アセンブリを初めてパブリッシングしたときに、応答の <AddedBOMs> セクションの <BOMHeader> エレメントに (追加した属性に対応する) 新しい子 XML エレメントが表示されます。
追加情報があるアセンブリのパブリッシング
この場合も、この例では、「追加情報がある部品のパブリッシング」のセクションで説明したものと同じ手順に従う必要がありますが、手順 1 で示されている応答メタ情報ファイルの Map エレメントと MapInformation エレメントをそれぞれ値 BOMHeader および BOMHeaderInfo に置き換えます。また、Java クラス com.ptc.windchill.esi.bom.ESIBOMHeaderRenderer を拡張し、以下のメソッドをオーバーライドします。
protected Element adjustElement( Element element, String group, WTPart part, Eff[] effs, Collection targets) throws ESIRendererException
また、以下の ESI サービスプロパティエントリを編集します。
<Option cardinality="duplicate" requestor="wt.part.WTPart" selector="BOMHEADER" serviceClass="com.ptc.windchill.esi.bom.ESIBOMHeaderRenderer"/>
|
上記のエントリを編集して、serviceClass 属性の値として ESIBOMHeaderRenderer の拡張の完全修飾名を指定します。このプロパティを通常の方法で適用してメソッドサーバーを再起動します。
|
アセンブリをパブリッシングすると、必要な追加情報が ESI 応答で送信されるようになります。これは、ESI 応答の <BOMHeader> エレメント内に、新しく追加された子 XML エレメントとして表示されます。
WTPartUsageLink に追加属性があるアセンブリのパブリッシング
この例では、アセンブリ部品を特定の部品マスターにリンクする WTPartUsageLink オブジェクトに追加されたソフト属性をパブリッシングします。ソフト属性の名前を仮に color とします。この属性が ESI 応答で送信されるようにするには、以下の手順を実行します。
• 通常の方法である「タイプおよび属性の管理」 UI を使用して、WTPartUsageLink にソフト属性として color を追加します。
• ESI 応答メタ情報ファイルのコピーを作成し、以下で説明するようにそのコンテンツを修正します。
<esi:Map id="NewBOMComponent">
<esi:attributeMapping sourceAttribute="PartMasterID">ObjectID</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="PartUsageLink.ComponentId">ComponentId</esi:attributeMapping>
<esi:attributeMapping sourceAttribute="xxxx">IsChildPhantom</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="color">Color</esi:attributeMapping>
</esi:Map>
<esi:MapInformation id="BOMComponentInfo">
<esi:typedef>wt.part.WTPartUsageLink</esi:typedef>
...
<esi:mapRef>NewBOMComponent</esi:mapRef>
</esi:MapInformation>
上記でハイライトされている部分からわかるように、Map エレメントと MapInformation エレメント (id 属性の値として BOMComponent と BOMComponentInfo を持つ) に変更を加える必要があります。Map エレメントの id 属性は修正後の値に設定され、属性 color 用の新しい attributeMapping エレメントが追加されています。さらに、関連する MapInformation エレメントの mapRef エレメントの値が、Map エレメントの id 属性の修正後の値に設定されています。
• 「配布を管理」 UI ( > または > の下に表示) を使用して、アセンブリのパブリッシング先となる配布ターゲットの「配布ターゲットを編集」 UI を開きます。ESI Response Meta Information File Path field を、手順 2 で修正したファイルに設定します。「OK」をクリックして配布ターゲットを保存します。編集後のターゲットをパブリッシング対象のアセンブリ (およびそのコンポーネント部品) に関連付けます (まだ関連付けられていない場合)。
(各コンポーネントで属性 color が必要な値に設定された状態で) アセンブリをパブリッシングすると、ESI 応答で、新しく追加した属性 Color が送信されます。アセンブリが初めてパブリッシングされた場合、応答の <AddedBOMComponents> セクションの <BOMComponent> エレメント内に子 XML エレメント <Color> が表示されます。明らかに、前述のユースケースは単に応答メタ情報ファイルの修正を必要としているだけで、その意味ではカスタマイズは必要ありません。
|
ESI 応答の <BOMComponent> エレメント内における <Color> エレメントの位置は、応答メタ情報ファイルの Map エレメントのどこに新規エントリが追加されるかによって異なります。
|
コンポーネント部品に関する追加情報があるアセンブリのパブリッシング
追加情報を ESI 応答の <BOMComponent> エレメントで送信する必要が生じることがあります (そのコンポーネント部品が最終品目であるかどうかを示す子エレメント <IsEndItem> など)。これを行うには、以下の手順を実行します。
1. 応答メタ情報ファイルのコピーを作成し、以下で説明するようにそのコンテンツを修正します。
<esi:Map id="NewBOMComponent">
<esi:attributeMapping sourceAttribute="PartMasterID">ObjectID</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="PartUsageLink.ComponentId">ComponentId</esi:attributeMapping>
<esi:attributeMapping sourceAttribute="xxxx">IsChildPhantom</esi:attributeMapping>
…
<esi:attributeMapping sourceAttribute="isEndItem">IsEndItem</esi:attributeMapping>
</esi:Map>
<esi:MapInformation id="BOMComponentInfo">
<esi:typedef>wt.part.WTPartUsageLink</esi:typedef>
...
<esi:mapRef>NewBOMComponent</esi:mapRef>
</esi:MapInformation>
2. クラス ESIBOMComponentRenderer の拡張を作成し、メソッド adjustElement(Element, String, PartUsageInfo, Collection) を以下のようにオーバーライドします。
protected Element adjustElement(Element elem, String group, PartUsageInfo pui, Collection targets )
throws ESIRendererException { Att att = elem.getAtt(“IsEndItem”);
if(att != null && (att.getValue() == null || att.getValue().toString().trim().equals(NULL_STRING)))
{
boolean endItem = pui.getUses().isEndItem();
String endItemAsStr = String.valueOf(endItem);
att.setValue(endItemAsStr);
}
return elem;
}
3. 「配布を管理」 UI ( > または > の下に表示) を使用して、アセンブリのパブリッシング先となる配布ターゲットの「配布ターゲットを編集」 UI を開きます。ESI Response Meta Information File Path フィールドを、手順 1 で修正したファイルに設定します。「OK」をクリックして配布ターゲットを保存します。編集後のターゲットをパブリッシング対象のアセンブリ (およびそのコンポーネント部品) に関連付けます (まだ関連付けられていない場合)。
4. ファイル <Windchill>\codebase\com\ptc\windchill\esi\conf\esi.service.properties.xconf を開き、以下のエントリを見つけます。
<Option cardinality="duplicate" requestor="wt.part.WTPart" selector="BOMCOMPONENT" serviceClass="com.ptc.windchill.esi.bom.ESIBOMComponentRenderer"/>
上記のエントリを編集して、serviceClass 属性の値として (手順 2 で作成した) ESIBOMComponentRenderer の拡張の完全修飾名を指定します。
5. 手順 4 で行った変更が適切に反映されるように、Windchill シェルからコマンド xconfmanager –p を実行します。メソッドサーバーを再起動します。
アセンブリをパブリッシングすると、<IsEndItem> エレメントが ESI 応答で送信されるようになります。このユースケースでは、WTPartUsageLink オブジェクトの属性として存在しない情報、つまり Query-Objects Webject を使用してフェッチできない情報を送信する必要があるので、BOM コンポーネントレンダラーをカスタマイズする必要があります。
アセンブリ部品の作業版数に設定されているものとは異なる親子関係を持つアセンブリのパブリッシング
BOM トランスフォーマを使用してアセンブリ部品の作業版数に設定されている親子関係の値をアセンブリのパブリッシング時にオーバーライドできます。このためには以下の手順を実行する必要があります。
1. Windchill ESI プリファレンス「ビューと配布ターゲットのマッピング」を、アセンブリのパブリッシング先となる配布ターゲットに Windchill ビューを関連付ける値に設定します。たとえば、アセンブリが設計ビューで作成され、Number 属性の値が 00001 である配布ターゲットにパブリッシングする場合、このプリファレンスを Design:00001 に設定します。
2. Windchill ESI プリファレンス「ビューと BOM タイプのマッピング」を、必要な BOM 親子関係の値に Windchill ビューを関連付ける値に設定します。たとえば、アセンブリをエンジニアリングアセンブリとしてパブリッシングする場合、このプリファレンスを Design:Engineering に設定します。
|
アセンブリがサイトにあるか組織内にあるかに応じて、サイトまたは組織でこれらのプリファレンスを設定できます。
|
3. 番号 00001 の配布ターゲットを対象のアセンブリに関連付けて、このアセンブリをリリースします。
|
配布ターゲットの「コンテキストのデフォルト」属性の値が「はい」に設定されている場合、(i) で説明した設定によって、ターゲットはアセンブリ部品に自動的に関連付けられます。
|
上記の結果として、リリース済みアセンブリの ESI 応答の Usage エレメントのコンテンツからわかるように、アセンブリはエンジニアリングアセンブリとして送信されます。送信された値によって、BOM トランスフォーマを使用してアセンブリ部品の作業版数に設定されているその他の BOM 親子関係の値がすべてオーバーライドされることを覚えておくことが重要です。
削除された BOM コンポーネントにカスタム属性が含まれているアセンブリのパブリッシング
このセクションでは、データベースから BOM コンポーネントを削除する際にカスタム属性値を保持する手順の概要を示します。この手順は、以下のタイプのリンクに適用されます。
• wt.mpm.rawmaterial.RawMaterialLink
• wt.mpm.coproduce.CoProduceMemberLink
• wt.mpm.coproduce.CoProduceUsageLink
ESI 応答で原材料、連産品メンバー、または連産品親子リンクを送信する際、削除された BOM コンポーネントエレメントで元の値とともに送信するカスタム (ソフト) 属性を特定します。
そのような属性を ESIResponseMetaInfo.xml ファイル内の esi:Map id="BOMComponent" エレメントまたは対応するカスタムエレメント内に追加します。
XML 属性 storeInSnapshotForTypes は同じエレメント内に追加されます。storeInSnapshotForTypes では、3 つのタイプのリンク wt.mpm.rawmaterial.RawMaterialLink、wt.mpm.coproduce.CoProduceMemberLink、および wt.mpm.coproduce.CoProduceUsageLink のいずれか (または複数) のみがサポートされています。
たとえば、文字列タイプの TestAttr IBA がタイプ wt.mpm.rawmaterial.RawMaterialLink に追加され、文字列タイプの SortAttr IBA がタイプ wt.mpm.coproduce.CoProduceMemberLink および wt.mpm.coproduce.CoProduceUsageLink に追加されるとします。
削除された BOM コンポーネントエレメントで TestAttr および SortAttr の元の値を送信するときに、これらを ESI 応答に含めるには、ESIResponseMetaInfo.xml ファイルの esi:Map id="BOMComponent" グループエレメントに以下のエレメントエントリを追加します。
BOMComponent マップの ID 属性を、そのコンテンツが更新される際に更新することをお勧めします。
<esi:Map id="BOMComponent">
<esi:attributeMapping sourceAttribute="TestAttr" storeInSnapshotForTypes="wt.mpm.rawmaterial.RawMaterialLink">TestAttr</esi:attributeMapping>
<esi:attributeMapping sourceAttribute="SortAttr" storeInSnapshotForTypes="wt.mpm.coproduce.CoProduceMemberLink,wt.mpm.coproduce.CoProduceUsageLink">SortAttr</esi:attributeMapping>
</esi:Map>
|
XML コンフィギュレーションの変更は、指定されているリンクにソフト属性があるパブリッシング済みの BOM 構造には適用されません。コンフィギュレーションの変更は、パブリッシングされていない BOM 構造にのみ適用されます。
|
ドキュメントの追加変更の選択的なレンダリング
プリファレンス「ドキュメントの関連付けの追加変更のみをパブリッシング」では、部品、プロセス計画、シーケンス、オペレーション、およびリソースのドキュメントの関連付けの追加変更のみをパブリッシングするかどうかを定義します。プリファレンスの設定を考慮することなく、指定したオブジェクトに対するドキュメントの関連付けの追加変更のパブリッシングを制御するには、次のようにクラス com.ptc.windchill.esi.esidoc.ESIDocumentsRenderer の拡張を作成し、メソッド isIncrementalDocAssociationsPublishEnabled をオーバーライドします。
public boolean isIncrementalDocAssociationsPublishEnabled(RevisionControlled currentObject) {
boolean flag = true;
if (!(MPMLinkFacade.isMPMLinkInstance(MPMLinkFacade.MPMLinkClass.MPMPROCESSPLAN, currentObject))) {
flag = ESIProperties.getProperty(DOCUMENT_LINK_DELTA_FLAG, true, (WTContained) currentObject);
} else {
flag = false;
}
return flag;
}
上記の例では、このプリファレンスが false に設定されていても、プロセス計画のドキュメントの関連付けの追加変更が ESI 応答にパブリッシングされています。