BrightSide Workbench Full Report + Source Code
ContactsCleanup.java
Go to the documentation of this file.
1 /*
2  * TurrĂ³ i Cutiller Foundation. License notice.
3  * Copyright (C) 2022 Lluis TurrĂ³ Cutiller <http://www.turro.org/>
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU Affero General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program 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 Affero General Public License for more details.
14  *
15  * You should have received a copy of the GNU Affero General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 
19 package org.turro.cleanup;
20 
21 import org.turro.contacts.db.ContactsPU;
22 import org.turro.jpa.Dao;
23 import org.turro.sql.SqlClause;
24 
29 @ElephantCleanup
30 public class ContactsCleanup extends AbstractCleanup {
31 
32  @Override
33  public boolean isMine(Object entity) {
34  return false;
35  }
36 
37  @Override
38  public void cleanEntity(Object entity, CleanupMode mode) {
39 
40  }
41 
42  @Override
43  public void cleanOrphans() {
44  Dao dao = new ContactsPU();
45  SqlClause.update("Convocation")
46  .append("set contact_fk = NULL")
47  .where().isNotNull("contact_fk")
48  .and().notExists(SqlClause.select("*").from("Contact c").where("c.identifier = contact_fk"))
49  .dao(dao)
50  .executeNative();
51  SqlClause.delete("CommentIt")
52  .where().isNotNull("creator_fk")
53  .and().notExists(SqlClause.select("*").from("Contact c").where("c.identifier = creator_fk"))
54  .dao(dao)
55  .executeNative();
56  SqlClause.delete("StarIt")
57  .where().isNotNull("creator_fk")
58  .and().notExists(SqlClause.select("*").from("Contact c").where("c.identifier = creator_fk"))
59  .dao(dao)
60  .executeNative();
61  SqlClause.delete("VoteIt")
62  .where().isNotNull("creator_fk")
63  .and().notExists(SqlClause.select("*").from("Contact c").where("c.identifier = creator_fk"))
64  .dao(dao)
65  .executeNative();
66  cleanOrphansFor("contact", getEntityPaths(dao, String.class, "Contact", "id", "contact"));
67  }
68 
69 }
void cleanOrphansFor(String root, Set< String > entities)
void cleanEntity(Object entity, CleanupMode mode)