/*******************************************************************************
* See the NOTICE file distributed with this work for additional information
* regarding copyright ownership.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with 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.
******************************************************************************/
package hr.fer.zemris.vhdllab.dao;
import hr.fer.zemris.vhdllab.entity.Project;
import java.util.List;
import org.springframework.transaction.annotation.Transactional;
/**
* This interface extends {@link EntityDao} to define extra methods for
* {@link Project} entity.
* <p>
* An implementation of this interface must be stateless!
* </p>
*/
@Transactional
public interface ProjectDao extends EntityDao<Project> {
/**
* Finds a project whose <code>userId</code> and <code>name</code> are
* specified by parameters. <code>null</code> value will be returned if such
* project doesn't exist.
*
* @param userId
* owner of project
* @param name
* a name of a project
* @throws NullPointerException
* if any parameter is <code>null</code>
* @return specified project or <code>null</code> if such project doesn't
* exist
*/
Project findByName(String userId, String name);
/**
* Finds all projects whose owner is specified user. Return value will never
* be <code>null</code>, although it can be an empty list.
*
* @param userId
* owner of projects
* @return list of user's projects
*/
List<Project> findByUser(String userId);
}