1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.java Sat Feb 14 14:27:53 2009 +0100
1.3 @@ -0,0 +1,75 @@
1.4 +package cz.frantovo.hrisniciSpameri.dao;
1.5 +
1.6 +import cz.frantovo.hrisniciSpameri.dto.Cil;
1.7 +import java.sql.Connection;
1.8 +import java.sql.Date;
1.9 +import java.sql.PreparedStatement;
1.10 +import java.sql.ResultSet;
1.11 +import java.util.Collection;
1.12 +import java.util.logging.Level;
1.13 +
1.14 +/**
1.15 + *
1.16 + * @author fiki
1.17 + */
1.18 +public class GeneratorSouhrnuDAO extends HrisniciSuperDAO {
1.19 +
1.20 + private enum SQL {
1.21 +
1.22 + VLOZ_SOUHRN
1.23 + }
1.24 +
1.25 + /**
1.26 + * Vygeneruje souhrn pro daný cíl a datum a uloží ho do databáze
1.27 + * @param cil cíl, pro který generujeme souhrn
1.28 + * @param den den, pro který souhrn generujeme.
1.29 + */
1.30 + private void generujSouhrn(Cil cil, Date den) {
1.31 + Connection dbZdroj = getSpojeni(cil.getDatabaze());
1.32 + Connection dbSouhrn = getSpojeni(null);
1.33 +
1.34 + if (dbZdroj == null || dbSouhrn == null) {
1.35 + /** TODO: Chyba spojení */
1.36 + } else {
1.37 + PreparedStatement ps = null;
1.38 + ResultSet rs = null;
1.39 + try {
1.40 + ps = dbZdroj.prepareStatement(cil.getSelekt());
1.41 + ps.setDate(1, den);
1.42 + rs = ps.executeQuery();
1.43 + PreparedStatement psSouhrn = dbSouhrn.prepareStatement(getSQL(SQL.VLOZ_SOUHRN));
1.44 + while (rs.next()) {
1.45 + /**
1.46 + * Souhrn bychom mohli vkládat pomocí SouhrnDAO,
1.47 + * ale z výkonnostních důvodů to budeme dělat tady
1.48 + * (jedno spojení a jeden předpřipravený příkaz).
1.49 + */
1.50 + psSouhrn.setDate(1, den);
1.51 + psSouhrn.setString(2, rs.getString("ip"));
1.52 + psSouhrn.setString(3, "TODO: přeložit " + rs.getString("ip"));
1.53 + psSouhrn.setInt(4, rs.getInt("pocet"));
1.54 + psSouhrn.setInt(5, cil.getId());
1.55 + psSouhrn.executeUpdate();
1.56 + }
1.57 + zavri(null, psSouhrn, null);
1.58 + dbSouhrn.commit();
1.59 + } catch (Exception e) {
1.60 + log.log(Level.SEVERE, "Chyba při generování souhrnu.", e);
1.61 + } finally {
1.62 + zavri(dbZdroj, ps, rs);
1.63 + zavri(dbSouhrn, null, null);
1.64 + }
1.65 + }
1.66 + }
1.67 +
1.68 + /**
1.69 + * Vygeneruje denní souhrny pro všechny cíle.
1.70 + * @param den den, pro který souhrny generujeme.
1.71 + */
1.72 + public void generujSouhrny(Date den) {
1.73 + Collection<Cil> cile = new CilDAO().getCile();
1.74 + for (Cil c : cile) {
1.75 + generujSouhrn(c, den);
1.76 + }
1.77 + }
1.78 +}
2.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
2.2 +++ b/java/HrisniciSpameri/src/java/cz/frantovo/hrisniciSpameri/dao/GeneratorSouhrnuDAO.sql.xml Sat Feb 14 14:27:53 2009 +0100
2.3 @@ -0,0 +1,11 @@
2.4 +<?xml version="1.0" encoding="UTF-8"?>
2.5 +<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
2.6 +<properties>
2.7 + <entry key="VLOZ_SOUHRN">
2.8 + <![CDATA[
2.9 + INSERT INTO souhrn
2.10 + (den, ip, domena, pocet, cil)
2.11 + VALUES (?,?,?,?,?)
2.12 + ]]>
2.13 + </entry>
2.14 +</properties>
2.15 \ No newline at end of file
3.1 --- a/sql/schéma.sql Sat Feb 14 13:32:38 2009 +0100
3.2 +++ b/sql/schéma.sql Sat Feb 14 14:27:53 2009 +0100
3.3 @@ -7,7 +7,7 @@
3.4 id bigint NOT NULL,
3.5 nazev character varying NOT NULL,
3.6 url character varying, -- Odkaz na daný cíl – pokud je to např. webová stránka
3.7 - selekt character varying NOT NULL, -- SQL dotaz, kterým získáme ze zdrojové databáze: IP adresu a počet pokusů o spamování pro daný den (parametr dotazu)
3.8 + selekt character varying NOT NULL, -- SQL dotaz, kterým získáme ze zdrojové databáze: IP adresu (sloupeček "ip") a počet pokusů (sloupeček "pocet") o spamování pro daný den (parametr dotazu)
3.9 databaze character varying NOT NULL, -- Celé JNDI jméno datového zdroje – databáze, na které bude volán selekt.
3.10 CONSTRAINT cil_pk PRIMARY KEY (id)
3.11 )
3.12 @@ -15,7 +15,7 @@
3.13 ALTER TABLE cil OWNER TO hrisnicispameri;
3.14 COMMENT ON TABLE cil IS 'Definice cílu (oběti) spamování.';
3.15 COMMENT ON COLUMN cil.url IS 'Odkaz na daný cíl – pokud je to např. webová stránka';
3.16 -COMMENT ON COLUMN cil.selekt IS 'SQL dotaz, kterým získáme ze zdrojové databáze: IP adresu a počet pokusů o spamování pro daný den (parametr dotazu)';
3.17 +COMMENT ON COLUMN cil.selekt IS 'SQL dotaz, kterým získáme ze zdrojové databáze: IP adresu (sloupeček "ip") a počet pokusů (sloupeček "pocet") o spamování pro daný den (parametr dotazu)';
3.18 COMMENT ON COLUMN cil.databaze IS 'Celé JNDI jméno datového zdroje – databáze, na které bude volán selekt.';
3.19
3.20