BrightSide Workbench Full Report + Source Code
PreferencesProvider.java
Go to the documentation of this file.
1 /*
2  * TurrĂ³ i Cutiller Foundation. License notice.
3  * Copyright (C) 2023 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.alliance.provider;
20 
21 import java.util.List;
22 import org.turro.alliance.db.AlliancePU;
23 import org.turro.jpa.Dao;
24 import org.turro.json.Jsons;
25 import org.turro.server.db.entities.AxMemberPreferences;
26 import org.turro.sql.SqlClause;
27 import org.turro.string.Strings;
28 import org.turro.util.Cached;
29 import org.turro.ws.WsMember;
30 import org.turro.ws.content.JsonServerProvider;
31 
36 public class PreferencesProvider extends JsonServerProvider {
37 
38  public PreferencesProvider(WsMember member, String reason, Jsons criteria) {
39  super(member, reason, criteria);
40  }
41 
42  @Override
43  protected Jsons loadData(WsMember member, String reason, Jsons criteria) {
44  AxMemberPreferences preferences = SqlClause.select("p").from("AxMemberPreferences p")
45  .where().equal("memberId", member.getMemberId())
46  .dao(dao.get())
47  .singleResult(AxMemberPreferences.class, null);
48  if(preferences == null) {
49  preferences = new AxMemberPreferences();
50  preferences.setMemberId(member.getMemberId());
51  }
52  return Jsons.read(preferences.toJson());
53  }
54 
55  @Override
56  protected long count(WsMember member, String reason, Jsons criteria) {
57  List<Long> ids = criteria.getArrayValues("categoryIds", Long.class);
58  String search = criteria.getString("search", "");
59  int phase = criteria.getInt("phase", -1);
60  return SqlClause.select("count(p)").from("AxProject p")
61  .startIf(ids != null && !ids.isEmpty())
62  .where().in("categoryId", ids)
63  .endIf()
64  .startIf(!Strings.isBlank(search))
65  .whereOrAnd().partial(search, "p.code", "p.name", "p.summary")
66  .endIf()
67  .startIf(phase > -1)
68  .whereOrAnd().equal("p.phaseIndex", phase)
69  .endIf()
70  .dao(dao.get())
71  .singleResult(Long.class, 0L);
72  }
73 
74  private final Cached<Dao> dao = Cached.instance(() -> new AlliancePU());
75 
76 }
PreferencesProvider(WsMember member, String reason, Jsons criteria)
Jsons loadData(WsMember member, String reason, Jsons criteria)
long count(WsMember member, String reason, Jsons criteria)