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

com.serphacker.serposcope.db.google.GoogleTargetSummaryDB Maven / Gradle / Ivy

The newest version!
/* 
 * Serposcope - SEO rank checker https://serposcope.serphacker.com/
 * 
 * Copyright (c) 2016 SERP Hacker
 * @author Pierre Nogues 
 * @license https://opensource.org/licenses/MIT MIT License
 */
package com.serphacker.serposcope.db.google;

import com.google.inject.Singleton;
import com.querydsl.core.Tuple;
import com.querydsl.sql.SQLQuery;
import com.querydsl.sql.dml.SQLDeleteClause;
import com.querydsl.sql.dml.SQLMergeClause;
import com.serphacker.serposcope.db.AbstractDB;
import com.serphacker.serposcope.models.google.GoogleTargetSummary;
import com.serphacker.serposcope.querybuilder.QGoogleRank;
import com.serphacker.serposcope.querybuilder.QGoogleTargetSummary;
import java.sql.Connection;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

@Singleton
public class GoogleTargetSummaryDB extends AbstractDB {

    QGoogleTargetSummary t_summary = QGoogleTargetSummary.googleTargetSummary;
    QGoogleRank t_rank = QGoogleRank.googleRank;

    public int insert(Collection summaries){
        int inserted = 0;
        
        try(Connection con = ds.getConnection()){
            
            for (GoogleTargetSummary target : summaries) {
                inserted += new SQLMergeClause(con, dbTplConf, t_summary)
                    .set(t_summary.groupId, target.getGroupId())
                    .set(t_summary.googleTargetId, target.getTargetId())
                    .set(t_summary.runId, target.getRunId())
                    
                    .set(t_summary.totalTop3, target.getTotalTop3())
                    .set(t_summary.totalTop10, target.getTotalTop10())
                    .set(t_summary.totalTop100, target.getTotalTop100())
                    .set(t_summary.totalOut, target.getTotalOut())
                    
                    .set(t_summary.topRanks, target.getTopRanksSerialized())
                    .set(t_summary.topImprovements, target.getTopImprovementsSerialized())
                    .set(t_summary.topLosts, target.getTopLostsSerialized())
                    
                    .set(t_summary.scoreRaw, target.getScoreRaw())
                    .set(t_summary.scoreBasisPoint, target.getScoreBP())
                    .set(t_summary.previousScoreBasisPoint, target.getPreviousScoreBP())
                    
                    .execute();
            }
            
        } catch(Exception ex){
            LOG.error("SQL error", ex);
        }
        
        return inserted;
    }
    
    public boolean deleteByTarget(int targetId){
        boolean deleted = false;
        try(Connection con = ds.getConnection()){
            deleted = new SQLDeleteClause(con, dbTplConf, t_summary)
                .where(t_summary.googleTargetId.eq(targetId))
                .execute() == 1;
        }catch(Exception ex){
            LOG.error("SQLError", ex);
        }
        return deleted;
    }
    
    public boolean deleteByRun(int runId){
        boolean deleted = false;
        try(Connection con = ds.getConnection()){
            deleted = new SQLDeleteClause(con, dbTplConf, t_summary)
                .where(t_summary.runId.eq(runId))
                .execute() == 1;
        }catch(Exception ex){
            LOG.error("SQLError", ex);
        }
        return deleted;
    }    
    
    public void wipe(){
        try(Connection con = ds.getConnection()){
            new SQLDeleteClause(con, dbTplConf, t_summary).execute();
        }catch(Exception ex){
            LOG.error("SQLError", ex);
        }
    }
    
    public Map getPreviousScore(int runId){
        Map scores = new HashMap<>();
        
        try(Connection con = ds.getConnection()){
            List records = new SQLQuery(con, dbTplConf)
                .select(t_summary.googleTargetId, t_summary.scoreBasisPoint)
                .from(t_summary)
                .where(t_summary.runId.eq(runId))
                .fetch();
            
            for (Tuple record : records) {
                scores.put(record.get(t_summary.googleTargetId), record.get(t_summary.scoreBasisPoint));
            }
                
        }catch(Exception ex){
            LOG.error("SQLError", ex);
        }
        
        return scores;
    }
    
    public List listScoreHistory(int groupId, int targetId, int history){
        List scores = new ArrayList<>();
        
        try(Connection con = ds.getConnection()){
            scores = new SQLQuery(con, dbTplConf)
                .select(t_summary.scoreBasisPoint)
                .from(t_summary)
                .where(t_summary.groupId.eq(groupId))
                .where(t_summary.googleTargetId.eq(targetId))
                .orderBy(t_summary.runId.desc())
                .limit(history)
                .fetch();
                
        }catch(Exception ex){
            LOG.error("SQLError", ex);
        }
        
        if(scores != null){
            Collections.reverse(scores);
        } else {
            scores = new ArrayList<>();
        }
        
        return scores;        
    }
    
