Skip to content

Latest commit

 

History

History
59 lines (47 loc) · 1.89 KB

README.md

File metadata and controls

59 lines (47 loc) · 1.89 KB

AMF-Metadata

This repository holds:

  • AMF Canonical Web Api Spec dialect
  • AMF Vocabularies
  • Canonical Web Api Spec Transform
  • Dialect and Vocabulary exporters

Artifacts

AMF Vocabulary

This resource only artifact holds the canonical web api spec dialect and AMF's vocabularies.

Artifact group: com.github.amlorg
Artifact name: amf-vocabulary
Depends on: None. This jar doesn't have dependencies with any other project.

How to read a dialect or vocabulary from the jar?
public class Main {

    public static void main(String[] args) {
        InputStream stream = Main.class.getClassLoader().getResourceAsStream("dialects/canonical_webapi_spec.yaml");
        String content = new BufferedReader(new InputStreamReader(stream)).lines().collect(Collectors.joining());
        System.out.println(content);
    }
}
How can i get all the files? scala example
def getResourcesFromJAR(): List[String] = {
      val buffer = ListBuffer[String]()
      val dirURL = Main.getClass.getClassLoader.getResource("dialects")
      val jarPath = dirURL.getPath().substring(5, dirURL.getPath().indexOf("!"));
      val jar = new JarFile(URLDecoder.decode(jarPath, "UTF-8"));
      val entries = jar.entries()
      while (entries.hasMoreElements) {
        val name = entries.nextElement().getName;
        if (name.startsWith("dialects") || name.startsWith("vocabularies")) {
          val checkSubdir = name.indexOf("/");
          if (checkSubdir >= 0) // no root files other than dirs
            buffer.append(name)
        }
      }
      buffer.toList
      // Then use getResourceAsStream as shown in the previous example
  }

AMF Transform

This artifact contains AMF model transformations. Currently the only one it has is the Canonical WebApi Spec transform.

Artifact group: com.github.amlorg
Artifact name: amf-transform
Depends on: https://github.com/aml-org/amf