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);}}}