From f64955c69d91e578e580b409ba31ac4b3477da96 Mon Sep 17 00:00:00 2001 From: vnugent Date: Wed, 12 Jul 2023 01:28:23 -0400 Subject: Initial commit --- back-end/src/IChannelContextManager.cs | 68 ++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 back-end/src/IChannelContextManager.cs (limited to 'back-end/src/IChannelContextManager.cs') diff --git a/back-end/src/IChannelContextManager.cs b/back-end/src/IChannelContextManager.cs new file mode 100644 index 0000000..55a7cd8 --- /dev/null +++ b/back-end/src/IChannelContextManager.cs @@ -0,0 +1,68 @@ +/* +* Copyright (c) 2023 Vaughn Nugent +* +* Library: CMNext +* Package: Content.Publishing.Blog.Admin +* File: IChannelContextManager.cs +* +* CMNext 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. +* +* CMNext 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/. +*/ + +using System.Threading; +using System.Threading.Tasks; + +using Content.Publishing.Blog.Admin.Model; + +namespace Content.Publishing.Blog.Admin +{ + internal interface IChannelContextManager + { + /// + /// Gets a channel context by id. + /// + /// The id of the context to get + /// + Task GetChannelAsync(string id, CancellationToken cancellation); + + /// + /// Gets the entire channel collection. + /// + /// Opaque objects that represent channel context objects + Task GetAllContextsAsync(CancellationToken cancellation); + + /// + /// Creates a new channel context. + /// + /// The new blog channel to create + /// A token to cancel the operation + /// The result of the operation + Task CreateChannelAsync(BlogChannel context, CancellationToken cancellation); + + /// + /// Updates an existing channel context. + /// + /// The channel context to update + /// A token to cancel the operation + /// The result of the operation + Task UpdateChannelAsync(BlogChannel context, CancellationToken cancellation); + + /// + /// Delets a channel context from the store. + /// + /// The context to delete + /// A token to cancel the operation + /// A task that completes when the channel was deleted + Task DeleteChannelAsync(IChannelContext context, CancellationToken cancellation); + } +} -- cgit