Subversion Repositories SmartDukaan

Rev

Rev 9262 | Blame | Compare with Previous | Last modification | View Log | RSS feed

package in.shop2020.googleadwords.util;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import org.apache.thrift.TException;
import org.apache.thrift.transport.TTransportException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import adwords.axis.v201309.basicoperations.GetAdGroups;

import in.shop2020.googleadwords.AdwordsAdGroup;
import in.shop2020.googleadwords.AdwordsAdGroupStatus;
import in.shop2020.googleadwords.AdwordsCampaign;
import in.shop2020.googleadwords.GoogleAdwordsService.Client;
import in.shop2020.googleadwords.GoogleAdwordsServiceException;
import in.shop2020.thrift.clients.AdwordsClient;
/*
 * Class AdwordsSaholicAdGroupSync - To Sync Adgroups between Google Adwords and our Database.
 */
public class AdwordsSaholicAdGroupSync{
        private static Logger logger = LoggerFactory.getLogger(AdwordsSaholicAdGroupSync.class);
        
        public static void main(String[] args) {
                
                AdwordsClient adwordsServiceClient= null;
                try {
                        adwordsServiceClient = new AdwordsClient();
                } catch (TTransportException e1) {
                        e1.printStackTrace();
                }
                Client client = adwordsServiceClient.getClient();
                List<AdwordsCampaign> campaignList =null;
                try {
                        campaignList = client.getAllAdwordsCampaigns();
                } catch (GoogleAdwordsServiceException e1) {
                        System.out.println("Error while requesting All Campaigns Google Adwords Service.."+e1.getMessage());
                        logger.error("Error while requesting All Campaigns Google Adwords Service.."+e1.getMessage());
                } catch (TException e1) {
                        System.out.println("Error while getting All Campaigns Google Adwords Service.."+e1.getMessage());
                        logger.error("Error while getting All Campaigns Google Adwords Service.."+e1.getMessage());
                }
                
                List<Long> errorCampaigns = new ArrayList<Long>();
                for(AdwordsCampaign campaign: campaignList){
                        List<Map<String, String>> adgroupDataMainList =null;
                        try {
                                adgroupDataMainList = GetAdGroups.runExample(campaign.getCampaignId());
                        } catch (Exception e) {
                                System.out.println(e.getMessage());
                                errorCampaigns.add(campaign.getCampaignId());
                                continue;
                        }
                        if(adgroupDataMainList!=null){
                                for(int i=0; i<adgroupDataMainList.size();i++){
                                        
                                        Map<String, String> adgroupDataMap = adgroupDataMainList.get(i);
                                        if(adgroupDataMap!=null){
                                                if("DELETED".equalsIgnoreCase(adgroupDataMap.get("Status"))){
                                                        continue;
                                                }
                                                AdwordsAdGroup adgroupDB = null;
                                                try {
                                                        adgroupDB = client.getAdwordsAdGroupByAdGroupId(Long.parseLong(adgroupDataMap.get("AdgroupId")));
                                                } catch (NumberFormatException e1) {
                                                        System.out.println(e1.getMessage());
                                                } catch (GoogleAdwordsServiceException e1) {
                                                        System.out.println("Error while requesting Adgroup Google Adwords Service.."+e1.getMessage());
                                                        logger.error("Error while requesting Adgroup Google Adwords Service.."+e1.getMessage());
                                                } catch (TException e1) {
                                                        System.out.println("Error while getting Adgroup Google Adwords Service.."+e1.getMessage());
                                                        logger.error("Error while getting Adgroup Google Adwords Service.."+e1.getMessage());
                                                }
                                                AdwordsAdGroup adgroup = new AdwordsAdGroup();
                                                System.out.println(adgroupDataMap.get("CampaignId")+" "
                                                                +adgroupDataMap.get("Name")+" "
                                                                +adgroupDataMap.get("AdgroupId")+ " "
                                                                +adgroupDataMap.get("CatalogItemId")+" "+adgroupDataMap.get("BidAmount")+" "
                                                                +adgroupDataMap.get("Status"));
                                                adgroup.setCampaignId(Long.parseLong(adgroupDataMap.get("CampaignId")));
                                                
                                                adgroup.setAdgroupId(Long.parseLong(adgroupDataMap.get("AdgroupId")));
                                                adgroup.setCatalogItemId(Long.parseLong(adgroupDataMap.get("CatalogItemId")));
                                                double amount= Double.parseDouble(adgroupDataMap.get("BidAmount"));
                                                amount = amount * Math.pow(10, -6);
                                                adgroup.setBidAmount(amount);
                                                adgroup.setName(adgroupDataMap.get("Name"));
                                                AdwordsAdGroupStatus status;
                                                if("PAUSED".equalsIgnoreCase(adgroupDataMap.get("Status"))){
                                                        status= AdwordsAdGroupStatus.PAUSED;
                                                }
                                                else if("ENABLED".equalsIgnoreCase(adgroupDataMap.get("Status"))){
                                                        status= AdwordsAdGroupStatus.ENABLED;
                                                }
                                                else{
                                                        status= AdwordsAdGroupStatus.DELETED;
                                                }
                                                adgroup.setStatus(status);
                                                adgroup.setStockLinked(0);
                                                if(adgroupDB.getAdgroupId()>0l){
                                                        adgroup.setId(adgroupDB.getId());
                                                        try {
                                                                client.updateAdwordsAdGroup(adgroup);
                                                        } catch (GoogleAdwordsServiceException e) {
                                                                System.out.println("Error while Requesting Updation AdGroup Google Adwords Service.."+e.getMessage());
                                                                logger.error("Error while Requesting Updation AdGroup Google Adwords Service.."+e.getMessage());
                                                        } catch (TException e) {
                                                                System.out.println("Error while Updating AdGroup Google Adwords Service.."+e.getMessage());
                                                                logger.error("Error while Updating AdGroup Google Adwords Service.."+e.getMessage());
                                                        }
                                                }
                                                else{
                                                        try {
                                                                client.addAdwordsAdGroup(adgroup);
                                                        } catch (GoogleAdwordsServiceException e) {
                                                                System.out.println("Error while Requesting Addition AdGroup Google Adwords Service.."+e.getMessage());
                                                                logger.error("Error while Requesting Addition AdGroup Google Adwords Service.."+e.getMessage());
                                                        } catch (TException e) {
                                                                System.out.println("Error while Adding AdGroup Google Adwords Service.."+e.getMessage());
                                                                logger.error("Error while Adding AdGroup Google Adwords Service.."+e.getMessage());
                                                        }
                                                }
                                                
                                        }
                                }
                        }
                }
                
                System.out.println("$$$$$$$$$$$$$$$$$$ Error Campaigns List $$$$$$$$$$$$$$$$$$$$$$$$$");
                for(Long l : errorCampaigns){
                        System.out.println(l);
                }
                
        }
}