/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: MIT-0
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of this
* software and associated documentation files (the "Software"), to deal in the Software
* without restriction, including without limitation the rights to use, copy, modify,
* merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using InventoryService.Models;
namespace InventoryService.Interface
{
public interface IUnicornRepository
{
///
/// Fetches a list of current unicorns.
///
/// List of unicorn objects.
List GetUnicorns();
///
/// Fetches unicorn based on unicorn identifier.
///
/// Unicorn Id.
/// Fetched unicorn
Task GetUnicornAsync(Guid id);
///
/// Updates unicorn based on changes.
///
/// Unicorn entity to update.
/// Save status.
Task UpdateUnicornAsync(Unicorn unicorn);
///
/// Creates a new unicorn entity in the context.
///
/// Unicorn entity to create.
/// Save status.
Task CreateUnicornAsync(Unicorn unicorn);
///
/// Removes unicorn from context.
///
/// Unicorn entity to delete.
/// Save status.
Task DeleteUnicornAsync(Unicorn unicorn);
///
/// Checks if a particular Unicorn exists.
///
/// Unicorn Id to search.
///
bool UnicornExists(Guid id);
}
}