Skip to content

Latest commit

 

History

History
55 lines (35 loc) · 1.87 KB

README.md

File metadata and controls

55 lines (35 loc) · 1.87 KB

manifests

This project contains dependency manifests. Manifests contain the rules for retrieving latest information about dependency.

What can be a dependency?

Dependency, as its name says, is something that a project depends on. Examples are:

  • Library
  • Framework
  • Application
  • Binary component

Uniqueness

Dependency name along with the its homepage URL must define it in a unique manner. There may be aliases used in different frameworks/toolkits as well. For instance, the name apache-kafka and the URL "https://kafka.apache.org/" can be used for defining Apache Kafka, and one of its aliases would be org.apache.kafka:kafka_2.10 (Maven alias).

Contribution

Dependency manifests are stored in the directory tree under the directory called manifests, where each level is defined by the first four letters of the dependency name. For example, for the given name "cassandra" the directory tree would be:

├── manifests
│   └── c
│       └── a
│           └── s
│               └── s
│                   ├── cassandra.json

Templates are stored in the same way under the templates directory.

To add a new manifest, find the relevant directory in the tree (create one if it doesn't exist), then add a new file named <dependency name>.json, which conforms to the dependency JSON schema file.

Variables

Here are variables that can be used in a manifest file:

Variable Description
${NAME} This variable is set to the dependency name

Manifest Generator

To make generating of manifest file easier, use script ./generate.py. This script asks user for needed values based on schema file, then generates a JSON file containing the answers user provided.