summaryrefslogtreecommitdiff
path: root/qicclient/client.hxx
blob: 1bc5ea4cac44e60f09c8dd76e3340e5d3c3db891 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#ifndef QICCLIENT_CLIENT_HXX
#define QICCLIENT_CLIENT_HXX

#include <QObject>
#include <icclient/typedefs.h>

namespace QICClient {

	using std::shared_ptr;
	class Catalog;
#ifndef __EMSCRIPTEN__
	class Ord;
#endif

	class Client : public QObject
	{
		Q_OBJECT

		public:
			/*!
			 * \brief Constructor.
			 * \param url Server root URL.
			 * \param certificate Path to the CA certificate file.
			 */
			Client(char const* url, char const* certificate = nullptr);
			~Client();

			/*!
			 * \brief For fetching products that belong a specific group.
			 * \param prodGroup The name of the product group.
			 * \param handler A pointer to a cURL write function callback.
			 */
			void results(QString const& prodGroup, icclient_handler handler = nullptr);

			/*!
			 * \brief For fetching data about all active products.
			 * \param handler A pointer to a cURL write function callback.
			 */
			void allProducts(icclient_handler handler = nullptr);

			void emitCatalog(icclient_catalog *catalog);

			/*!
			 * \brief For fetching data about a specific product.
			 * \param sku The SKU of the item to order.
			 * \param handler A pointer to a cURL write function callback.
			 */
			void flyPage(QString const& sku, icclient_handler handler);

#ifndef __EMSCRIPTEN__
			/*!
			 * \brief For putting an item to a cart.
			 * \param sku The SKU of the item to order.
			 * \param catalog The catalog from which the item is.
			 * \param order The order.
			 */
			void order(QString const& sku, Catalog const& catalog, Ord& order);
#endif

		signals:
			void gotResults(Catalog* catalog);
			void gotFlyPage(shared_ptr<Product> product);
	};

}

#endif