Skip to main content

OSS Directory

info

The OSS Directory serves as the "source of truth" for the projects and collections that are discoverable on Open Source Observer. While the directory may never be complete, it is actively maintained. We welcome community contributions of new projects and collections, as well as updates to existing entries. This directory is a public good, free to use and distribute.

Directory Structure

The OSS Directory is organized into two main folders:

  • ./data/projects - each file represents a single open source project and contains all of the artifacts for that project.
    • See ./src/resources/schema/project.json for the expected JSON schema
    • Files should be named by the project name
    • A project's name must be globally unique. If there is a conflict in chosen name, we will give priority to the project that has the associated GitHub organization
    • In most cases, we adopt the GitHub organization name as the name. If the project is not associated with a GitHub organization, you try to use the project name followed by the repo owner as the name.
  • ./data/collections - each file represents a collection of projects that have some collective meaning (e.g. all projects in an ecosystem).
    • See ./src/resources/schema/collection.json for the expected JSON schema
    • Collections are identified by their unique name

Collections


Collections are used to group projects together. For example, a collection may include all projects that are part of a particular ecosystem or all projects that are dependent on a given developer library.

name: my-collection
display_name: My Collection
projects:
- project-name1
- project-name2
- project-name3

A collection is validated by confirming that all of its projects are valid. Please consult the collection schema for more information.

Projects


Projects are used to group artifacts together. For example, a project may include a GitHub organization, an NPM package, and a blockchain address used for holding funds.

name: opensource-observer
display_name: Open Source Observer
github:
- url: https://github.com/opensource-observer
npm:
- url: https://www.npmjs.com/package/oss-directory
blockchain:
- address: "0x87feed6162cb7dfe6b62f64366742349bf4d1b05"
networks:
- mainnet
- optimism
tags:
- eoa
- wallet

In order to instantiate a project, we require a unique name and a GitHub URL that is not owned by any other project. Project metadata, including its display_name and description, can also be captured. Once instantiated, a project entry can be updated to include additional artifacts.

Critically, artifacts can only belong to one project. We run validation checks to ensure that artifacts are not duplicated across projects. Please consult the project schema for more information.

Artifacts


Artifacts are used to store information about work artifacts created by open source projects in the OSS Directory.

For example, here is the GitHub organization artifact (identified by a url field) that belongs to Open Source Observer's project file.

github:
- url: https://github.com/opensource-observer

Here is the NPM package artifact (identified by a url field) that belongs to Open Source Observer's project file.

npm:
- url: https://www.npmjs.com/package/oss-directory

Blockchain address artifacts include additional tags that are used as instructions for OSO's indexers. For example, a blockchain address with a wallet tag will be monitored for financial transactions and changes in token balances. A blockchain address with a deployer tag will be monitored for smart contract deployments. Any contracts deployed by a deployer will be associated with the deployer's project. Similarly, any contracts deployed by factories deployed by a deployer will also be associated with the deployer's project.

Tags are also used to indicate the network the address is used on. For example, a deployer may be active on both the Ethereum mainnet and the Optimism network.

Here is a blockchain address artifact that belongs to Open Source Observer's project file.

blockchain:
- address: "0x87feed6162cb7dfe6b62f64366742349bf4d1b05"
networks:
- mainnet
- optimism
tags:
- eoa
- wallet

To learn more, check out the artifact schema.

Example


Here's an example of how these building blocks can be used to model a collection of projects:

- Collection: IPFS                            # projects in the IPFS ecosystem
- Project: IPFS # IPFS GitHub organization
- Artifact: https://github.com/ipfs/ipfs # IPFS monorepo
- Artifact: https://github.com/ipfs/kubo # Kubo
- Artifact: https://github.com/ipfs/boxo # Boxo
- Artifact: https://github.com/ipfs/helia # helia
- Project: IPLD # IPLD GitHub organization
- Artifact: https://github.com/ipld/ipld # IPLD monorepo
- Artifact: https://github.com/ipld/go-ipld-prime # go-ipld-prime

Once these entries are submitted to the OSS Directory, OSO will add them to the next data indexing job. After indexing is complete, metrics about these artifacts, projects, and collections will be available in BigQuery and through the OSO API.