J’avais lancé cette série il y a longtemps avec une première introduction à la réalisation d’un itemtype dans Aras Innovator. Je poursuis avec une présentation beaucoup plus technique mais qui illustre bien la résilience de la solution Aras Innovator et sa capacité à communiquer avec le reste du monde.

La syntaxe de requête AML

AML

AML (extrait de la formation Aras Innovator – Developing Solutions© )

L’AML « Adaptive Markup Language » est le format de données échangées entre le serveur PLM Aras et les clients utilisateurs, principalement le navigateur web, mais aussi toutes les applications qui vont s’interfacer avec Aras Innovator. L’AML est du XML avec un ensemble de propriétés et d’attributs et une structure propre au modèle de données Aras.

Structure de l’AML (extrait de la formation Aras Innovator – Developing Solutions © )

Exemples

Exemple pour récupérer l’ensemble des articles

<AML>
 <Item action="get" type="part">
</AML>

Exemple pour récupérer tous les documents dont l' »item-number » commence par « Doc »

<AML>
 <Item action="get" type="document">
  <item_number condition="like">DOC-*</item_number>
 </Item>
</AML>

Exemple pour mettre à jour une quantité dans une nomenclature

<AML>
 <Item action="edit" type="part Bom" where="[part_bom].source_id='046F9545323D4CA3A6A9B9BD226DD6C2' and [part_bom].related_id='7A4E218774534F4CAF1629B15B31F73A'">
  <quantity>10</quantity>
 </Item>
</AML>

Exemple pour créer un projet

<AML>
 <Item type="Project" action="add">
  <name>TestAdding Project</name>
  <scheduling_type>Forward</scheduling_type>
  <project_update_mode>1</project_update_mode>
  <date_start_target>10/7/2009</date_start_target>
  <date_due_target>10/8/2009</date_due_target>
 </Item>
</AML>

Exemple pour créer un article avec un document existant attaché

<AML>
 <Item action="add" type="Part">
  <name>Xcd Board 47</name>
  <item_number>PRT-BRD-47</item_number>
  <Relationships>
   <Item action="add" type="Part Document">
    <related_id>
     <Item action="get" type="Document">
      <item_number>DOC-000001</item_number>
     </Item>
    </related_id>
   </Item>
  </Relationships>
 </Item>
</AML>

Exemple pour exécuter la promotion d’un item

<AML>
 <Item type="{Item Type}" action="promoteItem" id="{ID of Item}">
  <state>{Name of the new state}</state>
  <comments>{Additional comments to store in history.  Optional.}</comments>
 </Item>
</AML>

Utilisation d’opérateurs logiques

<AML>
 <Item action="get" type="part">
  <or>
   <and>
    <cost>350</cost>
    <classification>Product</classification>
   </and>
   <and>
    <cost>100</cost>
    <classification>Assembly</classification>
   </and>
  </or>
 </Item>
</AML>

Respect des permissions

Toutes ces requêtes se réalisent dans un contexte authentifié et donc identifié. Chaque requête va être exécutée par une identité dans Aras Innovator et sera soumise aux vérifications de droits et permissions de l’utilisateurs.

Les outils

A l’origine Aras fournit dans l’application une page sur laquelle il est possible de saisir de l’AML et de récupérer la réponse du serveur. C’est le NASH.

Autour de 2008 si je me souviens bien, un client Aras était venu en formation de développeur et avait pris l’initiative de développer un client windows qui permette de rédiger ces requêtes avec l’aide de l’auto-completion. A l’époque AML studio a donc été réalisé et est encore utilisé aujourd’hui dans les formations Aras.

Voici une vidéo qui présentait l’application AML studio :

Depuis quelques temps le projet AML studio a été remplacé par un outil plus riche, Innovator Admin:

Un contrôle de toute l’application

L’AML permet de manipuler toute l’application. Dans les exemples précédents je ne montrais que la partie manipulation de données, mais l’exemple suivant vous permet de manipuler le modèle de données.

Ajout d’une propriété sur l’itemtype Part

<AML>
  <Item action="edit" type="ItemType" where="[itemtype].name='Part'">
    <Relationships>
      <Item action="add" type="Property">
        <name>description_tech</name>
        <label>Description Technique</label>
        <data_type>text</data_type>
      </Item>
    </Relationships>
  </Item>
</AML>

C’est ce type d’AML qui permet de gérer tous le packaging, et autres opérations d’upgrade à travers un format d’échange « standardisé ».

La formation Aras permet de voir le détail des attributs disponibles et de parcourir différents exemples pour devenir autonome sur ce type de manipulation d’Aras Innovator.

Posted by Yoann Maingon

Consultant PLM avec des expériences autant côté métier que dans l'implémentation technique de solutions PLM et d'intégrations de systèmes, je partage avec vous mes expériences, mes recherches et mes développements à travers ce blog.