    public List list(int runId){
        return list(runId, false);
    }
    
    public List list(int runId, boolean skipTop){
        List summaries = new ArrayList<>();
        try(Connection con = ds.getConnection()){
            
            List summaryTuples = new SQLQuery(con, dbTplConf)
                .select(t_summary.all())
                .from(t_summary)
                .where(t_summary.runId.eq(runId))
                .fetch();
            
            for (Tuple tuple : summaryTuples) {
                
                GoogleTargetSummary summary = new GoogleTargetSummary(
                    tuple.get(t_summary.groupId),
                    tuple.get(t_summary.googleTargetId),
                    runId, 
                    tuple.get(t_summary.previousScoreBasisPoint)
                );
                
                summary.setTotalTop3(tuple.get(t_summary.totalTop3));
                summary.setTotalTop10(tuple.get(t_summary.totalTop10));
                summary.setTotalTop100(tuple.get(t_summary.totalTop100));
                summary.setTotalOut(tuple.get(t_summary.totalOut));
                
                summary.setScoreRaw(tuple.get(t_summary.scoreRaw));
                summary.setScoreBP(tuple.get(t_summary.scoreBasisPoint));
                
                if(!skipTop){
                    List topRanksIds = unserializeIds(tuple.get(t_summary.topRanks));
                    List topImprovementsIds = unserializeIds(tuple.get(t_summary.topImprovements));
                    List topLostsIds = unserializeIds(tuple.get(t_summary.topLosts));

                    Set searchIds = new HashSet<>();
                    searchIds.addAll(topRanksIds);
                    searchIds.addAll(topImprovementsIds);
                    searchIds.addAll(topLostsIds);

                    List rankTuples = new SQLQuery(con, dbTplConf)
                        .select(t_rank.all())
                        .from(t_rank)
                        .where(t_rank.runId.eq(runId))
                        .where(t_rank.groupId.eq(summary.getGroupId()))
                        .where(t_rank.googleTargetId.eq(summary.getTargetId()))
                        .where(t_rank.googleSearchId.in(searchIds))
                        .fetch();


                    for (Tuple rankTuple : rankTuples) {
                        summary.addRankToTop(GoogleRankDB.fromTuple(rankTuple));
                    }
                }
                
                summaries.add(summary);
            }
            
        } catch(Exception ex){
            LOG.error("SQLError", ex);
        }
        return summaries;
    }
    
    protected List unserializeIds(String str){
        if(str == null || str.isEmpty()){
            return Collections.EMPTY_LIST;
        }
        
        List ids = new ArrayList<>();
        
        String[] splits = str.split(",");
        for (String split : splits) {
            if(split.length() > 0){
                try {ids.add(Integer.parseInt(split));}catch(NumberFormatException ex){}
            }
        }
        
        return ids;
    }
    
    
    /*
    public List list(Collection groups){
        List targets = new ArrayList<>();
        
        try(Connection con = ds.getConnection()){
            
            SQLQuery query = new SQLQuery(con, dbTplConf)
                .select(t_target.all())
                .from(t_target);
            
            if(groups != null){
                query.where(t_target.groupId.in(groups));
            }
            
            List tuples = query.fetch();
            
            if(tuples != null){
                for (Tuple tuple : tuples) {
                    targets.add(fromTuple(tuple));
                }
            }
            
        } catch(Exception ex){
            LOG.error("SQL error", ex);
        }
        
        return targets;
    }
    
    public GoogleTarget get(int targetId){
        GoogleTarget target = null;
        
        try(Connection con = ds.getConnection()){
            
            Tuple tuple = new SQLQuery(con, dbTplConf)
                .select(t_target.all())
                .from(t_target)
                .where(t_target.id.eq(targetId))
                .fetchOne();
            
            target = fromTuple(tuple);
            
        } catch(Exception ex){
            LOG.error("SQL error", ex);
        }
        
        return target;
    }    
    
    GoogleTarget fromTuple(Tuple tuple) throws Exception{
        return new GoogleTarget(
            tuple.get(t_target.id),
            tuple.get(t_target.groupId),
            tuple.get(t_target.name),
            tuple.get(t_target.patternType) == null ? PatternType.REGEX : GoogleTarget.PatternType.values()[tuple.get(t_target.patternType)],
            tuple.get(t_target.pattern)
        );
    }
    */
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy