summaryrefslogtreecommitdiff
path: root/qicclient.hxx
blob: bc060e8eb8453f837052a33c5590d5a979318a56 (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
68
69
70
71
72
#ifndef QICCLIENT_HXX
#define QICCLIENT_HXX

#include <QObject>
#include "qicclient/catalog.hxx"
#include <icclient.h>

namespace QICClient {

	using std::shared_ptr;
	class Ord;

	class Client : public QObject
	{
		Q_OBJECT

		public:
			/*!
			 * \brief Constructor.
			 * \param sampleURL The value of the SAMPLEURL setting in products/variable.txt.
			 * \param image_Dir The value of the IMAGE_DIR setting in products/variable.txt.
			 * \param certificate Path to the CA certificate file.
			 */
			Client(char const* sampleURL, char const* image_Dir, 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 C style pointer to function for custom handling.
			 */
			//void results(QString const& prodGroup, void (*handler)(icclient_fetch_t*));
			/*!
			 * \brief For fetching data about all active products.
			 * \param handler A C style pointer to function for custom handling.
			 */
			void allproducts(void (*handler)(icclient_fetch_t*) = nullptr);
			void emitResults(icclient_fetch_t* fetch);
			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, void (*handler)(icclient_fetch_t*));
			/*!
			 * \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);

		public slots:
			/*!
			 * \brief For fetching products that belong a specific group.
			 * \param prodGroup The name of the product group.
			 */
			void results(QString const& prodGroup);
			/*!
			 * \brief For fetching data about all active products.
			 */
			void allProducts();

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

}

#endif