Ajout de l'algo
This commit is contained in:
@ -59,23 +59,54 @@ std::vector<models::Product> *DolibarrClient::list_products() const {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
models::Product DolibarrClient::get_product_by_factory_id(const char* factory_id) const {
|
||||
HTTPClient *client = this->build_url(replace_id("/products?sortorder=ASC&limit=1&sqlfilters=(t.accountancy_code_sell:like:'{id}')", factory_id).c_str());
|
||||
if (client->GET() == HTTP_CODE_OK) {
|
||||
DynamicJsonDocument doc(6144);
|
||||
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||
if (error) {
|
||||
Serial.println("ERROR: ");
|
||||
Serial.println(error.c_str());
|
||||
delete client;
|
||||
return {};
|
||||
}
|
||||
for (auto obj : doc.as<JsonArray>()) {
|
||||
models::Product product;
|
||||
product.date_creation = obj["date_creation"].as<std::string>();
|
||||
product.id = obj["id"].as<std::string>();
|
||||
product.entity = obj["entity"].as<std::string>();
|
||||
product.stock_reel = obj["stock_reel"].as<std::string>();
|
||||
product.label = obj["label"].as<std::string>();
|
||||
product.accountancy_code_sell = obj["accountancy_code_sell"].as<std::string>();
|
||||
product.accountancy_code_sell_export = obj["accountancy_code_sell_export"].as<std::string>();
|
||||
product.fk_default_warehouse = obj["fk_default_warehouse"].as<std::string>();
|
||||
delete client;
|
||||
return product;
|
||||
}
|
||||
delete client;
|
||||
return {};
|
||||
}
|
||||
delete client;
|
||||
return {};
|
||||
}
|
||||
|
||||
models::Product *DolibarrClient::get_product_by_id(const char* id_product) const {
|
||||
HTTPClient *client = this->build_url(replace_id(API_GET_PRODUCT_URL, id_product).c_str());
|
||||
if (client->GET() == HTTP_CODE_OK) {
|
||||
DynamicJsonDocument doc(6144);
|
||||
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||
if (error) {
|
||||
//Serial.println("ERROR: ");
|
||||
//Serial.println(error.c_str());
|
||||
delete client;
|
||||
return nullptr;
|
||||
}
|
||||
auto *product = new models::Product();
|
||||
product->date_creation = doc["date_creation"];
|
||||
product->id = doc["id"];
|
||||
product->entity = doc["entity"];
|
||||
product->stock_reel = doc["stock_reel"];
|
||||
product->label = doc["label"];
|
||||
product->date_creation = doc["date_creation"].as<std::string>();
|
||||
product->id = doc["id"].as<std::string>();
|
||||
product->entity = doc["entity"].as<std::string>();
|
||||
product->stock_reel = doc["stock_reel"].as<std::string>();
|
||||
product->label = doc["label"].as<std::string>();
|
||||
product->accountancy_code_sell = doc["accountancy_code_sell"].as<std::string>();
|
||||
product->accountancy_code_sell_export = doc["accountancy_code_sell_export"].as<std::string>();
|
||||
delete client;
|
||||
return product;
|
||||
}
|
||||
@ -108,13 +139,15 @@ std::vector<models::Warehouse> *DolibarrClient::list_warehouse() const {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
int DolibarrClient::create_movement(models::CreateProductStock &stock) const {
|
||||
int DolibarrClient::create_movement(models::CreateProductStock stock) const {
|
||||
HTTPClient *client = this->build_url(API_CREATE_STOCKS_MOVEMENTS_URL);
|
||||
DynamicJsonDocument doc(4096);
|
||||
std::string result;
|
||||
doc["product_id"] = stock.product_id;
|
||||
doc["warehouse_id"] = stock.warehouse_id;
|
||||
doc["qty"] = stock.qty;
|
||||
doc["movementlabel"] = "T-IOT - Warehouse GUI";
|
||||
doc["movementcode"] = "M" + stock.product_id + "-W" + stock.warehouse_id;
|
||||
serializeJson(doc, result);
|
||||
Serial.println(result.c_str());
|
||||
if (client->POST(result.c_str()) == HTTP_CODE_OK) {
|
||||
|
@ -24,7 +24,8 @@ public:
|
||||
std::vector<models::Warehouse> *list_warehouse() const;
|
||||
std::vector<models::Product> *list_products() const;
|
||||
models::Product *get_product_by_id(const char* id_product) const;
|
||||
int create_movement(models::CreateProductStock &stock) const;
|
||||
models::Product get_product_by_factory_id(const char* uuid) const;
|
||||
int create_movement(models::CreateProductStock stock) const;
|
||||
private:
|
||||
HTTPClient* httpClient{};
|
||||
struct DolibarrConfig dolibarr;
|
||||
|
@ -4,19 +4,22 @@
|
||||
namespace models {
|
||||
|
||||
struct Product {
|
||||
const char* id;
|
||||
const char* entity;
|
||||
const char* ref;
|
||||
const char* status;
|
||||
const char* date_creation;
|
||||
const char* date_modification;
|
||||
const char* label;
|
||||
const char* description;
|
||||
const char* type;
|
||||
const char* price;
|
||||
const char* stock_reel;
|
||||
const char* seuil_stock_alerte;
|
||||
const char* desiredstock;
|
||||
std::string id;
|
||||
std::string entity;
|
||||
std::string ref;
|
||||
std::string status;
|
||||
std::string date_creation;
|
||||
std::string date_modification;
|
||||
std::string label;
|
||||
std::string description;
|
||||
std::string type;
|
||||
std::string accountancy_code_sell;
|
||||
std::string accountancy_code_sell_export;
|
||||
std::string fk_default_warehouse;
|
||||
std::string price;
|
||||
std::string stock_reel;
|
||||
std::string seuil_stock_alerte;
|
||||
std::string desiredstock;
|
||||
};
|
||||
|
||||
struct ProductStock {
|
||||
@ -26,9 +29,9 @@ namespace models {
|
||||
};
|
||||
|
||||
struct CreateProductStock {
|
||||
const char* product_id;
|
||||
const char* warehouse_id;
|
||||
const char* qty;
|
||||
std::string product_id;
|
||||
std::string warehouse_id;
|
||||
std::string qty;
|
||||
};
|
||||
|
||||
struct Warehouse {
|
||||
|
Reference in New Issue
Block a user