use serde::{Deserialize, Serialize}; use crate::model::repository::RepositoryVisibility; use crate::model::{ repository::{Commit, Repository, RepositoryTreeEntry}, user::User, }; /// A request to create a repository. /// /// # Authentication /// - Instance Authentication /// - Used to validate User token `issued_for` /// - User Authentication /// - Used to source owning user /// - Used to authorize user token against user's instance /// # Authorization /// - Instance Authorization /// - Used to authorize action using User token requiring a correct `issued_for` and valid issuance from user's instance /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryCreateRequest { pub name: String, pub description: Option, pub visibility: RepositoryVisibility, pub default_branch: String, pub owner: User, } #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryCreateResponse; /// A request to inspect the tree of a repository. /// /// # Authentication /// - Instance Authentication /// - Validate request against the `issued_for` public key /// - Validate User token against the user's instance's public key /// # Authorization /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryFileInspectRequest { pub path: RepositoryTreeEntry, } #[derive(Clone, Serialize, Deserialize)] pub enum RepositoryFileInspectionResponse { File { commit_metadata: Commit, }, Folder { commit_metadata: Commit, members: Vec, }, Invalid { path: RepositoryTreeEntry, }, } /// A request to get a repository's information. /// /// # Authentication /// - Instance Authentication /// - Validate request against the `issued_for` public key /// - Validate User token against the user's instance's public key /// # Authorization /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssuesCountRequest; #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssuesCountResponse { pub count: u64, } /// A request to get a repository's issues count. /// /// # Authentication /// - Instance Authentication /// - Validate request against the `issued_for` public key /// - Validate User token against the user's instance's public key /// # Authorization /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssueLabelsRequest; #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssueLabelsResponse { pub labels: Vec, } #[derive(Clone, Serialize, Deserialize)] pub struct IssueLabel { pub name: String, pub color: String, } /// A request to get a repository's issue labels. /// /// # Authentication /// - Instance Authentication /// - Validate request against the `issued_for` public key /// - Validate User token against the user's instance's public key /// # Authorization /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssuesRequest; #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssuesResponse { pub issues: Vec, } /// A request to get a repository's issues. /// /// # Authentication /// - Instance Authentication /// - Validate request against the `issued_for` public key /// - Validate User token against the user's instance's public key /// # Authorization /// - User Authorization /// - Potential User permissions checks #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryIssue { pub author: User, pub id: u64, pub title: String, pub contents: String, pub labels: Vec, } #[derive(Clone, Serialize, Deserialize)] pub struct RepositoryInfoRequest { pub repository: Repository, /// Whether to fetch extra metadata like the last commit made to file or size pub extra_metadata: bool, /// Rev (branch) being requested pub rev: Option, /// Tree path being requested pub path: Option, }