ledger-core
QueryBuilder.h
1 /*
2  *
3  * QueryBuilder
4  * ledger-core
5  *
6  * Created by Pierre Pollastri on 27/06/2017.
7  *
8  * The MIT License (MIT)
9  *
10  * Copyright (c) 2016 Ledger
11  *
12  * Permission is hereby granted, free of charge, to any person obtaining a copy
13  * of this software and associated documentation files (the "Software"), to deal
14  * in the Software without restriction, including without limitation the rights
15  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
16  * copies of the Software, and to permit persons to whom the Software is
17  * furnished to do so, subject to the following conditions:
18  *
19  * The above copyright notice and this permission notice shall be included in all
20  * copies or substantial portions of the Software.
21  *
22  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
23  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
25  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
27  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
28  * SOFTWARE.
29  *
30  */
31 #ifndef LEDGER_CORE_QUERYBUILDER_H
32 #define LEDGER_CORE_QUERYBUILDER_H
33 
34 #include "QueryFilter.h"
35 #include <soci.h>
36 #include <list>
37 #include <tuple>
38 #include <utils/Option.hpp>
39 
40 namespace ledger {
41  namespace core {
42  class QueryBuilder {
43  public:
44  QueryBuilder() : _keys("*") {
45 
46  };
47  QueryBuilder& select(const std::string& keys);
48  QueryBuilder& select(std::string&& keys);
49  QueryBuilder& from(const std::string& table);
50  QueryBuilder& from(std::string&& table);
51  QueryBuilder& to(const std::string& output);
52  QueryBuilder& to(std::string&& output);
53  QueryBuilder& where(const std::shared_ptr<api::QueryFilter>& filter);
54  QueryBuilder& outerJoin(const std::string& table, const std::string& condition);
55  QueryBuilder& order(std::string&& keys, bool&& descending);
56  QueryBuilder& limit(int32_t limit);
57  QueryBuilder& offset(int32_t offset);
58  soci::details::prepare_temp_type execute(soci::session& sql);
59 
60  private:
61  using LeftOuterJoin = std::tuple<std::string, std::string>;
62 
63  std::string _keys;
64  std::string _table;
65  std::string _output;
66  std::list<std::tuple<std::string, bool>> _order;
67  std::vector<Option<LeftOuterJoin>> _outerJoins;
68  std::shared_ptr<QueryFilter> _filter;
69  Option<int32_t> _limit;
70  Option<int32_t> _offset;
71  };
72  }
73 }
74 
75 
76 #endif //LEDGER_CORE_QUERYBUILDER_H
Definition: QueryBuilder.h:42
Definition: Account.cpp:8