use 5.006; use strict; use warnings; package Metabase; # ABSTRACT: A database framework and API for resource metadata our $VERSION = '1.001'; # VERSION 1; =pod =head1 NAME Metabase - A database framework and API for resource metadata =head1 VERSION version 1.001 =head1 DESCRIPTION Metabase is a database framework and API for resource metadata. The framework describes how arbitrary data ("facts") are associated with particular resources or related to each other. The API describes how to store, retrieve, and search this information. =head2 History and Motivation Metabase was originally designed as a means of storing reports from the CPAN Testers project. When Metabase was initially developed, CPAN Testers reports were sent by individual testers to a single email server, which then forwarded them to a USENET group, which was considered the authoritative store. This presented problems: some testers couldn't send email, the system wasn't very searchable, was hard to mirror, and the data inside the system was entirely unstructured. Metabase aimed to avoid all of those problems by being transport-neutral, searchable and easier to mirror by design, and geared toward storing structured data. Simplicity is another design goal: while it has several moving parts, they're all simple and designed to be replaceable and extensible, rather than to be a perfect design up front. =head1 OVERVIEW A Metabase has several parts: =over =item * L, a class which manages access to the Archive and Index =item * L, a role for managing submission of facts to the Librarian =item * L, a role for storing and retrieving facts =item * L, a role for indexing and searching facts =item * L, a role for translating a common query data structure into a backend-specific query =back Roles require implementations. These could use flat files, relational databases, object databases, cloud services, or anything else that can satisfy the role API. Metabase comes with some simple, stupid backends for testing: =over 4 =item * L =item * L =back Facts stored with in a Metabase are defined as subclasses of L. L is a subclass that relates multiple facts. L provides the web API for storing, searching and retrieving facts. L is the client library to submit facts to a Metabase::Web server. A future Metabase::Client class will provide submit and search capabilities. =head1 SEE ALSO =over 4 =item * L =item * L =item * L =back =for :stopwords cpan testmatrix url annocpan anno bugtracker rt cpants kwalitee diff irc mailto metadata placeholders metacpan =head1 SUPPORT =head2 Bugs / Feature Requests Please report any bugs or feature requests through the issue tracker at L. You will be notified automatically of any progress on your issue. =head2 Source Code This is open source software. The code repository is available for public review and contribution under the terms of the license. L git clone https://github.com/dagolden/metabase.git =head1 AUTHORS =over 4 =item * David Golden =item * Ricardo Signes =item * Leon Brocard =back =head1 COPYRIGHT AND LICENSE This software is Copyright (c) 2012 by David Golden. This is free software, licensed under: The Apache License, Version 2.0, January 2004 =cut __END__