// Copyright 2012 Citrix Systems, Inc. Licensed under the // Apache License, Version 2.0 (the "License"); you may not use this // file except in compliance with the License. Citrix Systems, Inc. // reserves all rights not expressly granted by the License. // You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // Automatically generated by addcopyright.py at 04/03/2012 package com.cloud.user; import java.util.List; import com.cloud.configuration.Resource.ResourceType; import com.cloud.configuration.ResourceCount; import com.cloud.configuration.ResourceLimit; import com.cloud.domain.Domain; import com.cloud.exception.ResourceAllocationException; public interface ResourceLimitService { /** * Updates an existing resource limit with the specified details. If a limit doesn't exist, will create one. * * @param accountId * TODO * @param domainId * TODO * @param resourceType * TODO * @param max * TODO * * @return the updated/created resource limit */ ResourceLimit updateResourceLimit(Long accountId, Long domainId, Integer resourceType, Long max); /** * Updates an existing resource count details for the account/domain * * @param accountId * TODO * @param domainId * TODO * @param typeId * TODO * @return the updated/created resource counts */ List<? extends ResourceCount> recalculateResourceCount(Long accountId, Long domainId, Integer typeId); /** * Search for resource limits for the given id and/or account and/or type and/or domain. * * @param id * TODO * @param accountId * TODO * @param domainId * TODO * @param type * TODO * @return a list of limits that match the criteria */ public List<? extends ResourceLimit> searchForLimits(Long id, Long accountId, Long domainId, Integer type, Long startIndex, Long pageSizeVal); /** * Finds the resource limit for a specified account and type. If the account has an infinite limit, will check * the account's parent domain, and if that limit is also infinite, will return the ROOT domain's limit. * * @param account * @param type * @return resource limit */ public long findCorrectResourceLimitForAccount(Account account, ResourceType type); /** * Finds the resource limit for a specified domain and type. If the domain has an infinite limit, will check * up the domain hierarchy * * @param account * @param type * @return resource limit */ public long findCorrectResourceLimitForDomain(Domain domain, ResourceType type); /** * Increments the resource count * * @param accountId * @param type * @param delta */ public void incrementResourceCount(long accountId, ResourceType type, Long... delta); /** * Decrements the resource count * * @param accountId * @param type * @param delta */ public void decrementResourceCount(long accountId, ResourceType type, Long... delta); /** * Checks if a limit has been exceeded for an account * * @param account * @param type * @param count * the number of resources being allocated, count will be added to current allocation and compared * against maximum allowed allocation * @throws ResourceAllocationException */ public void checkResourceLimit(Account account, ResourceCount.ResourceType type, long... count) throws ResourceAllocationException; /** * Gets the count of resources for a resource type and account * * @param account * @param type * @return count of resources */ public long getResourceCount(Account account, ResourceType type); }