Subversion Repositories SmartDukaan

Rev

Blame | Last modification | View Log | RSS feed

package in.shop2020.inventory.controllers;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletContext;

import org.apache.commons.io.FileUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import in.shop2020.thrift.clients.WarehouseClient;
import in.shop2020.warehouse.WarehouseService.Client;

@SuppressWarnings("serial")
public class CheckGrnImeiController extends BaseController {
        private static Logger logger = LoggerFactory.getLogger(CheckGrnImeiController.class);
        private ServletContext context;
        private File checkImeiFile;
        private String errorMsg="";
        private String successMsg="";
        private String fileNameVal;

        public String create(){
                File fileToCreate = null;
                List<String> checkGrnImeiList = new ArrayList<String>();
                List<String> returnImeiStatusList = null;
                if(checkImeiFile!=null & fileNameVal !=null && !fileNameVal.isEmpty()){

                        logger.info("File Name "+checkImeiFile.getName());
                        System.out.println("File Name "+checkImeiFile.getName());

                        logger.info("File Name Value "+fileNameVal);
                        System.out.println("File Name Value "+fileNameVal);
                        String fileName = fileNameVal;
                        try {
                                if(!fileName.substring(fileName.lastIndexOf(".")+1).equalsIgnoreCase("txt")){
                                        throw new Exception("Not Again! File is not in expected TXT Format");
                                }
                                fileToCreate = new File("/tmp/", fileName);

                                FileUtils.copyFile(this.checkImeiFile, fileToCreate);
                        } catch (Exception e) {
                                logger.error("Hurray!! Error while writing file used to the local file system", e);
                                errorMsg = e.getMessage();
                                return "check-grn-imei";
                        }
                } else {
                        errorMsg = errorMsg + "<br>Folk, No File Uploaded or file name is blank";
                }

                if(fileToCreate==null){
                        errorMsg = errorMsg +" <br> No File to read";
                        return "check-grn-imei";
                }
                if(fileToCreate.isFile()){
                        try{
                                BufferedReader br = new BufferedReader(new FileReader(fileToCreate));
                                long line = 1;
                                String strLine;
                                String[] values;
                                while((strLine = br.readLine())!=null){
                                        if(line==1){
                                                values = strLine.split("\t");                                           
                                                if(values.length !=1){
                                                        errorMsg = errorMsg + " File contains Inappropriate Content ";
                                                        addActionError(errorMsg);
                                                        return create();
                                                }
                                                line++;
                                                continue;
                                        }
                                        values = strLine.split("\t");
                                        for(String s : values){
                                                logger.info("Row No "+line+" :"+s);
                                                System.out.println("Row No "+line+" :"+s);
                                        }
                                        checkGrnImeiList.add(values[0]);
                                        line++;
                                }
                                WarehouseClient warehouseClient = new WarehouseClient();
                                Client client = warehouseClient.getClient();
                                
                                if(checkGrnImeiList!=null && checkGrnImeiList.size()>0){
                                        returnImeiStatusList = client.checkGrnImeiStatus(checkGrnImeiList);
                                } else {
                                        errorMsg = errorMsg + " Buddy, there is no record to check";
                                }
                                
                                if(returnImeiStatusList!=null && returnImeiStatusList.size()>0){
                                        errorMsg = errorMsg + " Man, these imei are already resting in our system ";
                                        for(String imei : returnImeiStatusList){
                                                errorMsg = errorMsg + imei +" ";
                                        }
                                        return "check-grn-imei";
                                } else {
                                        successMsg = "Wow Man! You hit the jackpot. All are perfect.";
                                }
                                
                        }
                        catch(Exception e){
                                errorMsg = errorMsg + " <br> Error while checking Imeis Status";
                                logger.error(errorMsg, e);
                        }
                }

                return "check-grn-imei";
        }

        public String getServletContextPath() {
                return context.getContextPath();
        }

        public File getCheckImeiFile() {
                return checkImeiFile;
        }

        public void setCheckImeiFile(File checkImeiFile) {
                this.checkImeiFile = checkImeiFile;
        }

        public String getErrorMsg() {
                return errorMsg;
        }

        public void setErrorMsg(String errorMsg) {
                this.errorMsg = errorMsg;
        }

        public String getSuccessMsg() {
                return successMsg;
        }

        public void setSuccessMsg(String successMsg) {
                this.successMsg = successMsg;
        }

        public String getFileNameVal() {
                return fileNameVal;
        }

        public void setFileNameVal(String fileNameVal) {
                this.fileNameVal = fileNameVal;
        }

}