use of CustomerContracts.ACustomerExceptions.ProductCatalogDoesNotExist in project SmartCity-Market by TechnionYP5777.
the class Customer method addProductToCart.
@Override
public void addProductToCart(SmartCode c, int amount) throws CriticalError, CustomerNotConnected, AmountBiggerThanAvailable, ProductPackageDoesNotExist, InvalidParameter {
String serverResponse;
log.info("Creating viewProductFromCatalog (in order to addPtoductToCart) command wrapper to customer with id: " + id);
CatalogProduct catalogProduct;
try {
catalogProduct = viewCatalogProduct(c);
} catch (ProductCatalogDoesNotExist e1) {
log.fatal("Critical bug: failed to get catalog product from server");
throw new CriticalError();
}
establishCommunication(CustomerDefs.port, CustomerDefs.host, CustomerDefs.timeout);
try {
serverResponse = sendRequestWithRespondToServer(new CommandWrapper(id, CommandDescriptor.ADD_PRODUCT_TO_GROCERY_LIST, Serialization.serialize(new ProductPackage(c, amount, null))).serialize());
} catch (SocketTimeoutException e) {
log.fatal("Critical bug: failed to get respond from server");
throw new CriticalError();
}
terminateCommunication();
try {
resultDescriptorHandler(getCommandWrapper(serverResponse).getResultDescriptor());
} catch (InvalidCommandDescriptor | ProductCatalogDoesNotExist | GroceryListIsEmpty | AuthenticationError | UsernameAlreadyExists | ForgotPasswordWrongAnswer ¢) {
log.fatal("Critical bug: this command result isn't supposed to return here");
throw new CriticalError();
}
ProductPackage productPackage1 = new ProductPackage(c, amount, null), productPackage2 = new ProductPackage(c, amount, null);
groceryList.addProduct(productPackage1);
addProductToCacheAndUpdateCartData(productPackage2, catalogProduct);
log.info("addProductToGroceryList command succeed.");
}
use of CustomerContracts.ACustomerExceptions.ProductCatalogDoesNotExist in project SmartCity-Market by TechnionYP5777.
the class Customer method checkOutGroceryList.
@Override
public Double checkOutGroceryList() throws CriticalError, CustomerNotConnected, GroceryListIsEmpty {
String serverResponse;
Double $ = totalSum;
log.info("Creating CHECKOUT_GROCERY_LIST command wrapper to customer with id: " + id);
establishCommunication(CustomerDefs.port, CustomerDefs.host, CustomerDefs.timeout);
try {
serverResponse = sendRequestWithRespondToServer((new CommandWrapper(id, CommandDescriptor.CHECKOUT_GROCERY_LIST)).serialize());
} catch (SocketTimeoutException e) {
log.fatal("Critical bug: failed to get respond from server");
throw new CriticalError();
}
terminateCommunication();
try {
resultDescriptorHandler(getCommandWrapper(serverResponse).getResultDescriptor());
} catch (InvalidCommandDescriptor | InvalidParameter | AmountBiggerThanAvailable | ProductPackageDoesNotExist | AuthenticationError | ProductCatalogDoesNotExist | UsernameAlreadyExists | ForgotPasswordWrongAnswer ¢) {
log.fatal("Critical bug: this command result isn't supposed to return here");
throw new CriticalError();
}
/* update customer data: groceryList, cartProductCache, totalSum */
groceryList = new GroceryList();
cartProductCache = new HashMap<Long, CartProduct>();
totalSum = Double.valueOf(0);
totalProductsAmount = 0;
log.info("CHECKOUT_GROCERY_LIST command succeed.");
return $;
}
use of CustomerContracts.ACustomerExceptions.ProductCatalogDoesNotExist in project SmartCity-Market by TechnionYP5777.
the class Customer method login.
@Override
public void login(String username, String password, boolean updateProductPictures) throws CriticalError, AuthenticationError {
CommandWrapper cmdwrppr = null;
String serverResponse = null;
log.info("Creating login command wrapper for customer");
establishCommunication(CustomerDefs.port, CustomerDefs.host, CustomerDefs.timeout);
try {
serverResponse = sendRequestWithRespondToServer((new CommandWrapper(CustomerDefs.loginCommandSenderId, CommandDescriptor.LOGIN_CUSTOMER, Serialization.serialize(new Login(username, password)))).serialize());
} catch (SocketTimeoutException e) {
log.fatal("Critical bug: failed to get respond from server");
throw new CriticalError();
}
terminateCommunication();
cmdwrppr = getCommandWrapper(serverResponse);
try {
resultDescriptorHandler(cmdwrppr.getResultDescriptor());
} catch (InvalidCommandDescriptor | InvalidParameter | CustomerNotConnected | ProductCatalogDoesNotExist | AmountBiggerThanAvailable | ProductPackageDoesNotExist | GroceryListIsEmpty | UsernameAlreadyExists | ForgotPasswordWrongAnswer ¢) {
log.fatal("Critical bug: this command result isn't supposed to return here");
throw new CriticalError();
}
id = cmdwrppr.getSenderID();
if (this instanceof RegisteredCustomer)
customerProfile = Serialization.deserialize(cmdwrppr.getData(), CustomerProfile.class);
//check for new product pictures asynchronous
if (updateProductPictures)
new UpdateProductPictures().start();
log.info("Customer Login to server as succeed. Client id is: " + id);
}
use of CustomerContracts.ACustomerExceptions.ProductCatalogDoesNotExist in project SmartCity-Market by TechnionYP5777.
the class Customer method logout.
@Override
public void logout() throws CustomerNotConnected, CriticalError {
String serverResponse;
log.info("Creating customer logout command wrapper with id: " + id);
establishCommunication(CustomerDefs.port, CustomerDefs.host, CustomerDefs.timeout);
try {
serverResponse = sendRequestWithRespondToServer((new CommandWrapper(id, CommandDescriptor.LOGOUT)).serialize());
} catch (SocketTimeoutException e) {
log.fatal("Critical bug: failed to get respond from server");
throw new CriticalError();
}
terminateCommunication();
try {
resultDescriptorHandler(getCommandWrapper(serverResponse).getResultDescriptor());
} catch (InvalidCommandDescriptor | InvalidParameter | ProductCatalogDoesNotExist | AmountBiggerThanAvailable | ProductPackageDoesNotExist | GroceryListIsEmpty | AuthenticationError | UsernameAlreadyExists | ForgotPasswordWrongAnswer ¢) {
log.fatal("Critical bug: this command result isn't supposed to return here");
throw new CriticalError();
}
customerProfile = null;
log.info("logout from server succeed.");
}
use of CustomerContracts.ACustomerExceptions.ProductCatalogDoesNotExist in project SmartCity-Market by TechnionYP5777.
the class Customer method resume.
@Override
public void resume(int _id) throws CriticalError, CustomerNotConnected {
CommandWrapper $ = null;
String serverResponse;
log.info("Creating customer Load grocery list command wrapper with id: " + id);
establishCommunication(CustomerDefs.port, CustomerDefs.host, CustomerDefs.timeout);
try {
serverResponse = sendRequestWithRespondToServer((new CommandWrapper(id, CommandDescriptor.LOAD_GROCERY_LIST)).serialize());
} catch (SocketTimeoutException e) {
log.fatal("Critical bug: failed to get respond from server");
throw new CriticalError();
}
terminateCommunication();
try {
$ = getCommandWrapper(serverResponse);
resultDescriptorHandler($.getResultDescriptor());
id = _id;
groceryList = Serialization.deserialize($.getData(), GroceryList.class);
} catch (InvalidCommandDescriptor | InvalidParameter | ProductCatalogDoesNotExist | AmountBiggerThanAvailable | ProductPackageDoesNotExist | GroceryListIsEmpty | AuthenticationError | UsernameAlreadyExists | ForgotPasswordWrongAnswer ¢) {
log.fatal("Critical bug: this command result isn't supposed to return here");
throw new CriticalError();
}
/* Restoring Grocery list */
try {
loadCartProductCacheAndUpdateCartData();
} catch (ProductCatalogDoesNotExist | CriticalError | CustomerNotConnected e) {
log.fatal("Critical bug: Failed to fetch grocery list items from server");
}
log.info("load grocery list from server succeed.");
}
Aggregations