repco-dev.openaudiosearch.org
Open in
urlscan Pro
193.170.194.53
Public Scan
Submitted URL: http://repco-dev.openaudiosearch.org/
Effective URL: https://repco-dev.openaudiosearch.org/intro
Submission: On July 06 via api from US — Scanned from DE
Effective URL: https://repco-dev.openaudiosearch.org/intro
Submission: On July 06 via api from US — Scanned from DE
Form analysis
1 forms found in the DOMGET /search
<form method="get" action="/search" class="search-form"><input type="text" name="q" placeholder="type to search..." value=""><button type="submit">Search</button></form>
Text Content
REPCO Replication & Collector intro Search Show menu * Source code on GitHub * Getting Started * USER GUIDES * Quick Look * Command-line interface * Create a data source * SPECS * repco-v01 * ADVANCED TOPICS * Concept and Constrains * Architecture * Repositories * Data model * Domain data * BLOG * 2023-01-30 Hello repco * API * GraphQl API * ARCHIVE * Intro * notes * DEVELOPMENT * Testing WHAT IS REPCO? Repco is a digital infrastructure for a federated system where cross-European nodes of broadcasting services, disseminators of audiovisual content, and media outlets collaboratively participate on a federated platform. It is aimed at facilitating the exchange of content, metadata and audiences between these nodes. Repco deals with repositories of community media, which is defined as media (audio, video, pictures) that are produced by community-based, mostly non-commercial media creators. This includes community radio stations, recordings of events and lectures, podcasters and other media collections. The project started with a conference in Linz titled "Building a European Cultural Backbone". Repco is open to contributions of all kinds. Find us on GitHub, Discord and Matrix (soon, link coming). Repco is a project by: * arso collective * cultural broadcasting archive And kindly supported by: * European Cultural Foundation HOW DOES IT WORK? Repco is a decentralized and secure repository system for content and media metadata. It provides a simple way to store, manage, and replicate content across different platforms and devices. Repco is a system for managing and storing content using a distributed and decentralized data structure called an IPLD merkle tree. The system uses a keypair as the primary identifier for a repository, and each commit in a repository is signed to provide authenticity. The content of a repository can replicated to other nodes through a simple HTTP API. External data providers may be integrated into Repco through datasources, which are implemented as plugins. Repco is currently managed through a command line interface. The software also includes a simple web frontend for browsing the contents of a Repco node. The frontend also features functionality for users to create custom playlists. TECHNICAL OVERVIEW Each piece of content in Repco has a "revision". Each revision is hashed, and the hash is stored together with the content in a blockstore. These revisions are then grouped together into "commits". Each commit is also hashed, and the hash of the commit block is used as the head of the repo. The structure of a repo is a Merkle tree, where each commit is a node in the tree. This structure provides a simple and secure way to sync repos over untrusted connections or intermediaries. The root hash of a repo, with the contained signature and latest commit, contains the complete proof of the authenticity of the full repo. Repco uses CAR (Content Addressable Repository) streams to import and export data between repos. The CAR streams contain the blocks of a repo and allow for incremental decoding and verification. Repco also includes a DataSource feature, which allows you to fetch updates from external sources and convert the data into the Repco data model. To implement a DataSource, you need to create a DataSourcePlugin that implements the DataSourcePlugins interface. The DataSource has a definition consisting of a UID, name, and plugin ID, and provides methods to fetch updates, fetch data by UID, and check if a UID can be fetched. Repco provides a command-line interface (CLI) to control the system and manage repositories and DataSources. You can create a repo, mirror an existing repo, list repos, import and export data, and much more. The core logic of Repco is implemented in TypeScript in the repco-core module. Repco uses PostgreSQL for data storage. The Repco datamodel is written as a Prisma schema definition for PostgreSQL. FUTURE PLANS The next chapter of the project involves extending a data model with proper file storage and implementing three storage providers with different capabilities: local roots, S3, and IPFS. The data model must have the ability to store rich metadata and support version control, while providing a job queue/worker system to make it easy to extract metadata and perform data processing tasks. Additionally, the project aims to provide support for license handling, with the ability to assign licenses to files and other content items. This will be coupled with a capability model (UCAN) to determine access to content based on assigned licenses and viewer capabilities. The project also aims to implement search and discovery features, including facetted search, full-text search, keyword search, and the ability to query by concepts. The data model will support merging of concepts and proper support for distinct concept trees (taxonomies). Finally, the project will focus on providing support for derived files, including version control and automated extraction using tools such as ffmpeg. The project will have a job server logic for workers to create derivations and manage available licenses per-repository.