All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceImpl Maven / Gradle / Ivy

package net.anotheria.anosite.photoserver.service.blur.persistence;

import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.FIELD_NAME_ALBUM_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.FIELD_NAME_BLUR;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.FIELD_NAME_PHOTO_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.FIELD_NAME_USER_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_CREATE;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_DELETE_BY_ALBUM_AND_PHOTO_AND_USER_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_DELETE_BY_ALBUM_AND_USER_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_DELETE_BY_ALBUM_ID;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_META_ADD_RIGHTS;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_META_CREATE_TABLE;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_READ_ALBUM_BLURRED_FOR_USER;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_READ_PICTURE_BLURRED_FOR_USER;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_READ_SETTING;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.SQL_READ_SETTINGS_WITH_ORDER;
import static net.anotheria.anosite.photoserver.service.blur.persistence.BlurSettingsPersistenceServiceConstants.TABLE_NAME;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import net.anotheria.anosite.photoserver.service.blur.BlurSettingBO;
import net.anotheria.db.service.GenericPersistenceService;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * BlurSettingsPersistenceService implementation.
 *
 * @author h3ll
 */
public class BlurSettingsPersistenceServiceImpl extends GenericPersistenceService implements BlurSettingsPersistenceService {

	/**
	 * {@link Logger} instance.
	 */
	private static final Logger LOGGER = LoggerFactory.getLogger(BlurSettingsPersistenceServiceImpl.class);
	/**
	 * DDL queries list.
	 */
	private final List ddlQueries = new ArrayList();
	/**
	 * Default - All album pictures ID.
	 */
	protected static final long FOR_ALL_PICTURES_IN_ALBUM = BlurSettingBO.ALL_ALBUM_PICTURES_DEFAULT_CONSTANT;
	/**
	 * Default all users ID.
	 */
	protected static final String FOR_ALL_USERS = BlurSettingBO.ALL_USERS_DEFAULT_CONSTANT;

	/**
	 * Constructor.
	 */
	protected BlurSettingsPersistenceServiceImpl() {
		ddlQueries.add(SQL_META_CREATE_TABLE);
		ddlQueries.add(SQL_META_ADD_RIGHTS);

		initialize();

	}

	@Override
	public BlurSettingBO readBlurSetting(long albumId, long pictureId, String userId) throws BlurSettingsPersistenceServiceException {
		Connection conn = null;
		PreparedStatement st = null;
		ResultSet rs = null;
		try {
			conn = getConnection();
			st = conn.prepareStatement(SQL_READ_SETTINGS_WITH_ORDER);
			st.setLong(1, albumId);
			st.setLong(2, pictureId);
			st.setLong(3, FOR_ALL_PICTURES_IN_ALBUM);// default picture (for all)
			st.setString(4, userId);
			st.setString(5, FOR_ALL_USERS); ;//default user (for all)

			rs = st.executeQuery();
			BlurSettingBO result = null;

			if (rs.next()) {
				result = new BlurSettingBO();
				result.setAlbumId(rs.getLong(FIELD_NAME_ALBUM_ID));
				result.setPictureId(rs.getLong(FIELD_NAME_PHOTO_ID));
				result.setUserId(rs.getString(FIELD_NAME_USER_ID));
				result.setBlurred(rs.getBoolean(FIELD_NAME_BLUR));
				//just  for debug
				LOGGER.debug(result.toString());
			}
			//debug section.
			while (rs.next()) {
				BlurSettingBO debug = new BlurSettingBO();
				debug.setAlbumId(rs.getLong(FIELD_NAME_ALBUM_ID));
				debug.setPictureId(rs.getLong(FIELD_NAME_PHOTO_ID));
				debug.setUserId(rs.getString(FIELD_NAME_USER_ID));
				debug.setBlurred(rs.getBoolean(FIELD_NAME_BLUR));
				//just  for debug
				LOGGER.debug(result.toString());
			}
			return result;

		} catch (SQLException e) {
			LOGGER.error("readBlurSetting(" + albumId + "," + pictureId + "," + userId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);

		} finally {
			close(rs);
			close(st);
			close(conn);
		}
	}

	@Override
	public void blurAlbum(long albumId) throws BlurSettingsPersistenceServiceException {
		//check
		BlurSettingBO settings = readAlbumSetting(albumId);
		if (settings != null && settings.isBlurred())
			throw new AlbumIsBlurredPersistenceException(albumId);


		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCr = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_ID);
			stDel.setLong(1, albumId);
			stDel.executeUpdate();

			//creating new record!
			stCr = conn.prepareStatement(SQL_CREATE);
			stCr.setLong(1, albumId);
			stCr.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
			stCr.setString(3, FOR_ALL_USERS);
			stCr.setBoolean(4, true);

