Skip to content

Latest commit

 

History

History
143 lines (119 loc) · 4.16 KB

README.md

File metadata and controls

143 lines (119 loc) · 4.16 KB

Structure Go Report Card

Official structures and specs of the storage format. Reference implementation in Go (golang).

Concepts

Structure supports a photo-centric storage system. Its primary goal is to consume content from many places (called sources), and store them in any number of places (called destinations). It keeps track of the sources, destinations, and each piece of content in the Index. Along the way, it extracts metadata from the content and stores it in Meta.

Terminology

  • Source (short: Src) - A places that's searched for content.
  • Destination (short: Dst) - A place where content is stored.
  • URI - The way that all content is referenced. Can specifically be any URL or URN.
  • Hash - The way all content is identified, a unique fingerprint of the content.
  • Index - A database of sources, destinations: where content was found, and where it was stored.
  • Meta - Information extracted from a piece of content at source.

Example

As an example, we'll use a filesystem-based approach. However, the specifics of data location, file naming, and storage format are all flexible. That said, for simplicity let's say we have a source directory at /tmp/src like so:

/tmp/src/
  fictional/
    image.jpg
    image.xmp

And we want to store that content at /tmp/dst. The default filesystem format looks like this:

/tmp/dst/
  index.json
  media/
    2018/2018-11-10/
      f42a59131aaf2e5c475f8a35126b034549c05bd5.jpg
  meta/
    f4/2a/
      59131aaf2e5c475f8a35126b034549c05bd5.json

The image has been stored at media/<date>/<hash>.<format> and its associated metadata at meta/<hash>.json.

Index

The index is a catalog of content that's been stored. Where it was found (the source), and where it was put (the destination). An index can store any number of sources and any number of destinations. You can use the index to find content and retrieve it from the destination, or even put it back where it was originally found on the source.

The file /tmp/dst/index.json contains:

{
  "version": "v1",
  "srcs": [
    {
      "src_id": "e8400c72-f7d0-53f9-98ca-ee23238231fe",
      "src_uri": "file:///tmp/src/"
    }
  ],
  "dsts": [
    {
      "dst_id": "0e73b6c5-26dc-58a6-8fa9-edd5be9ad99d",
      "index_uri": "file:///tmp/dst/",
      "data_uri": "file:///tmp/dst/",
      "meta_uri": "file:///tmp/dst/"
    }
  ],
  "refs": [
    {
      "hash": "f6cf14423780c715b3812bed6295babef572ed56",
      "srcs": [
        {
          "src_id": "e8400c72-f7d0-53f9-98ca-ee23238231fe",
          "data_uri": "file:///tmp/src/fictional/image.jpg",
          "meta_uri": "file:///tmp/src/fictional/image.xmp",
          "modified_at": "2018-11-12T00:00:00Z"
        }
      ],
      "dsts": [
        {
          "dst_id": "0e73b6c5-26dc-58a6-8fa9-edd5be9ad99d",
          "data_uri": "media/2018/2018-11-10/f6cf14423780c715b3812bed6295babef572ed56.jpg",
          "meta_uri": "meta/f6/cf/14423780c715b3812bed6295babef572ed56.json",
          "data_size": 2000,
          "meta_size": 84,
          "stored_at": "2018-11-13T00:00:00Z",
          "updated_at": "2018-11-14T00:00:00Z"
        }
      ]
    }
  ]
}

See how this document was generated.

Meta

Meta is a document describing the content. Each piece of content may have none, some, or all possible information available (see the full definition. You can use the meta document to find out information about a piece of content.

The file /tmp/dst/meta/f4/2a/59131aaf2e5c475f8a35126b034549c05bd5.json contains:

{
  "version": "v1",
  "type": "jpg",
  "size": 1024,
  "inherent": {
    "created": "2018-01-01T00:00:00Z",
    "image": {
      "width": 3000,
      "height": 5000
    },
    "exif": {
      "ExposureTime": {
        "id": "ShutterSpeed",
        "val": "1/60"
      }
    }
  },
  "sidecar": {
    "exif": {
      "FNumber": {
        "id": "0x829d",
        "val": 1.8
      }
    }
  }
}

See how this document was generated.


Copyright (c) 2018 Ryan Carver / www.recentralized.org

License: MIT