Coverage Report - org.jtheque.primary.dao.impl.DaoLanguages
 
Classes in this File Line Coverage Branch Coverage Complexity
DaoLanguages
0 %
0/26
0 %
0/8
1.308
DaoLanguages$1
N/A
N/A
1.308
DaoLanguages$LanguageQueryMapper
0 %
0/9
N/A
1.308
DaoLanguages$LanguageRowMapper
0 %
0/5
N/A
1.308
 
 1  
 package org.jtheque.primary.dao.impl;
 2  
 
 3  
 /*
 4  
  * This file is part of JTheque.
 5  
  *
 6  
  * JTheque is free software: you can redistribute it and/or modify
 7  
  * it under the terms of the GNU General Public License as published by
 8  
  * the Free Software Foundation, either version 3 of the License.
 9  
  *
 10  
  * JTheque is distributed in the hope that it will be useful,
 11  
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 12  
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 13  
  * GNU General Public License for more details.
 14  
  *
 15  
  * You should have received a copy of the GNU General Public License
 16  
  * along with JTheque.  If not, see <http://www.gnu.org/licenses/>.
 17  
  */
 18  
 
 19  
 import org.jtheque.core.managers.persistence.GenericDao;
 20  
 import org.jtheque.core.managers.persistence.Query;
 21  
 import org.jtheque.core.managers.persistence.QueryMapper;
 22  
 import org.jtheque.core.managers.persistence.able.Entity;
 23  
 import org.jtheque.core.managers.persistence.context.IDaoPersistenceContext;
 24  
 import org.jtheque.primary.dao.able.IDaoLanguages;
 25  
 import org.jtheque.primary.od.able.Language;
 26  
 import org.jtheque.primary.od.impl.LanguageImpl;
 27  
 import org.springframework.jdbc.core.simple.ParameterizedRowMapper;
 28  
 import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
 29  
 
 30  
 import javax.annotation.Resource;
 31  
 import java.sql.ResultSet;
 32  
 import java.sql.SQLException;
 33  
 import java.util.Collection;
 34  
 import java.util.List;
 35  
 
 36  
 /**
 37  
  * A Data Access Object implementation for languages.
 38  
  *
 39  
  * @author Baptiste Wicht
 40  
  */
 41  0
 public final class DaoLanguages extends GenericDao<Language> implements IDaoLanguages {
 42  0
     private final ParameterizedRowMapper<Language> rowMapper = new LanguageRowMapper();
 43  0
     private final QueryMapper queryMapper = new LanguageQueryMapper();
 44  
 
 45  
     @Resource
 46  
     private IDaoPersistenceContext persistenceContext;
 47  
 
 48  
     @Resource
 49  
     private SimpleJdbcTemplate jdbcTemplate;
 50  
 
 51  
     /**
 52  
      * Create a new DaoLanguages.
 53  
      */
 54  
     public DaoLanguages() {
 55  0
         super(TABLE);
 56  0
     }
 57  
 
 58  
     @Override
 59  
     public Collection<Language> getLanguages() {
 60  0
         return getAll();
 61  
     }
 62  
 
 63  
     @Override
 64  
     public Language getLanguage(int id) {
 65  0
         return get(id);
 66  
     }
 67  
 
 68  
     @Override
 69  
     public Language getLanguage(String name) {
 70  0
         List<Language> languages = jdbcTemplate.query("SELECT * FROM " + TABLE + " WHERE NAME = ?", rowMapper, name);
 71  
 
 72  0
         if (languages.isEmpty()) {
 73  0
             return null;
 74  
         }
 75  
 
 76  0
         Language language = languages.get(0);
 77  
 
 78  0
         if (isNotInCache(language.getId())) {
 79  0
             getCache().put(language.getId(), language);
 80  
         }
 81  
 
 82  0
         return getCache().get(language.getId());
 83  
     }
 84  
 
 85  
     @Override
 86  
     public boolean exist(Language language) {
 87  0
         return getLanguage(language.getName()) != null;
 88  
     }
 89  
 
 90  
     @Override
 91  
     public Language createLanguage() {
 92  0
         return new LanguageImpl();
 93  
     }
 94  
 
 95  
     @Override
 96  
     protected ParameterizedRowMapper<Language> getRowMapper() {
 97  0
         return rowMapper;
 98  
     }
 99  
 
 100  
     @Override
 101  
     protected QueryMapper getQueryMapper() {
 102  0
         return queryMapper;
 103  
     }
 104  
 
 105  
     @Override
 106  
     protected void loadCache() {
 107  0
         Collection<Language> languages = persistenceContext.getSortedList(TABLE, rowMapper);
 108  
 
 109  0
         for (Language language : languages) {
 110  0
             getCache().put(language.getId(), language);
 111  
         }
 112  
 
 113  0
         setCacheEntirelyLoaded();
 114  0
     }
 115  
 
 116  
     @Override
 117  
     protected void load(int i) {
 118  0
         Language language = persistenceContext.getDataByID(TABLE, i, rowMapper);
 119  
 
 120  0
         getCache().put(i, language);
 121  0
     }
 122  
 
 123  
     /**
 124  
      * A row mapper to map resultset to language.
 125  
      *
 126  
      * @author Baptiste Wicht
 127  
      */
 128  0
     private final class LanguageRowMapper implements ParameterizedRowMapper<Language> {
 129  
         @Override
 130  
         public Language mapRow(ResultSet rs, int i) throws SQLException {
 131  0
             Language language = createLanguage();
 132  
 
 133  0
             language.setId(rs.getInt("ID"));
 134  0
             language.setName(rs.getString("NAME"));
 135  
 
 136  0
             return language;
 137  
         }
 138  
     }
 139  
 
 140  
     /**
 141  
      * A query mapper to map language to query.
 142  
      *
 143  
      * @author Baptiste Wicht
 144  
      */
 145  0
     private static final class LanguageQueryMapper implements QueryMapper {
 146  
         @Override
 147  
         public Query constructInsertQuery(Entity entity) {
 148  0
             Language borrower = (Language) entity;
 149  
 
 150  0
             String query = "INSERT INTO " + TABLE + " (NAME) VALUES(?)";
 151  
 
 152  0
             Object[] parameters = {
 153  
                     borrower.getName()};
 154  
 
 155  0
             return new Query(query, parameters);
 156  
         }
 157  
 
 158  
         @Override
 159  
         public Query constructUpdateQuery(Entity entity) {
 160  0
             Language borrower = (Language) entity;
 161  
 
 162  0
             String query = "UPDATE " + TABLE + " SET NAME = ? WHERE ID = ?";
 163  
 
 164  0
             Object[] parameters = {
 165  
                     borrower.getName(),
 166  
                     borrower.getId()};
 167  
 
 168  0
             return new Query(query, parameters);
 169  
         }
 170  
     }
 171  
 }