			stCr.executeUpdate();

		} catch (SQLException e) {
			LOGGER.error("isAlbumBlurred(" + albumId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCr);
			close(conn);
		}
	}


	@Override
	public void blurAlbum(long albumId, String userId) throws BlurSettingsPersistenceServiceException {
		//check
		BlurSettingBO settings = readAlbumSetting(albumId, userId);
		if (settings != null && settings.isBlurred())
			throw new AlbumIsBlurredPersistenceException(albumId, userId);

		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCr = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setString(2, userId);
			stDel.executeUpdate();

			//creating new record!
			stCr = conn.prepareStatement(SQL_CREATE);
			stCr.setLong(1, albumId);
			stCr.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
			stCr.setString(3, userId);
			stCr.setBoolean(4, true);

			stCr.executeUpdate();

		} catch (SQLException e) {
			LOGGER.error("blurAlbum(" + albumId + ", " + userId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCr);
			close(conn);
		}
	}


	@Override
	public void unBlurAlbum(long albumId) throws BlurSettingsPersistenceServiceException {
		//check
		BlurSettingBO setting = readAlbumSetting(albumId);
		if (setting == null || !setting.isBlurred())
			throw new AlbumIsNotBlurredPersistenceException(albumId);

		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_ID);
			stDel.setLong(1, albumId);
			stDel.executeUpdate();

			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
			stCR.setString(3, FOR_ALL_USERS);
			stCR.setBoolean(4, false);

			stCR.executeUpdate();


		} catch (SQLException e) {
			LOGGER.error("unBlurAlbum(" + albumId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}
	}

	@Override
	public void unBlurAlbum(long albumId, String userId) throws BlurSettingsPersistenceServiceException {

		//checking that is blurred!
		BlurSettingBO setting = readAlbumSetting(albumId, userId);
		if (setting == null || !setting.isBlurred())
			throw new AlbumIsNotBlurredPersistenceException(albumId);


		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setString(2, userId);
			stDel.executeUpdate();


			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
			stCR.setString(3, userId);
			stCR.setBoolean(4, false);

			stCR.executeUpdate();

		} catch (SQLException e) {
			LOGGER.error("unBlurAlbum(" + albumId + ", " + userId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}
	}


	@Override
	public void blurPicture(long albumId, long pictureId, String userId) throws BlurSettingsPersistenceServiceException {

		//check
		BlurSettingBO setting = readBlurSetting(albumId, pictureId, userId);
		if (setting != null && setting.isBlurred())
			throw new PictureIsBlurredPersistenceException(albumId, pictureId, userId);

		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_PHOTO_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setLong(2, pictureId);
			stDel.setString(3, userId);

			stDel.executeUpdate();

			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, pictureId);
			stCR.setString(3, userId);
			stCR.setBoolean(4, true);
			stCR.executeUpdate();


		} catch (SQLException e) {
			LOGGER.error("blurPicture(" + albumId + ", " + pictureId + "," + userId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}

	}

	@Override
	public void blurPicture(long albumId, long pictureId) throws BlurSettingsPersistenceServiceException {
		if (isPictureBlurredForAllUsers(albumId, pictureId))
			throw new PictureIsBlurredPersistenceException(albumId, pictureId);
		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_PHOTO_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setLong(2, pictureId);
			stDel.setString(3, FOR_ALL_USERS);

			stDel.executeUpdate();

			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, pictureId);
			stCR.setString(3, FOR_ALL_USERS);
			stCR.setBoolean(4, true);
			stCR.executeUpdate();


		} catch (SQLException e) {
			LOGGER.error("blurPicture(" + albumId + ", " + pictureId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}
	}

	@Override
	public void unBlurPicture(long albumId, long pictureId, String userId) throws BlurSettingsPersistenceServiceException {

		//check
		BlurSettingBO setting = readBlurSetting(albumId, pictureId, userId);
		if (setting == null || !setting.isBlurred())
			throw new PictureIsNotBlurredPersistenceException(albumId, pictureId, userId);


		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_PHOTO_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setLong(2, pictureId);
			stDel.setString(3, userId);

			stDel.executeUpdate();

			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, pictureId);
			stCR.setString(3, userId);
			stCR.setBoolean(4, false);
			stCR.executeUpdate();

		} catch (SQLException e) {
			LOGGER.error("blurPicture(" + albumId + ", " + pictureId + "," + userId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}
	}

	@Override
	public void unBlurPicture(long albumId, long pictureId) throws BlurSettingsPersistenceServiceException {
		if (!isPictureBlurredForAllUsers(albumId, pictureId))
			throw new PictureIsNotBlurredPersistenceException(albumId, pictureId);

		Connection conn = null;
		PreparedStatement stDel = null;
		PreparedStatement stCR = null;
		try {
			conn = getConnection();
			stDel = conn.prepareStatement(SQL_DELETE_BY_ALBUM_AND_PHOTO_AND_USER_ID);
			stDel.setLong(1, albumId);
			stDel.setLong(2, pictureId);
			stDel.setString(3, FOR_ALL_USERS);

			stDel.executeUpdate();

			stCR = conn.prepareStatement(SQL_CREATE);
			stCR.setLong(1, albumId);
			stCR.setLong(2, pictureId);
			stCR.setString(3, FOR_ALL_USERS);
			stCR.setBoolean(4, false);
			stCR.executeUpdate();


		} catch (SQLException e) {
			LOGGER.error("blurPicture(" + albumId + ", " + pictureId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(stDel);
			close(stCR);
			close(conn);
		}
	}

	@Override
	public void removeBlurSettings(long albumId) throws BlurSettingsPersistenceServiceException {
		Connection conn = null;
		PreparedStatement st = null;
		try {
			conn = getConnection();
			st = conn.prepareStatement(SQL_DELETE_BY_ALBUM_ID);
			st.setLong(1, albumId);

			st.executeUpdate();

		} catch (SQLException e) {
			LOGGER.error("removeBlurSettings(" + albumId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(st);
			close(conn);
		}
	}

	/**
	 * Return true - if picture blurred for all users!  Means  that   record like (albumId,0,0) - album blurred  or
	 * record (albumId,pictureId,0)  - exists.
	 *
	 * @param albumId   id of album
	 * @param pictureId id of picture
	 * @return boolean value
	 * @throws BlurSettingsPersistenceServiceException
	 *          on sql erros
	 */
	private boolean isPictureBlurredForAllUsers(long albumId, long pictureId) throws BlurSettingsPersistenceServiceException {
		Connection conn = null;
		PreparedStatement st = null;
		ResultSet rs = null;
		try {
			conn = getConnection();
			st = conn.prepareStatement(SQL_READ_PICTURE_BLURRED_FOR_USER);
			st.setLong(1, albumId);
			st.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
			st.setLong(3, pictureId);
			st.setString(4, FOR_ALL_USERS);

			rs = st.executeQuery();
			return rs.next() && rs.getBoolean(FIELD_NAME_BLUR);

		} catch (SQLException e) {
			LOGGER.error("isPictureBlurredForAllUsers(" + albumId + "," + pictureId + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(rs);
			close(st);
			close(conn);
		}
	}


	@Override
	protected List getDDL() {
		return ddlQueries;
	}

	@Override
	protected String getTableName() {
		return TABLE_NAME;
	}

	@Override
	protected String getPKFieldName() {
		//Not required!  here we have Primary on Multiple fields.
		return null;
	}


	/**
	 * Return BlurSetting with selected properties.
	 *
	 * @param args arguments array
	 * @return {@link BlurSettingBO}
	 * @throws BlurSettingsPersistenceServiceException
	 *          on SQL errors
	 */
	private BlurSettingBO readAlbumSetting(Object... args) throws BlurSettingsPersistenceServiceException {
		Connection conn = null;
		PreparedStatement st = null;
		ResultSet rs = null;
		try {
			conn = getConnection();
			switch (args.length) {
				case 1:
					st = conn.prepareStatement(SQL_READ_SETTING);
					//albumID
					st.setLong(1, Long.valueOf(String.valueOf(args[0])));
					//all pictures in album
					st.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
					//all users in album
					st.setString(3, FOR_ALL_USERS);
					break;

				case 2:
					st = conn.prepareStatement(SQL_READ_ALBUM_BLURRED_FOR_USER);
					//album id
					st.setLong(1, Long.valueOf(String.valueOf(args[0])));
					//picture id
					st.setLong(2, FOR_ALL_PICTURES_IN_ALBUM);
					// user Id
					st.setString(3, String.valueOf(args[1]));
					//// all users Ids
					st.setString(4, FOR_ALL_USERS);
					break;

				case 3:
					st = conn.prepareStatement(SQL_READ_SETTING);
					//album ID
					st.setLong(1, Long.valueOf(String.valueOf(args[0])));
					//photoId
					st.setLong(2, Long.valueOf(String.valueOf(args[1])));
					//userId
					st.setString(3, String.valueOf(args[2]));
					break;
			}
			rs = st.executeQuery();
			if (rs.next()) {
				BlurSettingBO result = new BlurSettingBO();
				result.setAlbumId(rs.getLong(FIELD_NAME_ALBUM_ID));
				result.setPictureId(rs.getLong(FIELD_NAME_PHOTO_ID));
				result.setUserId(rs.getString(FIELD_NAME_USER_ID));
				result.setBlurred(rs.getBoolean(FIELD_NAME_BLUR));
				return result;
			}

			return null;

		} catch (SQLException e) {
			LOGGER.error("readAlbumSetting(" + args.length + ")", e);
			throw new BlurSettingsPersistenceServiceException("Persistence failed.", e);
		} finally {
			close(rs);
			close(st);
			close(conn);
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy