feat: define interfaces to enable file-based federation mechanisms

DESCRIPTION
    <BASE_DIR>/forge.example.com/:
	This directory contains all data related to a particular forge instance running
	at forge.example.com

    <BASE_DIR>/forge.example.com/forgeinfo:
	This file contains metadata pertaining to a forge.

	The file format and file name is left to the discretion of the
	implementer.

    <BASE_DIR>/forge.example.com/john/:
	This directory contains all data related to a user named "john"
	on forge instance at forge.example.com.

    <BASE_DIR>/forge.example.com/john/userinfo:
	This file contains all metadata related to a user named "john"
	on forge instance at forge.example.com.

	The file format and file name is left to the discretion of the
	implementer.

    <BASE_DIR>/forge.example.com/john/repo-foo/:
	This directory contains all data related to a repository named
	"repo-foo" owned by user "john" on forge instance at
	forge.example.com.

    <BASE_DIR>/forge.example.com/john/repo-foo/repo-info:
	This file contains all metadata related to a repository named
	"repo-foo" owned by user "john" on forge instance at
	forge.example.com.

	The file format and file name is left to the discretion of the
	implementer.
This commit is contained in:
Aravinth Manivannan 2022-05-17 19:42:23 +05:30
parent 65176bbdea
commit 95ca4fb1d3
Signed by: realaravinth
GPG key ID: AD9F0F08E855ED88
4 changed files with 158 additions and 0 deletions

View file

@ -0,0 +1,24 @@
[package]
name = "federate-core"
version = "0.1.0"
authors = ["realaravinth <realaravinth@batsense.net>"]
description = "ForgeFlux StarChart - Federated forge spider"
documentation = "https://forgeflux.org/"
edition = "2021"
license = "AGPLv3 or later version"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
async-trait = "0.1.51"
thiserror = "1.0.30"
serde = { version = "1", features = ["derive"]}
url = { version = "2.2.2", features = ["serde"] }
[dependencies.db-core]
path = "../../db/db-core"
[features]
default = []
test = []

View file

@ -0,0 +1,17 @@
/*
* ForgeFlux StarChart - A federated software forge spider
* Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/

View file

@ -0,0 +1,68 @@
/*
* ForgeFlux StarChart - A federated software forge spider
* Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
use std::path::Path;
use std::result::Result;
use async_trait::async_trait;
use serde::Serialize;
use db_core::prelude::*;
#[cfg(feature = "test")]
pub mod tests;
#[async_trait]
pub trait Federate: Sync + Send + Clone {
type Error: std::error::Error + std::fmt::Debug;
/// utility method to create dir if not exists
async fn create_dir_if_not_exists(&self, path: &Path) -> Result<(), Self::Error>;
/// utility method to write data
async fn write_util<S: Serialize + Send + Sync>(
&self,
data: &S,
path: &Path,
) -> Result<(), Self::Error>;
/// utility method to remove file/dir
async fn rm_util(&self, path: &Path) -> Result<(), Self::Error>;
/// create forge isntance
async fn create_forge_isntance(&self, f: &CreateForge<'_>) -> Result<(), Self::Error>;
/// delete forge isntance
async fn delete_forge_instance(&self, hostname: &str) -> Result<(), Self::Error>;
/// create user isntance
async fn create_user(&self, f: &AddUser<'_>) -> Result<(), Self::Error>;
/// add repository isntance
async fn create_repository(&self, f: &AddRepository<'_>) -> Result<(), Self::Error>;
/// delete user
async fn delete_user(&self, username: &str, hostname: &str) -> Result<(), Self::Error>;
/// delete repository
async fn delete_repository(
&self,
owner: &str,
name: &str,
hostname: &str,
) -> Result<(), Self::Error>;
}

View file

@ -0,0 +1,49 @@
/*
* ForgeFlux StarChart - A federated software forge spider
* Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
//! Test utilities
use crate::*;
/// adding forge works
pub async fn adding_forge_works<'a, T: Federate>(
ff: &T,
create_forge_msg: CreateForge<'a>,
create_user_msg: AddUser<'a>,
add_repo_msg: AddRepository<'a>,
) {
let _ = ff.delete_forge_instance(create_forge_msg.hostname).await;
ff.create_forge_isntance(&create_forge_msg).await.unwrap();
// add user
ff.create_user(&create_user_msg).await.unwrap();
// add repository
ff.create_repository(&add_repo_msg).await.unwrap();
// delete repository
ff.delete_repository(add_repo_msg.owner, add_repo_msg.name, add_repo_msg.hostname)
.await
.unwrap();
// delete user
ff.delete_user(create_user_msg.username, create_user_msg.hostname)
.await
.unwrap();
// delete user
ff.delete_forge_instance(create_forge_msg.hostname)
.await
.unwrap();
}