Subversion Repositories SmartDukaan

Rev

Rev 5374 | Rev 5397 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
457 rajveer 1
package in.shop2020.util;
2
 
1226 rajveer 3
import in.shop2020.metamodel.core.Bullet;
479 rajveer 4
import in.shop2020.metamodel.core.Entity;
1226 rajveer 5
import in.shop2020.metamodel.core.EntityState;
5396 amit.gupta 6
import in.shop2020.metamodel.core.EntityStatus;
3873 mandeep.dh 7
import in.shop2020.metamodel.core.EnumDataObject;
1226 rajveer 8
import in.shop2020.metamodel.core.Feature;
479 rajveer 9
import in.shop2020.metamodel.core.FreeformContent;
5370 amit.gupta 10
import in.shop2020.metamodel.core.Media;
11
import in.shop2020.metamodel.core.Media.Type;
1226 rajveer 12
import in.shop2020.metamodel.core.PrimitiveDataObject;
479 rajveer 13
import in.shop2020.metamodel.core.Slide;
580 rajveer 14
import in.shop2020.metamodel.definitions.BulletDefinition;
457 rajveer 15
import in.shop2020.metamodel.definitions.Catalog;
580 rajveer 16
import in.shop2020.metamodel.definitions.Category;
17
import in.shop2020.metamodel.definitions.CategorySlideDefinition;
457 rajveer 18
import in.shop2020.metamodel.definitions.DefinitionsContainer;
580 rajveer 19
import in.shop2020.metamodel.definitions.FeatureDefinition;
20
import in.shop2020.metamodel.definitions.SlideDefinition;
21
import in.shop2020.metamodel.definitions.SlideFeatureDefinition;
479 rajveer 22
import in.shop2020.metamodel.util.CreationUtils;
2720 mandeep.dh 23
import in.shop2020.metamodel.util.ExpandedBullet;
1739 rajveer 24
import in.shop2020.metamodel.util.ExpandedEntity;
2287 rajveer 25
import in.shop2020.model.v1.catalog.InventoryService.Client;
26
import in.shop2020.model.v1.catalog.Item;
27
import in.shop2020.model.v1.catalog.status;
3127 rajveer 28
import in.shop2020.thrift.clients.CatalogClient;
4706 amit.gupta 29
import in.shop2020.utils.Logger;
457 rajveer 30
 
2720 mandeep.dh 31
import java.io.BufferedReader;
5370 amit.gupta 32
import java.io.ByteArrayInputStream;
33
import java.io.ByteArrayOutputStream;
2720 mandeep.dh 34
import java.io.DataInputStream;
35
import java.io.File;
36
import java.io.FileInputStream;
5370 amit.gupta 37
import java.io.FileOutputStream;
38
import java.io.InputStream;
2720 mandeep.dh 39
import java.io.InputStreamReader;
5370 amit.gupta 40
import java.io.ObjectInputStream;
41
import java.io.ObjectOutputStream;
42
import java.io.OutputStream;
2720 mandeep.dh 43
import java.util.ArrayList;
5370 amit.gupta 44
import java.util.Collection;
3873 mandeep.dh 45
import java.util.Collections;
4706 amit.gupta 46
import java.util.HashMap;
2720 mandeep.dh 47
import java.util.List;
48
import java.util.Map;
49
import java.util.TreeMap;
580 rajveer 50
 
5370 amit.gupta 51
import org.apache.commons.io.IOUtils;
4818 amit.gupta 52
import org.apache.commons.lang.StringUtils;
53
 
457 rajveer 54
/*
55
 * @author rajveer 
56
 * 
57
 *
58
 */
59
 
60
public class ContentMigrator {
61
	private String sourceDbPath;
62
	private String destinationDbPath;
4964 amit.gupta 63
 
457 rajveer 64
	public static void main(String[] args) throws Exception {
65
		String usage = "Usage: ContentMigrator {source db path}{destination db path}";
4964 amit.gupta 66
 
67
		String sourceDbPath = null, destinationDbPath = null;
68
		String dryRun = null;
69
		// if(args.length < 2) {
70
		// System.out.println(usage);
71
		// System.exit(-1);
72
		// }else{
73
		// sourceDbPath = args[0];
74
		// destinationDbPath = args[1];
75
		// dryRun = args[2];
76
		// }
77
		//
5281 amit.gupta 78
		ContentMigrator contentmigrator = new ContentMigrator(sourceDbPath,destinationDbPath);
5396 amit.gupta 79
		contentmigrator.migrateHeadSetBack();
5281 amit.gupta 80
		//contentmigrator.renameTitles();
4964 amit.gupta 81
		// contentmigrator.migrateWarrantyType();
82
		// CreationUtils.storeComparisonStats(null);n
83
		// contentmigrator.migrateMedia();
84
		// contentmigrator.populateHelpdocEntityIds();
85
		// contentmigrator.migrateDataBack();
86
		// contentmigrator.migrateBrandModel(dryRun);
87
		// contentmigrator.migrateData();
88
		// contentmigrator.migrateRemoveBorrowedCategoryIdFromSlide();
89
		// contentmigrator.migrateModel1();
90
		// contentmigrator.changeEntityState();
91
		// contentmigrator.removeBrowserBullets();
92
		// contentmigrator.migrateModel2();
93
		// contentmigrator.printDataModel();
94
		// contentmigrator.makeEntitiesObject();
95
		// contentmigrator.printSlides();
1739 rajveer 96
		/*
4964 amit.gupta 97
		 * DefinitionsContainer dfc =
98
		 * Catalog.getInstance().getDefinitionsContainer(); for(Long fid:
99
		 * dfc.getCategoryFacetDefinitions().keySet()){ for(FacetDefinition
100
		 * facetDef:
101
		 * dfc.getCategoryFacetDefinitions().get(fid).getFacetDefinitions()){
102
		 * System.out.println("***" + fid + " *** " + facetDef.getID() +
103
		 * facetDef.getTarget() ); }
104
		 * 
105
		 * }
106
		 */
107
 
108
		// System.out.println("**********" + dfc.getCategoryFacetDefinitions());
109
		// System.out.println("**********" + dfc.getSlideFacetDefinitions());
110
 
111
		/*
112
		 * for(Long defID : dfc.getSlideFacetDefinitions().keySet()){
113
		 * for(FacetDefinition facetDef:
114
		 * dfc.getSlideFacetDefinitions().get(defID)){ System.out.println(defID
115
		 * + "****" + facetDef.getID() + facetDef.getDescription()); }
116
		 * 
117
		 * }
118
		 */
119
 
120
		/*
121
		 * System.out.println(OldCreationUtils.getSlideSequence(1000194));
122
		 * List<Slide> slides = OldCreationUtils.getEntity(1000194).getSlides();
123
		 * for(Slide slide: slides){
124
		 * System.out.println(slide.getSlideDefinitionID()); }
125
		 */
126
 
127
		// ContentMigrator contentmigrator = new ContentMigrator(sourceDbPath,
128
		// destinationDbPath);
129
		// boolean result = contentmigrator.migrate();
130
		// System.out.println("Content migration status:  "+ result);
131
 
132
	}
133
 
134
	private void renameTitles() throws Exception {
135
		Map<Long, Entity> map = CreationUtils.getEntities();
136
		for (Long entityId : map.keySet()) {
137
			Entity entity = map.get(entityId);
138
			if (entity == null || entity.getSlides() == null) {
139
				continue;
1314 rajveer 140
			}
141
 
4964 amit.gupta 142
 
143
			String brand = entity.getBrand();
144
			String modelName = entity.getModelName();
145
			String modelNumber = entity.getModelNumber();
146
			String value = "";
147
			if(StringUtils.isEmpty(modelName)){
148
				value = brand + " " + modelNumber + " Price in India | Specifications, Features and Reviews";
149
			}else {
150
				value = brand + " " + modelName + " Price in India | " + modelNumber + " Specifications, Features and Reviews";
1314 rajveer 151
			}
152
 
4964 amit.gupta 153
			Slide summarySlide = entity.getSlide(130054);
154
			if(summarySlide != null){
155
				for(Feature f : summarySlide.getFeatures()){
156
					if (f.getFeatureDefinitionID()==120132){
157
						List<Bullet> bulletList = f.getBullets();
158
						for (Bullet b : bulletList) {
159
							b.setDataObject(new PrimitiveDataObject(value));
160
						}
161
						CreationUtils.updateEntity(entity);
162
						continue;
163
					}
164
				}
165
			}
1314 rajveer 166
		}
457 rajveer 167
	}
168
 
4818 amit.gupta 169
	private void migrateNetwork() throws Exception {
170
		Map<Long, Entity> map = CreationUtils.getEntities();
4964 amit.gupta 171
		for (Long entityId : map.keySet()) {
172
			Entity entity = map.get(entityId);
173
			if (entity == null || entity.getSlides() == null) {
174
				continue;
175
			}
4818 amit.gupta 176
 
4964 amit.gupta 177
			for (Slide slide : entity.getSlides()) {
5281 amit.gupta 178
				if (slide.getSlideDefinitionID() == 130095) {
179
					List<Slide> slides = slide.getChildrenSlides();
180
					for(Slide slide1  : slides){
181
						if(slide1.getSlideDefinitionID() == 130096){							
182
							List<Feature> features = slide1.getFeatures();
183
							for (Feature f : features) {
184
								if (f.getFeatureDefinitionID() == 120175) {
185
									List<Bullet> bs = f.getBullets();
186
									for (Bullet b : bs) {
187
										Long enumValueId = ((EnumDataObject) b
188
												.getDataObject()).getEnumValueID();
189
										String value = Catalog.getInstance().getDefinitionsContainer().getEnumValue(enumValueId).getValue(); 
190
										if (value.trim().equals("")) {
191
											continue;
192
										}
193
										System.out.println(value);
194
 
195
									}
4964 amit.gupta 196
								}
197
							}
198
						}
199
					}
200
				}
201
 
202
			}
203
 
204
			CreationUtils.updateEntity(entity);
205
		}
4818 amit.gupta 206
	}
5370 amit.gupta 207
	private void migrateHeadSet() throws Exception {
208
 
209
		//Starting entity id for new Category with 10000
210
		long newCounter = 77777000;
211
		Collection<Entity> entities = CreationUtils.getEntities(10015);
212
 
213
		//entities = (List<Entity>)this.clone(entities);
214
		for (Entity entity : entities) {
215
			long entityId = entity.getID();
216
			try {
217
				List<Slide> entitySlides = entity.getSlides();
218
				if (entity == null || entitySlides == null) {
219
					continue;
220
				}
221
				Slide summarySlide = null;
222
				FreeformContent ffc = null;
223
 
224
				List<Slide> newEntitySlides = new ArrayList<Slide>(); 
225
				Slide connectivitySlide = new Slide(130129);
226
				Slide looknfeelSlide = new Slide(130128);
227
				for (Slide slide : entitySlides) {
228
					slide=(Slide)this.clone(slide);
229
					if (slide.getSlideDefinitionID() == 130068) {
230
						List<Feature> connectivityFeatures = new ArrayList<Feature>();
231
						List<Feature> looknfeelFeatures = new ArrayList<Feature>();
232
						List<Feature> features = slide.getFeatures();
233
						for (Feature f : features) {
234
							if (f.getFeatureDefinitionID() == 120105) {
235
								connectivityFeatures.add(f);
236
							}
237
							if (f.getFeatureDefinitionID() == 120106) {
238
								looknfeelFeatures.add(f);
239
							}
240
						}
241
						ffc = slide.getFreeformContent();
242
						if(ffc != null){
243
							Map<String, Media> mediaMap = ffc.getMedias();
244
							if(mediaMap!=null){
245
								for(Media media : mediaMap.values()){
246
									if(media.getType().equals(Type.IMAGE) || media.getType().equals(Type.DOCUMENT)){
247
										copyMedia(String.valueOf(newCounter), String.valueOf(entityId),media);
248
									}
249
								}
250
							}
251
						}
252
						connectivitySlide.setFeatures(connectivityFeatures);
253
						looknfeelSlide.setFeatures(looknfeelFeatures);
254
						looknfeelSlide.setFreeformContent(ffc);
255
					} 
256
					//Summary slide
257
					if(slide.getSlideDefinitionID() == 130054) {
258
						summarySlide = slide; 
259
						FreeformContent ffc1 = slide.getFreeformContent();
260
						if(ffc1 != null){
261
							Map<String, Media> mediaMap = ffc1.getMedias();
262
							if(mediaMap==null){
263
								continue;
264
							}
265
							for(Media media : mediaMap.values()){
266
								if(media.getType().equals(Type.IMAGE) || media.getType().equals(Type.DOCUMENT)){
267
									copyMedia(String.valueOf(newCounter), String.valueOf(entityId),media);
268
								}
269
							}
270
						}
271
					}
272
 
273
				}
274
 
275
				Entity newEntity = new Entity(newCounter, 10099);
5374 amit.gupta 276
				List<Long> newSlideSequence = new ArrayList<Long>();
277
				newSlideSequence.add(130128L);
278
				newSlideSequence.add(130129L);
279
				newSlideSequence.add(130054L);
280
				newEntity.setSlideSequence(newSlideSequence);
5370 amit.gupta 281
				newEntity.setBrand(entity.getBrand());
282
				newEntity.setModelName(entity.getModelName());
283
				newEntity.setModelNumber(entity.getModelNumber());
284
				//entitySlides.remove(featureSlide);
285
				newEntitySlides.add(connectivitySlide);
286
				newEntitySlides.add(looknfeelSlide);
287
				newEntitySlides.add(summarySlide);
288
				newEntity.setSlides(newEntitySlides);
289
				EntityState es = new EntityState(newCounter, 10099, "admin");
290
				es.setBrand(entity.getBrand());
291
				es.setModelName(entity.getModelName());
292
				es.setModelNumber(entity.getModelNumber());
293
				CreationUtils.createEntity(newEntity, es);
294
				System.out.println("New entity : " + newCounter + " created using : " + entityId);
295
				System.out.println(CreationUtils.getEntity(newCounter));
296
				newCounter++;
297
			}catch(Exception e){
298
				System.out.println("Could not migrate " + entityId);
299
			}
300
		}
301
 
302
	}
4818 amit.gupta 303
 
304
	private long getEnumValueForNetwork(String value, Long entityLong) {
305
		value = value.toLowerCase().replaceAll(" ", "");
306
		Map<String, Long> map = new HashMap<String, Long>();
4964 amit.gupta 307
		map.put("quadband(gsm850/900/1800/1900)", 110382L);
4818 amit.gupta 308
		map.put("quadband(gsm850/900/1800/1900)-sim1", 110383l);
309
		map.put("quadband(gsm850/900/1800/1900)-sim2", 110384l);
310
		map.put("triband(gsm900/1800/1900)", 110385l);
311
		map.put("triband(gsm900/1800/1900)-sim1", 110386l);
312
		map.put("triband(gsm900/1800/1900)-sim2", 110387l);
313
		map.put("dualband(gsm900/1800)", 110388l);
314
		map.put("dualband(gsm900/1800)-sim1", 110389l);
315
		map.put("dualband(gsm900/1800)-sim2", 110390l);
4964 amit.gupta 316
		map.put("cdma800", 110391l); // CDMA 800
317
		map.put("cdma800-sim2", 110392l); // CDMA 800-SIM 2
318
		map.put("cdma800-sim3", 110393l); // CDMA 800-SIM 3
319
 
320
		if (!StringUtils.contains(value, "sim")
321
				&& StringUtils.contains(value, "850/900/1800/1900")) {
4818 amit.gupta 322
			return map.get("quadband(gsm850/900/1800/1900)");
323
		}
4964 amit.gupta 324
		if (StringUtils.contains(value, "sim1")
325
				&& StringUtils.contains(value, "850/900/1800/1900")) {
4818 amit.gupta 326
			return map.get("quadband(gsm850/900/1800/1900)-sim1");
327
		}
4964 amit.gupta 328
		if (StringUtils.contains(value, "sim2")
329
				&& StringUtils.contains(value, "850/900/1800/1900")) {
4818 amit.gupta 330
			return map.get("quadband(gsm850/900/1800/1900)-sim2");
331
		}
4964 amit.gupta 332
		if (!StringUtils.contains(value, "sim")
333
				&& StringUtils.contains(value, "900/1800/1900")) {
4818 amit.gupta 334
			return map.get("triband(gsm900/1800/1900)");
335
		}
4964 amit.gupta 336
		if (StringUtils.contains(value, "sim1")
337
				&& StringUtils.contains(value, "900/1800/1900")) {
4818 amit.gupta 338
			return map.get("triband(gsm900/1800/1900)-sim1");
339
		}
4964 amit.gupta 340
		if (StringUtils.contains(value, "sim2")
341
				&& StringUtils.contains(value, "900/1800/1900")) {
4818 amit.gupta 342
			return map.get("triband(gsm900/1800/1900)-sim2");
343
		}
4964 amit.gupta 344
		if (!StringUtils.contains(value, "sim")
345
				&& StringUtils.contains(value, "900/1800")) {
4818 amit.gupta 346
			return map.get("dualband(gsm900/1800)");
347
		}
4964 amit.gupta 348
		if (StringUtils.contains(value, "sim1")
349
				&& StringUtils.contains(value, "900/1800")) {
4818 amit.gupta 350
			return map.get("dualband(gsm900/1800)-sim1");
351
		}
4964 amit.gupta 352
		if (StringUtils.contains(value, "sim2")
353
				&& StringUtils.contains(value, "900/1800")) {
4818 amit.gupta 354
			return map.get("dualband(gsm900/1800)-sim2");
355
		}
4964 amit.gupta 356
		if (StringUtils.contains(value, "cdma")) {
357
			if (StringUtils.contains(value, "sim2")) {
4818 amit.gupta 358
				return map.get("cdma800-sim2");
359
			}
4964 amit.gupta 360
			if (StringUtils.contains(value, "sim3")) {
4818 amit.gupta 361
				return map.get("cdma800-sim3");
362
			}
363
			return map.get("cdma800");
4964 amit.gupta 364
		} else {
365
			System.out.println("Unknown networks: " + value + " : "
366
					+ entityLong);
4818 amit.gupta 367
			return 0;
368
		}
369
	}
370
 
457 rajveer 371
	public ContentMigrator(String sourceDbPath, String destinationDbPath) {
4964 amit.gupta 372
		this.sourceDbPath = sourceDbPath;
457 rajveer 373
		this.destinationDbPath = destinationDbPath;
374
	}
2720 mandeep.dh 375
 
3873 mandeep.dh 376
	public void migrateWarrantyType() throws Exception {
4964 amit.gupta 377
		Map<Long, Entity> map = CreationUtils.getEntities();
378
		for (Long entityId : map.keySet()) {
379
			Entity entity = map.get(entityId);
380
			if (entity == null || entity.getSlides() == null) {
381
				continue;
382
			}
383
			for (Slide slide : entity.getSlides()) {
384
				if (slide.getSlideDefinitionID() == 130054) {
385
					Slide warrantySlide = new Slide(130105);
386
					warrantySlide.setFeatures(new ArrayList<Feature>());
3873 mandeep.dh 387
 
4964 amit.gupta 388
					Feature feature = new Feature(120219);
389
					feature.setBullets(Collections.singletonList(new Bullet(
390
							new EnumDataObject(110299))));
391
					warrantySlide.getFeatures().add(feature);
3873 mandeep.dh 392
 
4964 amit.gupta 393
					Feature existingWarrantyFeature = null;
394
					for (Feature summaryFeature : slide.getFeatures()) {
395
						if (summaryFeature.getFeatureDefinitionID() == 120125) {
396
							existingWarrantyFeature = summaryFeature;
397
							warrantySlide.getFeatures().add(summaryFeature);
398
							break;
399
						}
400
					}
3873 mandeep.dh 401
 
4964 amit.gupta 402
					slide.getFeatures().remove(existingWarrantyFeature);
403
					slide.addChild(warrantySlide);
404
					break;
405
				}
406
 
407
			}
408
 
409
			CreationUtils.updateEntity(entity);
410
		}
3873 mandeep.dh 411
	}
412
 
2720 mandeep.dh 413
	public void migrateMedia() throws Exception {
4964 amit.gupta 414
		Map<Long, Entity> map = CreationUtils.getEntities();
415
		for (Long entityId : map.keySet()) {
416
			Entity entity = map.get(entityId);
417
			if (entity == null || entity.getSlides() == null) {
418
				continue;
419
			}
420
			for (Slide slide : entity.getSlides()) {
421
				FreeformContent ffc = slide.getFreeformContent();
2720 mandeep.dh 422
 
4964 amit.gupta 423
				// if (ffc == null || ffc.getMediasNew() == null) {
424
				// continue;
425
				// }
426
				//
427
				// Map<String, Media> newMap = new LinkedHashMap<String,
428
				// Media>();
429
				// Media media = null;
430
				// for (String label : ffc.getMediasNew().keySet()) {
431
				// MediaNew m = ffc.getMediasNew().get(label);
432
				// media = new Media(m.getLabel(), Media.Type.valueOf(m
433
				// .getType().name()), m.getLocation());
434
				// media.setTitle(m.getTitle());
435
				// media.setFileName(m.getFileName());
436
				// newMap.put(label, media);
437
				// }
438
				// ffc.setMedias(newMap);
439
				// ffc.setMediasNew(null);
2720 mandeep.dh 440
 
4964 amit.gupta 441
				// if (ffc == null || ffc.getMedias() == null) {
442
				// continue;
443
				// }
444
				// Map<String, MediaNew> newMap = new LinkedHashMap<String,
445
				// MediaNew>();
446
				// MediaNew mediaNew = null;
447
				// for (String label : ffc.getMedias().keySet()) {
448
				// Media m = ffc.getMedias().get(label);
449
				// if (m.getType().equalsIgnoreCase("image")) {
450
				// mediaNew = new MediaNew(m.getLabel(),
451
				// MediaNew.Type.IMAGE, m.getLocation());
452
				// mediaNew.setFileName(m.getFileName());
453
				// } else if (m.getType().equalsIgnoreCase("youtube")) {
454
				// if (m.getVideoType().equalsIgnoreCase("withskin")) {
455
				// mediaNew = new MediaNew(m.getLabel(),
456
				// MediaNew.Type.VIDEO_WITH_SKIN,
457
				// m.getLocation());
458
				// } else {
459
				// mediaNew = new MediaNew(m.getLabel(),
460
				// MediaNew.Type.VIDEO_WITHOUT_SKIN,
461
				// m.getLocation());
462
				// }
463
				// }
464
				//
465
				// if (mediaNew != null) {
466
				// mediaNew.setTitle(m.getTitle());
467
				// newMap.put(label, mediaNew);
468
				// }
469
				// }
470
				// ffc.setMediasNew(newMap);
471
				// ffc.setMedias(null);
472
			}
473
			CreationUtils.updateEntity(entity);
474
		}
2720 mandeep.dh 475
	}
476
 
4964 amit.gupta 477
	public boolean populateHelpdocEntityIds() throws Exception {
478
		for (Entity entity : CreationUtils.getEntities().values()) {
2471 rajveer 479
			CreationUtils.updateEntity(entity);
480
		}
481
		return true;
482
	}
2720 mandeep.dh 483
 
4964 amit.gupta 484
	public boolean migrateBrandModel(String dryRun) throws Exception {
3127 rajveer 485
		CatalogClient catalogServiceClient = new CatalogClient();
2287 rajveer 486
		Client client = catalogServiceClient.getClient();
487
		List<Item> items = client.getAllItemsByStatus(status.ACTIVE);
488
		items.addAll(client.getAllItemsByStatus(status.PAUSED));
489
		items.addAll(client.getAllItemsByStatus(status.CONTENT_COMPLETE));
490
		Map<Long, Entity> entities = CreationUtils.getEntities();
491
		long count = 0;
492
		StringBuffer sb = new StringBuffer();
4964 amit.gupta 493
		for (Item item : items) {
2287 rajveer 494
			long entityId = item.getCatalogItemId();
495
			Entity entity = entities.get(entityId);
4964 amit.gupta 496
			if (entity == null) {
2292 rajveer 497
				continue;
498
			}
2294 rajveer 499
			String itemBrand = item.getBrand().trim();
2287 rajveer 500
			String itemModelName = item.getModelName();
4964 amit.gupta 501
			if (itemModelName != null) {
2294 rajveer 502
				itemModelName = itemModelName.trim();
503
			}
504
			String itemModelNumber = item.getModelNumber().trim();
505
			String entityBrand = entity.getBrand().trim();
506
			String entityModelName = entity.getModelName().trim();
4964 amit.gupta 507
			if (entityModelName != null) {
2294 rajveer 508
				entityModelName = entityModelName.trim();
509
			}
510
			String entityModelNumber = entity.getModelNumber().trim();
4964 amit.gupta 511
 
512
			if (itemBrand.equals(entityBrand)
513
					&& itemModelNumber.equals(entityModelNumber)) {
514
				if (itemModelName != null && entityModelName != null
515
						&& itemModelName.equals(entityModelName)) {
2292 rajveer 516
					continue;
4964 amit.gupta 517
				} else if (itemModelName == null && entityModelName == null) {
518
					continue;
2292 rajveer 519
				}
4964 amit.gupta 520
 
2287 rajveer 521
			}
522
			count++;
4964 amit.gupta 523
			sb.append(count + ") Item:   " + itemBrand + "\t" + itemModelName
524
					+ "\t" + itemModelNumber + "\t" + item.getId() + "\n");
525
			sb.append(count + ") Entity: " + entityBrand + "\t"
526
					+ entityModelName + "\t" + entityModelNumber + "\t"
527
					+ entity.getID() + "\n");
528
 
529
			if (dryRun.equals("false")) {
2294 rajveer 530
				item.setBrand(entityBrand);
531
				item.setModelName(entityModelName);
532
				item.setModelNumber(entityModelNumber);
4964 amit.gupta 533
				client.updateItem(item);
2287 rajveer 534
			}
535
		}
536
		System.out.println(sb.toString());
537
		return true;
538
	}
2720 mandeep.dh 539
 
473 rajveer 540
	/**
4964 amit.gupta 541
	 * this function will read source definition and source entities, and will
542
	 * convert source entities to destination entities according to destination
543
	 * definitions.
473 rajveer 544
	 * 
545
	 * @return boolean
4964 amit.gupta 546
	 * @throws Exception
473 rajveer 547
	 */
1226 rajveer 548
 
4964 amit.gupta 549
	public void printSlides() throws Exception {
550
		DefinitionsContainer defc = Catalog.getInstance()
551
				.getDefinitionsContainer();
552
		for (Category category : defc.getCategories().values()) {
553
			if (category.getChildrenCategory() != null)
554
				continue;
555
			System.out.println(category.getID() + "\t" + category.getLabel());
556
			for (CategorySlideDefinition defs : defc
557
					.getCategorySlideDefinitions(category.getID())) {
558
				System.out.println(defs.getSlideDefintionID()
559
						+ "\t"
560
						+ defs.getEditorialImportance()
561
						+ "\t"
562
						+ defc.getSlideDefinition(defs.getSlideDefintionID())
563
								.getLabel()
564
						+ "\t"
565
						+ defc.getSlideDefinition(defs.getSlideDefintionID())
566
								.getChildrenSlideDefinitionIDs());
1226 rajveer 567
			}
568
		}
569
	}
4964 amit.gupta 570
 
571
	public void removeBrowserBullets() throws Exception {
572
		Map<Long, List<ExpandedBullet>> learnedBullets = CreationUtils
573
				.getLearnedBullets();
1226 rajveer 574
		learnedBullets.get(new Long(120076));
575
		learnedBullets.remove(new Long(120076));
576
		CreationUtils.storeLearnedBullets(learnedBullets);
4964 amit.gupta 577
 
1226 rajveer 578
	}
4964 amit.gupta 579
 
580
	public boolean changeEntityState() throws Exception {
1226 rajveer 581
		Map<Long, EntityState> entitiesState = CreationUtils.getEntitiesState();
4964 amit.gupta 582
		for (Long entityId : entitiesState.keySet()) {
1226 rajveer 583
			EntityState state = entitiesState.get(entityId);
4964 amit.gupta 584
			if (state.getCategoryID() == 10002
585
					|| state.getCategoryID() == 10003
586
					|| state.getCategoryID() == 10004
587
					|| state.getCategoryID() == 10005) {
1226 rajveer 588
				state.setCompletedBy("");
589
				state.setMerkedReadyBy("");
4964 amit.gupta 590
				// state.setStatus(EntityStatus.ASSIGNED);
591
				// CreationUtils.updateEntityState(state);
1226 rajveer 592
				System.out.println(entityId + ":" + state.getStatus());
593
			}
594
			CreationUtils.updateEntityState(state);
595
		}
596
		return true;
597
	}
1739 rajveer 598
 
4964 amit.gupta 599
	public boolean migrateDataBack() throws Exception {
1226 rajveer 600
		Map<Long, Entity> entities = CreationUtils.getEntities();
4964 amit.gupta 601
		for (Entity entity : entities.values()) {
602
			if (entity == null) {
603
				continue;
604
			}
1226 rajveer 605
			List<Slide> slides = entity.getSlides();
4964 amit.gupta 606
			if (slides != null) {
607
				for (Slide slide : slides) {
608
					if (slide.getSlideDefinitionID() == 130054) {
609
						List<Feature> features = slide.getFeatures();
610
						int length = features.size();
611
						features.remove(length - 1);
612
						features.remove(length - 2);
613
						features.remove(length - 3);
614
						/*
615
						 * boolean a = false,b=false,c=false; for(Feature
616
						 * feature: features){ switch
617
						 * ((int)feature.getFeatureDefinitionID()) { case
618
						 * 120132: if(a){
619
						 * 
620
						 * }else{ a=true; } break; case 120133: break; case
621
						 * 120134: break; default: break; } }
622
						 */
623
						CreationUtils.updateEntity(entity);
1226 rajveer 624
					}
625
				}
626
			}
627
		}
4964 amit.gupta 628
		return true;
1226 rajveer 629
	}
4964 amit.gupta 630
 
631
	public boolean migrateData() throws Exception {
1226 rajveer 632
		Map<Long, Entity> entities = CreationUtils.getEntities();
4964 amit.gupta 633
		for (Entity entity : entities.values()) {
634
			ExpandedEntity expEntity = new ExpandedEntity(entity);
1226 rajveer 635
			List<Slide> slides = entity.getSlides();
4964 amit.gupta 636
			if (slides != null) {
637
				for (Slide slide : slides) {
638
					if (slide.getSlideDefinitionID() == 130054) {
639
						List<Feature> features = slide.getFeatures();
640
						String title = expEntity.getBrand() + " "
641
								+ expEntity.getModelName() + " "
642
								+ expEntity.getModelNumber();
643
						if (expEntity.getCategory().getParentCategory().getID() == 10001) {
644
							title += " | " + expEntity.getBrand()
645
									+ " Mobile Phones";
1226 rajveer 646
						}
4964 amit.gupta 647
						if (expEntity.getCategory().getParentCategory().getID() == 10011) {
648
							title += " " + expEntity.getCategory().getLabel()
649
									+ " | " + expEntity.getBrand()
650
									+ " Mobile Phone Accessories";
1226 rajveer 651
						}
4964 amit.gupta 652
						title += " | Saholic.com";
653
 
654
						// Add page title
655
						Feature feature1 = new Feature(120132);
656
						PrimitiveDataObject pdo1 = new PrimitiveDataObject(
657
								title);
658
						List<Bullet> bullets1 = new ArrayList<Bullet>();
659
						Bullet bullet1 = new Bullet(pdo1);
660
						bullets1.add(bullet1);
661
						feature1.setBullets(bullets1);
662
						features.add(feature1);
663
 
664
						String description = "Best Price "
665
								+ expEntity.getBrand() + " "
666
								+ expEntity.getModelName() + " "
667
								+ expEntity.getModelNumber() + " ";
668
 
669
						if (expEntity.getCategory().getParentCategory().getID() == 10011) {
670
							description += expEntity.getCategory().getLabel()
671
									+ " in India.";
672
						} else {
673
							description += ".";
1226 rajveer 674
						}
4964 amit.gupta 675
						description += " Experience n' buy online. FREE Next Day delivery."
676
								+ " Original product - Full manufacturer warranty. Comprehensive reviews.";
1226 rajveer 677
 
4964 amit.gupta 678
						description = description.replaceAll("--", "-");
679
 
680
						// Add meta description
681
						Feature feature2 = new Feature(120133);
682
						PrimitiveDataObject pdo2 = new PrimitiveDataObject(
683
								description);
684
						List<Bullet> bullets2 = new ArrayList<Bullet>();
685
						Bullet bullet2 = new Bullet(pdo2);
686
						bullets2.add(bullet2);
687
						feature2.setBullets(bullets2);
688
 
689
						features.add(feature2);
690
 
691
						String keywords = expEntity.getBrand() + " "
692
								+ expEntity.getModelName() + " "
693
								+ expEntity.getModelNumber() + ", ";
694
						if (expEntity.getCategory().getParentCategory().getID() == 10001) {
695
							keywords += expEntity.getBrand()
696
									+ " mobile phones, ";
1226 rajveer 697
						}
4964 amit.gupta 698
						if (expEntity.getCategory().getParentCategory().getID() == 10011) {
699
							keywords += "phone accessories, ";
1226 rajveer 700
						}
4964 amit.gupta 701
						keywords += expEntity.getBrand() + " "
702
								+ expEntity.getModelName() + " "
703
								+ expEntity.getModelNumber() + " Price, ";
704
						keywords += expEntity.getBrand() + " "
705
								+ expEntity.getModelName() + " "
706
								+ expEntity.getModelNumber() + " India, ";
707
						if (expEntity.getCategory().getParentCategory().getID() == 10001) {
708
							keywords += expEntity.getBrand() + " "
709
									+ expEntity.getModelName() + " "
710
									+ expEntity.getModelNumber() + " Review, ";
1226 rajveer 711
						}
4964 amit.gupta 712
						// Add meta keyborad
713
						Feature feature3 = new Feature(120134);
714
						PrimitiveDataObject pdo3 = new PrimitiveDataObject(
715
								keywords);
716
						List<Bullet> bullets3 = new ArrayList<Bullet>();
717
						Bullet bullet3 = new Bullet(pdo3);
718
						bullets3.add(bullet3);
719
						feature3.setBullets(bullets3);
720
 
721
						features.add(feature3);
722
 
723
						CreationUtils.updateEntity(entity);
724
					}
725
				}
726
			}
727
		}
728
		return true;
729
	}
730
 
731
	public boolean migrateModel2() throws Exception {
732
		Map<Long, Entity> entities = CreationUtils.getEntities();
733
		for (Entity entity : entities.values()) {
734
			List<Slide> slides = entity.getSlides();
735
			if (slides != null) {
736
				for (Slide slide : slides) {
737
					if (slide.getSlideDefinitionID() == 130011) {
738
						for (Feature feature : slide.getFeatures()) {
739
							if (feature.getFeatureDefinitionID() == 120054) {
740
								// feature.setFeatureDefinitionID(120030);
741
								System.out.println("* " + entity.getID() + ":"
742
										+ entity.getCategoryID());
1226 rajveer 743
							}
744
						}
4964 amit.gupta 745
					}
1226 rajveer 746
 
4964 amit.gupta 747
					if (slide.getSlideDefinitionID() == 130029) {
748
						// System.out.println("** " + entity.getID() + ":" +
749
						// entity.getCategoryID());
750
						if (entity.getCategoryID() == 10002) {
751
							Feature feature = new Feature(120051);
752
							slide.getFeatures().add(feature);
753
							System.out.println("** " + entity.getID() + ":"
754
									+ entity.getCategoryID());
1226 rajveer 755
						}
756
					}
757
 
758
				}
759
			}
4964 amit.gupta 760
			CreationUtils.updateEntity(entity);
1226 rajveer 761
		}
762
		return true;
763
	}
4964 amit.gupta 764
 
765
	/*
766
	 * public boolean migrateModel1() throws Exception{ //DefinitionsContainer
767
	 * oldDfc = new DefinitionsContainer(Utils.CONTENT_DB_PATH +
768
	 * "olddefinitions" + File.separator); //DefinitionsContainer newDfc = new
769
	 * DefinitionsContainer(Utils.CONTENT_DB_PATH + "olddefinitions" +
770
	 * File.separator);
771
	 * 
772
	 * Map<Long, Entity> entities = CreationUtils.getEntities(); for(Entity
773
	 * entity: entities.values()){ List<Long> slideSequence =
774
	 * entity.getSlideSequence(); Map<Long,Long> removeMap = new HashMap<Long,
775
	 * Long>(); List<Slide> slides = entity.getSlides(); if(slides!=null){
776
	 * for(Slide slide: slides){ List<Feature> features; Slide childSlide;
777
	 * switch ((int)slide.getSlideDefinitionID()) {
778
	 * 
779
	 * //Keyboard case 130004: case 130026: case 130027: case 130057:
780
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130026);
781
	 * slide.setSlideDefinitionID(130026); break;
782
	 * 
783
	 * //Voice Calling case 130005: removeMap.put(slide.getSlideDefinitionID(),
784
	 * (long)130005); slide.setSlideDefinitionID(130005); features = new
785
	 * ArrayList<Feature>(); features.addAll(slide.getFeatures()); childSlide =
786
	 * slide.getChildrenSlides().get(0);
787
	 * features.addAll(childSlide.getFeatures());
788
	 * if(childSlide.getFreeformContent()!=null){
789
	 * System.out.println("Voice Calling : HAS FFC : " +
790
	 * childSlide.getFreeformContent().getFreeformText() +
791
	 * childSlide.getFreeformContent().getMedias()); }
792
	 * slide.setChildrenSlides(null); slide.setFeatures(features); break; case
793
	 * 130035: removeMap.put(slide.getSlideDefinitionID(), (long)130005);
794
	 * slide.setSlideDefinitionID(130005); for(Feature feata:
795
	 * slide.getFeatures()){ if(feata.getFeatureDefinitionID()==120055){
796
	 * feata.setFeatureDefinitionID(120012); } } break;
797
	 * 
798
	 * //Data Connectivity case 130007: case 130028:
799
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130007);
800
	 * slide.setSlideDefinitionID(130007); break;
801
	 * 
802
	 * //Music case 130029: case 130030: case 130008:
803
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130029);
804
	 * slide.setSlideDefinitionID(130029); break;
805
	 * 
806
	 * //Video case 130031: case 130009:
807
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130031);
808
	 * slide.setSlideDefinitionID(130031); break;
809
	 * 
810
	 * //Camera case 130010: case 130036: case 130037:
811
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130010);
812
	 * slide.setSlideDefinitionID(130010); break; case 130060:
813
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130010);
814
	 * slide.setSlideDefinitionID(130010);
815
	 * 
816
	 * features = slide.getFeatures(); // Just to add camera feature in basic
817
	 * phones Feature feature = new Feature(120056); List<Bullet> bullets = new
818
	 * ArrayList<Bullet>(); PrimitiveDataObject pdo = new
819
	 * PrimitiveDataObject("1"); Bullet bullet = new Bullet(pdo);
820
	 * bullets.add(bullet); feature.setBullets(bullets); features.add(feature);
821
	 * //Created new feature break;
822
	 * 
823
	 * //Memory case 130011: removeMap.put(slide.getSlideDefinitionID(),
824
	 * (long)130011); slide.setSlideDefinitionID(130011); break; case 130032:
825
	 * case 130061: removeMap.put(slide.getSlideDefinitionID(), (long)130011);
826
	 * slide.setSlideDefinitionID(130011); features = slide.getFeatures();
827
	 * for(Feature feat: features){ if(feat.getFeatureDefinitionID() == 120054){
828
	 * feat.setFeatureDefinitionID(120030); } } break;
829
	 * 
830
	 * //Battery case 130044: removeMap.put(slide.getSlideDefinitionID(),
831
	 * (long)130043); slide.setSlideDefinitionID(130043);
832
	 * if(slide.getChildrenSlides().get(0).getSlideDefinitionID() == 130047){
833
	 * slide.getChildrenSlides().get(0).setSlideDefinitionID(130046); } break;
834
	 * 
835
	 * case 130042: removeMap.put(slide.getSlideDefinitionID(), (long)130043);
836
	 * slide.setSlideDefinitionID(130043); childSlide =
837
	 * slide.getChildrenSlides().get(0); if(childSlide.getSlideDefinitionID() ==
838
	 * 130045){ childSlide.setSlideDefinitionID(130046); }
839
	 * 
840
	 * List<Feature> childFeatures1 = new ArrayList<Feature>(); List<Feature>
841
	 * childFeatures2 = new ArrayList<Feature>(); Slide childChildSlide1 = new
842
	 * Slide(130048); Slide childChildSlide2 = new Slide(130049);
843
	 * 
844
	 * childChildSlide1.setFeatures(childFeatures1);
845
	 * childChildSlide2.setFeatures(childFeatures2);
846
	 * 
847
	 * childSlide.addChild(childChildSlide1);
848
	 * childSlide.addChild(childChildSlide2);
849
	 * 
850
	 * 
851
	 * for(Feature f: childSlide.getFeatures()){ if(f.getFeatureDefinitionID()
852
	 * == 120063){ f.setFeatureDefinitionID(120068); childFeatures1.add(f); }
853
	 * if(f.getFeatureDefinitionID() == 120064){
854
	 * f.setFeatureDefinitionID(120069); childFeatures2.add(f); } }
855
	 * 
856
	 * childSlide.setFeatures(null);
857
	 * 
858
	 * break;
859
	 * 
860
	 * case 130062: removeMap.put(slide.getSlideDefinitionID(), (long)130043);
861
	 * slide.setSlideDefinitionID(130043);
862
	 * 
863
	 * childSlide = new Slide(130046); features = new ArrayList<Feature>();
864
	 * 
865
	 * slide.addChild(childSlide);
866
	 * 
867
	 * List<Feature> childFeatures11 = new ArrayList<Feature>(); List<Feature>
868
	 * childFeatures21 = new ArrayList<Feature>(); Slide childChildSlide11 = new
869
	 * Slide(130048); Slide childChildSlide21 = new Slide(130049);
870
	 * 
871
	 * childChildSlide11.setFeatures(childFeatures11);
872
	 * childChildSlide21.setFeatures(childFeatures21);
873
	 * 
874
	 * childSlide.addChild(childChildSlide11);
875
	 * childSlide.addChild(childChildSlide21); for(Feature f:
876
	 * slide.getFeatures()){ if(f.getFeatureDefinitionID() == 120072){
877
	 * features.add(f); } if(f.getFeatureDefinitionID() == 120073){
878
	 * features.add(f); } if(f.getFeatureDefinitionID() == 120063){
879
	 * f.setFeatureDefinitionID(120068); childFeatures11.add(f); }
880
	 * if(f.getFeatureDefinitionID() == 120064){
881
	 * f.setFeatureDefinitionID(120069); childFeatures21.add(f); } }
882
	 * slide.setFeatures(features); break;
883
	 * 
884
	 * 
885
	 * //Mail n Msg case 130041: case 130063:
886
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130039);
887
	 * slide.setSlideDefinitionID(130039); break; case 130039:
888
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130039);
889
	 * slide.setSlideDefinitionID(130039);
890
	 * 
891
	 * childSlide = slide.getChildrenSlides().get(0);
892
	 * slide.setFeatures(childSlide.getFeatures());
893
	 * if(childSlide.getFreeformContent()!=null){
894
	 * System.out.println("Mail n Msg : HAS FFC : " +
895
	 * childSlide.getFreeformContent().getFreeformText() +
896
	 * childSlide.getFreeformContent().getMedias()); }
897
	 * slide.setChildrenSlides(null); break;
898
	 * 
899
	 * //Software case 130020: case 130034:
900
	 * removeMap.put(slide.getSlideDefinitionID(), (long)130020);
901
	 * slide.setSlideDefinitionID(130020); break;
902
	 * 
903
	 * 
904
	 * //Internet case 130050: removeMap.put(slide.getSlideDefinitionID(),
905
	 * (long)130050); slide.setSlideDefinitionID(130050);
906
	 * slide.setFeatures(slide.getChildrenSlides().get(0).getFeatures());
907
	 * 
908
	 * if(slide.getChildrenSlides().get(0).getFreeformContent()!=null){ String
909
	 * ffc = slide.getFreeformContent().getFreeformText();
910
	 * if(slide.getChildrenSlides
911
	 * ().get(0).getFreeformContent().getFreeformText()!=null){
912
	 * if(slide.getChildrenSlides
913
	 * ().get(0).getFreeformContent().getFreeformText().trim()!=""){ ffc = ffc +
914
	 * "\n *********    " +
915
	 * slide.getChildrenSlides().get(0).getFreeformContent().getFreeformText();
916
	 * System.out.println("**************" +
917
	 * slide.getChildrenSlides().get(0).getFreeformContent().getFreeformText());
918
	 * } }
919
	 * 
920
	 * List<String> ffcs = new ArrayList<String>(); ffcs.add(ffc);
921
	 * slide.getFreeformContent().setFreeformTexts(ffcs); }
922
	 * 
923
	 * slide.setChildrenSlides(null); //System.out.println("Slide: 130050");
924
	 * //printSlideContent(slide); break;
925
	 * 
926
	 * case 130052: removeMap.put(slide.getSlideDefinitionID(), (long)130050);
927
	 * slide.setSlideDefinitionID(130050);
928
	 * 
929
	 * for(Feature f2: slide.getFeatures()){ if(f2.getFeatureDefinitionID() ==
930
	 * 120077){ f2.setFeatureDefinitionID(120074); // List<Bullet> newBullets =
931
	 * new ArrayList<Bullet>(); // for(Bullet bul: f2.getBullets()){ //
932
	 * CompositeDataObject cdo = (CompositeDataObject) bul.getDataObject(); //
933
	 * for(PrimitiveDataObject pdo1: cdo.getPrimitiveDataObjects()){ //
934
	 * pdo1.getValue(); // BulletDataObject bdo2 = new
935
	 * EnumDataObject(enumValueID); // Bullet newbul = new Bullet(bdo2); //
936
	 * newBullets.add(newbul); // } // // } // f2.setBullets(newBullets); }
937
	 * if(f2.getFeatureDefinitionID() == 120078){
938
	 * f2.setFeatureDefinitionID(120075); } } //
939
	 * slide.setFeatures(slide.getChildrenSlides().get(0).getFeatures()); //
940
	 * slide.setChildrenSlides(null); //System.out.println("Slide: 130052");
941
	 * 
942
	 * //printSlideContent(slide); break;
943
	 * 
944
	 * case 130051: removeMap.put(slide.getSlideDefinitionID(), (long)130050);
945
	 * slide.setSlideDefinitionID(130050); // System.out.println(slide);
946
	 * //System.out.println("Slide 130051:"); // printSlideContent(slide);
947
	 * break;
948
	 * 
949
	 * default: break; }
950
	 * 
951
	 * } List<Long> newSequence = new ArrayList<Long>(); for(Long id:
952
	 * slideSequence){ if(removeMap.containsKey(id)){
953
	 * newSequence.add(removeMap.get(id)); }else{ newSequence.add(id); } }
954
	 * entity.setSlideSequence(newSequence); CreationUtils.updateEntity(entity);
955
	 * } }
956
	 * 
957
	 * return true; }
958
	 */
959
 
960
	public void printSlideContent(Slide slide) {
961
 
962
		System.out.println("Slide: "
963
				+ slide.getFreeformContent().getFreeformText());
964
		if (slide.getFeatures() != null) {
965
			for (Feature feature : slide.getFeatures()) {
966
				if (feature.getBullets() != null) {
967
					for (Bullet bullet : feature.getBullets()) {
968
						// System.out.println(bullet.getDataObject().toString());
969
						// System.out.println(bullet.getFreeformContent());
1226 rajveer 970
					}
971
				}
4964 amit.gupta 972
				if (feature.getFreeformContent() != null) {
973
					System.out.println("Feature: "
974
							+ feature.getFreeformContent().getFreeformText());
1226 rajveer 975
				}
976
			}
977
		}
4964 amit.gupta 978
		if (slide.getChildrenSlides() != null) {
979
			for (Slide sl : slide.getChildrenSlides()) {
1226 rajveer 980
				System.out.println("Child1: ");
981
				printSlideContent(sl);
982
				System.out.println("Child2: ");
983
			}
984
		}
4964 amit.gupta 985
 
1226 rajveer 986
	}
4964 amit.gupta 987
 
1230 rajveer 988
	/*
4964 amit.gupta 989
	 * public boolean migrateModel() throws Exception{ //DefinitionsContainer
990
	 * oldDfc = new DefinitionsContainer(Utils.CONTENT_DB_PATH +
991
	 * "olddefinitions" + File.separator); //DefinitionsContainer newDfc = new
992
	 * DefinitionsContainer(Utils.CONTENT_DB_PATH + "olddefinitions" +
993
	 * File.separator);
994
	 * 
995
	 * Map<Long, Entity> entities = CreationUtils.getEntities(); for(Entity
996
	 * entity: entities.values()){ List<Slide> slides = entity.getSlides();
997
	 * if(slides!=null){ List<Slide> newSlides = new ArrayList<Slide>();
998
	 * for(Slide slide: slides){ Slide newSlide; List<Feature> features; Slide
999
	 * childSlide; switch ((int)slide.getSlideDefinitionID()) {
1000
	 * 
1001
	 * //Keyboard case 130004: case 130026: case 130027: case 130057: newSlide =
1002
	 * new Slide(130026); newSlide.setChildrenSlides(slide.getChildrenSlides());
1003
	 * newSlide.setFeatures(slide.getFeatures());
1004
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1005
	 * newSlides.add(newSlide); break;
1006
	 * 
1007
	 * //Voice Calling case 130005: newSlide = new Slide(130005);
1008
	 * newSlide.setChildrenSlides(null); features = new ArrayList<Feature>();
1009
	 * features.addAll(slide.getFeatures()); childSlide =
1010
	 * slide.getChildrenSlides().get(0);
1011
	 * features.addAll(childSlide.getFeatures());
1012
	 * if(childSlide.getFreeformContent()!=null){
1013
	 * System.out.println("Voice Calling : HAS FFC : " +
1014
	 * childSlide.getFreeformContent().getFreeformText() +
1015
	 * childSlide.getFreeformContent().getMedias()); }
1016
	 * newSlide.setFeatures(features);
1017
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1018
	 * newSlides.add(newSlide); break; case 130035: newSlide = new
1019
	 * Slide(130035); newSlide.setChildrenSlides(slide.getChildrenSlides());
1020
	 * for(Feature feata: slide.getFeatures()){
1021
	 * if(feata.getFeatureDefinitionID()==120055){
1022
	 * feata.setFeatureDefinitionID(120012); } }
1023
	 * newSlide.setFeatures(slide.getFeatures());
1024
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1025
	 * newSlides.add(newSlide); break;
1026
	 * 
1027
	 * //Data Connectivity case 130007: case 130028: newSlide = new
1028
	 * Slide(130007); newSlide.setChildrenSlides(slide.getChildrenSlides());
1029
	 * newSlide.setFeatures(slide.getFeatures());
1030
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1031
	 * newSlides.add(newSlide); break;
1032
	 * 
1033
	 * //Music case 130029: case 130030: case 130008: newSlide = new
1034
	 * Slide(130029); newSlide.setChildrenSlides(slide.getChildrenSlides());
1035
	 * newSlide.setFeatures(slide.getFeatures());
1036
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1037
	 * newSlides.add(newSlide); break;
1038
	 * 
1039
	 * //Video case 130031: case 130009: newSlide = new Slide(130031);
1040
	 * newSlide.setChildrenSlides(slide.getChildrenSlides());
1041
	 * newSlide.setFeatures(slide.getFeatures());
1042
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1043
	 * newSlides.add(newSlide); break;
1044
	 * 
1045
	 * //Camera case 130010: case 130036: case 130037: newSlide = new
1046
	 * Slide(130010); newSlide.setChildrenSlides(slide.getChildrenSlides());
1047
	 * newSlide.setFeatures(slide.getFeatures());
1048
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1049
	 * newSlides.add(newSlide); break; case 130060: newSlide = new
1050
	 * Slide(130010); newSlide.setChildrenSlides(slide.getChildrenSlides());
1051
	 * features = slide.getFeatures(); // Just to add camera feature in basic
1052
	 * phones Feature feature = new Feature(120056); List<Bullet> bullets = new
1053
	 * ArrayList<Bullet>(); PrimitiveDataObject pdo = new
1054
	 * PrimitiveDataObject("1"); Bullet bullet = new Bullet(pdo);
1055
	 * bullets.add(bullet); feature.setBullets(bullets); features.add(feature);
1056
	 * //Created new feature newSlide.setFeatures(features);
1057
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1058
	 * newSlides.add(newSlide); break;
1059
	 * 
1060
	 * //Memory case 130011: newSlide = new Slide(130011);
1061
	 * newSlide.setChildrenSlides(slide.getChildrenSlides());
1062
	 * newSlide.setFeatures(slide.getFeatures());
1063
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1064
	 * newSlides.add(newSlide); break; case 130032: case 130061: newSlide = new
1065
	 * Slide(130011); newSlide.setChildrenSlides(slide.getChildrenSlides());
1066
	 * features = slide.getFeatures(); for(Feature feat: features){
1067
	 * if(feat.getFeatureDefinitionID() == 130054){
1068
	 * feat.setFeatureDefinitionID(120030); } }
1069
	 * newSlide.setFeatures(slide.getFeatures());
1070
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1071
	 * newSlides.add(newSlide); break;
1072
	 * 
1073
	 * //Battery case 130044: newSlide = new Slide(130043);
1074
	 * if(slide.getChildrenSlides().get(0).getSlideDefinitionID() == 130047){
1075
	 * slide.getChildrenSlides().get(0).setSlideDefinitionID(130046); }
1076
	 * newSlide.setChildrenSlides(slide.getChildrenSlides());
1077
	 * newSlide.setFeatures(slide.getFeatures());
1078
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1079
	 * newSlides.add(newSlide); break;
1080
	 * 
1081
	 * case 130042: newSlide = new Slide(130043); childSlide =
1082
	 * slide.getChildrenSlides().get(0); if(childSlide.getSlideDefinitionID() ==
1083
	 * 130045){ childSlide.setSlideDefinitionID(130046); }
1084
	 * newSlide.setChildrenSlides(slide.getChildrenSlides());
1085
	 * 
1086
	 * List<Feature> childFeatures1 = new ArrayList<Feature>(); List<Feature>
1087
	 * childFeatures2 = new ArrayList<Feature>(); Slide childChildSlide1 = new
1088
	 * Slide(130048); Slide childChildSlide2 = new Slide(130049);
1089
	 * 
1090
	 * childChildSlide1.setFeatures(childFeatures1);
1091
	 * childChildSlide2.setFeatures(childFeatures2);
1092
	 * 
1093
	 * childSlide.addChild(childChildSlide1);
1094
	 * childSlide.addChild(childChildSlide2);
1095
	 * 
1096
	 * 
1097
	 * for(Feature f: childSlide.getFeatures()){ if(f.getFeatureDefinitionID()
1098
	 * == 120063){ f.setFeatureDefinitionID(120068); childFeatures1.add(f); }
1099
	 * if(f.getFeatureDefinitionID() == 120064){
1100
	 * f.setFeatureDefinitionID(120069); childFeatures2.add(f); } }
1101
	 * 
1102
	 * childSlide.setFeatures(null);
1103
	 * 
1104
	 * newSlide.setFeatures(slide.getFeatures());
1105
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1106
	 * newSlides.add(newSlide); break;
1107
	 * 
1108
	 * case 130062: newSlide = new Slide(130043);
1109
	 * newSlide.setChildrenSlides(slide.getChildrenSlides()); childSlide = new
1110
	 * Slide(130046); features = new ArrayList<Feature>();
1111
	 * newSlide.setFeatures(features); newSlide.addChild(childSlide);
1112
	 * 
1113
	 * List<Feature> childFeatures11 = new ArrayList<Feature>(); List<Feature>
1114
	 * childFeatures21 = new ArrayList<Feature>(); Slide childChildSlide11 = new
1115
	 * Slide(130048); Slide childChildSlide21 = new Slide(130049);
1116
	 * 
1117
	 * childChildSlide11.setFeatures(childFeatures11);
1118
	 * childChildSlide21.setFeatures(childFeatures21);
1119
	 * 
1120
	 * childSlide.addChild(childChildSlide11);
1121
	 * childSlide.addChild(childChildSlide21); for(Feature f:
1122
	 * slide.getFeatures()){ if(f.getFeatureDefinitionID() == 120072){
1123
	 * features.add(f); } if(f.getFeatureDefinitionID() == 120073){
1124
	 * features.add(f); } if(f.getFeatureDefinitionID() == 120063){
1125
	 * f.setFeatureDefinitionID(120068); childFeatures11.add(f); }
1126
	 * if(f.getFeatureDefinitionID() == 120064){
1127
	 * f.setFeatureDefinitionID(120069); childFeatures21.add(f); } }
1128
	 * 
1129
	 * newSlide.setFeatures(slide.getFeatures());
1130
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1131
	 * newSlides.add(newSlide); break;
1132
	 * 
1133
	 * 
1134
	 * //Mail n Msg case 130041: case 130063: newSlide = new Slide(130039);
1135
	 * newSlide.setChildrenSlides(slide.getChildrenSlides());
1136
	 * newSlide.setFeatures(slide.getFeatures());
1137
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1138
	 * newSlides.add(newSlide); break; case 130039: newSlide = new
1139
	 * Slide(130039); //newSlide.setChildrenSlides(slide.getChildrenSlides());
1140
	 * childSlide = slide.getChildrenSlides().get(0);
1141
	 * newSlide.setFeatures(childSlide.getFeatures());
1142
	 * if(childSlide.getFreeformContent()!=null){
1143
	 * System.out.println("Mail n Msg : HAS FFC : " +
1144
	 * childSlide.getFreeformContent().getFreeformText() +
1145
	 * childSlide.getFreeformContent().getMedias()); }
1146
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1147
	 * newSlides.add(newSlide); break;
1148
	 * 
1149
	 * //Software case 130020: case 130034: newSlide = new Slide(130034);
1150
	 * newSlide.setChildrenSlides(slide.getChildrenSlides()); features =
1151
	 * slide.getFeatures(); newSlide.setFeatures(slide.getFeatures());
1152
	 * newSlide.setFreeformContent(slide.getFreeformContent());
1153
	 * newSlides.add(newSlide); break;
1154
	 * 
1155
	 * 
1156
	 * default: newSlides.add(slide); break; } } entity.setSlides(newSlides);
1157
	 * CreationUtils.updateEntity(entity); } }
1158
	 * 
1159
	 * return true; }
1160
	 */
1161
	public boolean migrateRemoveBorrowedCategoryIdFromSlide() throws Exception {
1226 rajveer 1162
		Map<Long, Entity> entities = CreationUtils.getEntities();
4964 amit.gupta 1163
		for (Entity entity : entities.values()) {
1164
			if (entity.getID() == 0) {
1226 rajveer 1165
				CreationUtils.deleteEntity(entity.getID());
1166
			}
1167
			List<Slide> slides = entity.getSlides();
4964 amit.gupta 1168
			if (slides != null) {
1226 rajveer 1169
				List<Slide> newSlides = new ArrayList<Slide>();
4964 amit.gupta 1170
				for (Slide slide : slides) {
1226 rajveer 1171
					Slide newSlide = new Slide(slide.getSlideDefinitionID());
1172
					newSlide.setChildrenSlides(slide.getChildrenSlides());
1173
					newSlide.setFeatures(slide.getFeatures());
1174
					newSlide.setFreeformContent(slide.getFreeformContent());
1175
					newSlides.add(newSlide);
1176
				}
1177
				entity.setSlides(newSlides);
1178
				CreationUtils.updateEntity(entity);
1179
			}
1180
		}
1181
		return true;
1182
	}
479 rajveer 1183
 
4964 amit.gupta 1184
	public boolean migrate() throws Exception {
580 rajveer 1185
		/*
4964 amit.gupta 1186
		 * DefinitionsContainer sourceDefs = new
1187
		 * DefinitionsContainer(sourceDbPath); DefinitionsContainer
1188
		 * destinationDefs = new DefinitionsContainer(destinationDbPath);
1189
		 * EntityContainer sourceEnts = new EntityContainer(sourceDbPath);
1190
		 * EntityContainer destinationEnts = new
1191
		 * EntityContainer(destinationDbPath);
1192
		 * 
1193
		 * Map<Long, Entity> entities = sourceEnts.getEntities();
1194
		 * 
1195
		 * File f = new File("/home/rajveer/Desktop/info.txt"); FileWriter
1196
		 * fstream = new FileWriter(f); BufferedWriter out = new
1197
		 * BufferedWriter(fstream); StringBuilder sb = new StringBuilder();
1198
		 * 
1199
		 * 
1200
		 * for(Entity entity: entities.values()){ List<Slide> slides =
1201
		 * entity.getSlides();
1202
		 * 
1203
		 * //List<String> vidLabels =
1204
		 * CreationUtils.getMediaLabels(entity.getID(),"youtube");
1205
		 * //List<String> imgLabels =
1206
		 * CreationUtils.getMediaLabels(entity.getID(),"image");
1207
		 * 
1208
		 * //Map<String, Media> rawMedia =
1209
		 * CreationUtils.getRawMedia(entity.getID());
1210
		 * 
1211
		 * 
1212
		 * // List<String> vidLabels =
1213
		 * OldCreationUtils.getMediaLabels(entity.getID(),"youtube"); //
1214
		 * List<String> imgLabels =
1215
		 * OldCreationUtils.getMediaLabels(entity.getID(),"image");
1216
		 * 
1217
		 * Entity newEntity = new Entity(entity.getID(),
1218
		 * entity.getCategoryID()); newEntity.setBrand(entity.getBrand());
1219
		 * newEntity.setModelName(entity.getModelName());
1220
		 * newEntity.setModelNumber(entity.getModelNumber());
1221
		 * 
1222
		 * 
1223
		 * Map<String, in.shop2020.creation.util.Media> rawMedia =
1224
		 * OldCreationUtils.getRawMedia(entity.getID());
1225
		 * 
1226
		 * Map<String, Media> newrawMedia = new HashMap<String, Media>();
1227
		 * 
1228
		 * 
1229
		 * int totalRawVideos = 0; int totalRawImages = 0;
1230
		 * 
1231
		 * if(rawMedia!=null){ for(String label: rawMedia.keySet()){
1232
		 * in.shop2020.creation.util.Media media = rawMedia.get(label);
1233
		 * 
1234
		 * label = media.getLabel(); String type = media.getType(); String
1235
		 * location = media.getLocation();
1236
		 * 
1237
		 * Media newMedia = new Media(label, type, location);
1238
		 * 
1239
		 * newMedia.setTitle("Title"); if(type.equals("image")){
1240
		 * totalRawImages++; newMedia.setFileName(media.getFileName());
1241
		 * newMedia.setVideoType(""); }else{ totalRawVideos++;
1242
		 * newMedia.setVideoType("withoutskin"); newMedia.setFileName(""); }
1243
		 * 
1244
		 * newrawMedia.put(label, newMedia); System.out.println("old " +
1245
		 * media.toString()); // System.out.println("new " +
1246
		 * newMedia.toString()); // OldCreationUtils.removeMedia(entity.getID(),
1247
		 * label); // CreationUtils.addMedia(entity.getID(), newMedia); } }
1248
		 * 
1249
		 * int totalVideos = 0; int totalImages = 0; if(rawMedia==null){
1250
		 * for(Slide slide: slides ){
1251
		 */
1252
		/*
1253
		 * FreeformContent ffc = slide.getFreeformContent(); List<String>
1254
		 * vidList = new ArrayList<String>(); List<String> imgList = new
1255
		 * ArrayList<String>();
1256
		 * 
1257
		 * if(ffc!=null){ List<String> vidFfcLabels = ffc.getYoutubeRefs();
1258
		 * if(vidFfcLabels!=null){ for(String vidFfcLabel: vidFfcLabels){
1259
		 * StringTokenizer strTkn = new StringTokenizer(vidFfcLabel,"~!~");
1260
		 * String vidLabel = null; if(strTkn.hasMoreTokens()){ vidLabel =
1261
		 * strTkn.nextToken(); vidList.add(vidFfcLabel);
1262
		 * 
1263
		 * // ffc.removeMedia("youtube", vidFfcLabel); //
1264
		 * ffc.addMedia("youtube", vidLabel); } if(vidLabel == null){
1265
		 * System.out.println("Something is really breaking .. bu ha ha !!!"); }
1266
		 * totalVideos++; } } List<String> imgFfcLabels = ffc.getImageRefs();
1267
		 * if(imgFfcLabels!=null){ for(String imgFfcLabel: imgFfcLabels){
1268
		 * StringTokenizer strTkn = new StringTokenizer(imgFfcLabel,"~!~");
1269
		 * String imgLabel = null; if(strTkn.hasMoreTokens()){ imgLabel =
1270
		 * strTkn.nextToken(); imgList.add(imgFfcLabel);
1271
		 * 
1272
		 * // ffc.removeMedia("image", imgFfcLabel); // ffc.addMedia("image",
1273
		 * imgLabel); } if(imgLabel == null){
1274
		 * System.out.println("Something is really breaking .. bu ha ha !!!"); }
1275
		 * totalImages++; } }
1276
		 * 
1277
		 * for(String vidlab : vidList){ ffc.removeMedia("youtube", vidlab);
1278
		 * ffc.addMedia("youtube", (new StringTokenizer(vidlab,
1279
		 * "~!~")).nextToken()); } for(String imglab : imgList){
1280
		 * ffc.removeMedia("image",imglab); ffc.addMedia("image", (new
1281
		 * StringTokenizer(imglab, "~!~")).nextToken()); }
1282
		 * slide.setFreeformContent(ffc); System.out.println("Slide id is " +
1283
		 * slide.getSlideDefinitionID() + "   vid labels:  " + vidFfcLabels +
1284
		 * "   img labels" + imgFfcLabels); }
1285
		 */
1286
		/*
1287
		 * newEntity.addSlide(slide); }
1288
		 * 
1289
		 * // System.out.println("entity:"+ entity.getID() + ":trv:" +
1290
		 * totalRawVideos + ":tri:" + totalRawImages +":tv:" + totalVideos
1291
		 * +":ti:" + totalImages); // sb.append("entity:"+ entity.getID() +
1292
		 * ":trv:" + totalRawVideos + ":tri:" + totalRawImages +":tv:" +
1293
		 * totalVideos +":ti:" + totalImages+ ":tr:"
1294
		 * +(totalRawVideos+totalRawImages) + ":t:" +(totalVideos+totalImages) +
1295
		 * ":vd:" +(totalRawVideos-totalVideos) + ":id:"
1296
		 * +(totalRawImages-totalImages) + "\n"); sb.append(entity.getID() +
1297
		 * "\n");
1298
		 * 
1299
		 * 
1300
		 * destinationEnts.updateEntity(newEntity);
1301
		 * CreationUtils.storeEntity(newEntity);
1302
		 * 
1303
		 * Map<Long, List<Entity>> entitiesByCategory =
1304
		 * sourceEnts.getEntitiesbyCategory();
1305
		 * 
1306
		 * Map<Long, Entity> xentities = destinationEnts.getEntities();
1307
		 * 
1308
		 * CreationUtils.rewriteRepository(xentities, entitiesByCategory); }
1309
		 * else{ sb.append("				" + entity.getID() + "\n"); } }
1310
		 * 
1311
		 * 
1312
		 * out.write(sb.toString()); out.close();
1313
		 */
457 rajveer 1314
		return true;
1315
	}
4964 amit.gupta 1316
 
1317
	private boolean makeEntitiesObject() throws Exception {
1318
		// DefinitionsContainer sourceDefs = new
1319
		// DefinitionsContainer(sourceDbPath);
1320
		// DefinitionsContainer destinationDefs = new
1321
		// DefinitionsContainer(destinationDbPath);
1322
		// EntityContainer sourceEnts = new EntityContainer(sourceDbPath);
1323
		// EntityContainer destinationEnts = new
1324
		// EntityContainer(destinationDbPath);
1325
 
1326
		/*
1327
		 * Map<Long, List<Entity>> catEntities =
1328
		 * sourceEnts.getEntitiesbyCategory();
1329
		 * 
1330
		 * Map<Long, Entity> entities = sourceEnts.getEntities(); for(Long
1331
		 * catId: catEntities.keySet()){ List<Entity> ents =
1332
		 * catEntities.get(catId); for(Entity entity: ents){
1333
		 * entities.put(entity.getID(), entity);
1334
		 * System.out.println(entity.getID() + ":" + entity.getCategoryID() +
1335
		 * ":"+ entity.getBrand() + " "+ entity.getModelName() + " " +
1336
		 * entity.getModelNumber()); } }
1337
		 */
1338
 
791 rajveer 1339
		Map<Long, List<Entity>> catEntities = new TreeMap<Long, List<Entity>>();
1340
		Map<Long, Entity> entities = new TreeMap<Long, Entity>();
2720 mandeep.dh 1341
 
4964 amit.gupta 1342
		FileInputStream fstream = new FileInputStream("/home/rajveer/Desktop/1");
1343
		DataInputStream in = new DataInputStream(fstream);
1344
		BufferedReader br = new BufferedReader(new InputStreamReader(in));
1345
		String strLine;
2720 mandeep.dh 1346
 
4964 amit.gupta 1347
		while ((strLine = br.readLine()) != null) {
1348
			long entityID = Long.parseLong(strLine);
1349
			String entityDBFile = sourceDbPath + "entities" + File.separator
1350
					+ entityID + "/entity.ser";
1351
			System.out.println(entityDBFile);
1352
			Entity entity = (Entity) DBUtils.read(entityDBFile);
1353
			entities.put(entityID, entity);
2720 mandeep.dh 1354
 
4964 amit.gupta 1355
			List<Entity> catent = catEntities.get(entity.getCategoryID());
1356
			if (catent == null) {
1357
				catent = new ArrayList<Entity>();
1358
			}
1359
			catent.add(entity);
1360
			catEntities.put(entity.getCategoryID(), catent);
1361
		}
1362
		in.close();
1363
 
1364
		String entitiesDBFile = sourceDbPath + "entities" + File.separator
1365
				+ "entities.ser";
1366
		String entitiesbycategoryDBFile = sourceDbPath + "entities"
1367
				+ File.separator + "entitiesbycategory.ser";
1368
 
791 rajveer 1369
		DBUtils.delete(entitiesDBFile);
1370
		DBUtils.store(entities, entitiesDBFile);
2720 mandeep.dh 1371
 
4964 amit.gupta 1372
		// Remove existing
791 rajveer 1373
		DBUtils.delete(entitiesbycategoryDBFile);
1374
		DBUtils.store(catEntities, entitiesbycategoryDBFile);
2720 mandeep.dh 1375
 
4964 amit.gupta 1376
		return false;
791 rajveer 1377
	}
2720 mandeep.dh 1378
 
4964 amit.gupta 1379
	private boolean printDataModel() throws Exception {
1380
		DefinitionsContainer dfc = Catalog.getInstance()
1381
				.getDefinitionsContainer();
1226 rajveer 1382
		StringBuilder sb = new StringBuilder();
2720 mandeep.dh 1383
 
1226 rajveer 1384
		Map<Long, SlideDefinition> allSlideDefs = dfc.getSlideDefinitions();
4964 amit.gupta 1385
		for (Long slideDefId : allSlideDefs.keySet()) {
1226 rajveer 1386
			SlideDefinition slideDef = allSlideDefs.get(slideDefId);
1387
			sb.append(slideDefId + " - " + slideDef.getLabel() + "\n");
4964 amit.gupta 1388
			if (!slideDef.getChildrenSlideDefinitionIDs().isEmpty()) {
1389
				sb.append("Child Slides are: \t"
1390
						+ slideDef.getChildrenSlideDefinitionIDs() + "\n");
1226 rajveer 1391
			}
4964 amit.gupta 1392
			List<SlideFeatureDefinition> featureDefs = slideDef
1393
					.getSlideFeatureDefinitions();
1394
			for (SlideFeatureDefinition featureDef : featureDefs) {
1395
				sb.append("\t"
1396
						+ featureDef.getFeatureDefintionID()
1397
						+ "\t"
1398
						+ dfc.getFeatureDefinition(
1399
								featureDef.getFeatureDefintionID()).getLabel()
1400
						+ "\t" + featureDef.getEditorialImportance() + "\n");
1226 rajveer 1401
			}
1402
		}
1403
		System.out.println(sb.toString());
580 rajveer 1404
		Map<Long, Category> categories = dfc.getCategories();
4964 amit.gupta 1405
		if (categories != null) {
1226 rajveer 1406
			return true;
1407
		}
4964 amit.gupta 1408
		for (Category category : categories.values()) {
1409
			if (category.getChildrenCategory() != null) {
580 rajveer 1410
				continue;
1411
			}
1226 rajveer 1412
			sb.append(category.getLabel() + "\n");
4964 amit.gupta 1413
			List<CategorySlideDefinition> slideDefs = dfc
1414
					.getCategorySlideDefinitions(category.getID());
1415
			List<Long> slideSequence = dfc.getCategorySlideSequence(category
1416
					.getID());
1417
			for (CategorySlideDefinition slideDef : slideDefs) {
1418
				sb.append("\t"
1419
						+ dfc.getSlideDefinition(slideDef.getSlideDefintionID())
1420
								.getLabel() + "\t"
1421
						+ slideDef.getEditorialImportance() + "\n");
1422
				// List<FeatureDefinition> featureDefs =
1423
				// dfc.getFeatureDefinitions(slideDef.getSlideDefintionID());
1424
 
1425
				List<SlideFeatureDefinition> slideFeatureDefs = dfc
1426
						.getSlideDefinition(slideDef.getSlideDefintionID())
1427
						.getSlideFeatureDefinitions();
1428
 
1429
				for (SlideFeatureDefinition slideFeatureDef : slideFeatureDefs) {
1430
					FeatureDefinition featureDef = dfc
1431
							.getFeatureDefinition(slideFeatureDef
1432
									.getFeatureDefintionID());
1433
					BulletDefinition bulletDef = featureDef
1434
							.getBulletDefinition();
1435
					sb.append("\t\t\t" + featureDef.getLabel() + "\t"
1436
							+ slideFeatureDef.getEditorialImportance() + "\t"
1437
							+ featureDef.allowsBlank() + "\t"
1438
							+ bulletDef.isLearned() + "\t"
1439
							+ bulletDef.isMultivalue());
580 rajveer 1440
					List<Long> units = bulletDef.getUnitIDs();
4964 amit.gupta 1441
					if (bulletDef.getDatatypeDefinitionID() != null) {
1442
						sb.append("\t"
1443
								+ dfc.getDatatypeDefinition(
1444
										bulletDef.getDatatypeDefinitionID())
1445
										.getName());
1446
 
1226 rajveer 1447
					}
4964 amit.gupta 1448
					if (units != null) {
1449
						for (Long unit : units) {
1450
							sb.append("\t" + dfc.getUnit(unit).getFullForm()
1451
									+ "\t" + dfc.getUnit(unit).getShortForm());
580 rajveer 1452
						}
1453
					}
1226 rajveer 1454
					sb.append("\n");
580 rajveer 1455
				}
4964 amit.gupta 1456
 
580 rajveer 1457
				/*
4964 amit.gupta 1458
				 * for(FeatureDefinition featureDef: featureDefs){
1459
				 * BulletDefinition bulletDef =
1460
				 * featureDef.getBulletDefinition(); System.out.println("			" +
1461
				 * featureDef.getLabel() + " 	" + featureDef.allowsBlank() + "	"
1462
				 * + bulletDef.isLearned() + "	" + bulletDef.isMultivalue());
1463
				 * List<Long> units = bulletDef.getUnitIDs(); if(units!=null){
1464
				 * for(Long unit: units){ System.out.println("								"+
1465
				 * dfc.getUnit(unit).getFullForm() + "	"+
1466
				 * dfc.getUnit(unit).getShortForm()); } }
1467
				 * if(bulletDef.getDatatypeDefinitionID()!=null){
1468
				 * System.out.println("										" +
1469
				 * dfc.getDatatypeDefinition(bulletDef
1470
				 * .getDatatypeDefinitionID()).getName());
1471
				 * 
1472
				 * } }
1473
				 */
580 rajveer 1474
			}
1475
		}
1226 rajveer 1476
		System.out.println(sb.toString());
580 rajveer 1477
		return true;
1478
	}
4964 amit.gupta 1479
 
1480
	public boolean migrateOS() throws Exception {
4706 amit.gupta 1481
		Map<Long, Entity> map = CreationUtils.getEntities();
4964 amit.gupta 1482
		for (Long entityId : map.keySet()) {
1483
			Entity entity = map.get(entityId);
1484
			if (entity == null || entity.getSlides() == null) {
1485
				continue;
1486
			}
1487
 
1488
			for (Slide slide : entity.getSlides()) {
1489
				if (slide.getSlideDefinitionID() == 130020) {
1490
					List<Feature> features = slide.getFeatures();
1491
					for (Feature f : features) {
1492
						if (f.getFeatureDefinitionID() == 120043) {
1493
							Bullet b = f.getBullets().get(0);
1494
							String value = ((PrimitiveDataObject) b
1495
									.getDataObject()).getValue();
1496
							long enumValueID = getEnumValueForOS(value);
1497
							if (enumValueID == 110371L) {
1498
								Logger.log("Set entity:" + entityId
1499
										+ " as proprietary software", entity);
1500
							}
4706 amit.gupta 1501
							b.setDataObject(new EnumDataObject(enumValueID));
4964 amit.gupta 1502
						}
1503
					}
1504
				}
4706 amit.gupta 1505
 
4964 amit.gupta 1506
			}
1507
 
1508
			CreationUtils.updateEntity(entity);
1509
		}
1510
		return true;
4706 amit.gupta 1511
	}
1512
 
1513
	private long getEnumValueForOS(String value) {
1514
		value = value.toLowerCase();
1515
		Map<String, Long> map = getOSEnumMap();
4964 amit.gupta 1516
		String os = "Proprietary software";
1517
		if (value.contains("android")) {
1518
			if (value.contains("1.5")) {
1519
				os = "Android v1.5 (Cupcake)";
1520
			}
1521
			if (value.contains("1.6")) {
1522
				os = "Android v1.6 (Donut)";
1523
			}
1524
			if (value.contains("2.1")) {
1525
				os = "Android v2.1 (Eclair)";
1526
			}
1527
			if (value.contains("2.2")) {
1528
				os = "Android v2.2 (Froyo)";
1529
			}
1530
			if (value.contains("2.3")) {
1531
				os = "Android v2.3 (Gingerbread)";
1532
			}
1533
			if (value.contains("3.0")) {
1534
				os = "Android v3.0 (Honeycomb)";
1535
			}
1536
			if (value.contains("3.1")) {
1537
				os = "Android v3.1 (Honeycomb)";
1538
			}
1539
			if (value.contains("3.2")) {
1540
				os = "Android v3.2 (Honeycomb)";
1541
			}
4706 amit.gupta 1542
		}
4964 amit.gupta 1543
		if (value.contains("blackberry")) {
1544
			if (value.contains("os")) {
4706 amit.gupta 1545
				os = "BlackBerry OS";
1546
			}
4964 amit.gupta 1547
			if (value.contains("5.0")) {
4706 amit.gupta 1548
				os = "BlackBerry OS 5.0";
1549
			}
4964 amit.gupta 1550
			if (value.contains("6.0")) {
4706 amit.gupta 1551
				os = "BlackBerry OS 6.0";
1552
			}
4964 amit.gupta 1553
			if (value.contains("7.0")) {
4706 amit.gupta 1554
				os = "BlackBerry OS 7.0";
1555
			}
4964 amit.gupta 1556
			if (value.contains("tablet os")) {
4706 amit.gupta 1557
				os = "BlackBerry Tablet OS";
1558
			}
1559
		}
4964 amit.gupta 1560
		if (value.contains("brew mobile platform")) {
4706 amit.gupta 1561
			os = "Brew Mobile Platform";
1562
		}
4964 amit.gupta 1563
		if (value.contains("maemo 5")) {
4706 amit.gupta 1564
			os = "Maemo 5";
1565
		}
4964 amit.gupta 1566
		if (value.contains("windows phone 7")) {
4706 amit.gupta 1567
			os = "Windows Phone 7";
1568
		}
4964 amit.gupta 1569
		if (value.contains("windows phone 7.5 mango")) {
4706 amit.gupta 1570
			os = "Windows Phone 7.5 Mango";
1571
		}
4964 amit.gupta 1572
		if (value.contains("proprietary")) {
1573
			if (value.contains("lg"))
4706 amit.gupta 1574
				os = "Proprietary LG software";
4964 amit.gupta 1575
			else if (value.contains("micromax")) {
4706 amit.gupta 1576
				os = "Proprietary Micromax software";
4964 amit.gupta 1577
			} else if (value.contains("samsung")) {
4706 amit.gupta 1578
				os = "Proprietary Samsung software";
4964 amit.gupta 1579
			} else if (value.contains("sony ericsson")) {
4706 amit.gupta 1580
				os = "Proprietary Sony Ericsson software";
4964 amit.gupta 1581
			} else if (value.contains("spice")) {
4706 amit.gupta 1582
				os = "Proprietary Spice software";
4964 amit.gupta 1583
			} else if (value.contains("lava")) {
4706 amit.gupta 1584
				os = "Proprietary Lava software";
4964 amit.gupta 1585
			} else if (value.contains("alcatel")) {
4706 amit.gupta 1586
				os = "Proprietary Alcatel software";
4964 amit.gupta 1587
			} else if (value.contains("motorola")) {
4706 amit.gupta 1588
				os = "Proprietary Motorola software";
4964 amit.gupta 1589
			} else if (value.contains("karbonn")) {
4706 amit.gupta 1590
				os = "Proprietary Karbonn software";
4964 amit.gupta 1591
			} else {
4706 amit.gupta 1592
				os = "Proprietary software";
1593
			}
1594
		}
4964 amit.gupta 1595
		if (value.contains("mmp")) {
4706 amit.gupta 1596
			os = "Proprietary Samsung software";
1597
		}
4964 amit.gupta 1598
		if (value.contains("samsung")) {
1599
			if (value.contains("bada")) {
1600
				os = "Samsung bada";
1601
			}
1602
			if (value.contains("bada 1.2")) {
1603
				os = "Samsung bada 1.2";
1604
			}
4706 amit.gupta 1605
		}
4964 amit.gupta 1606
		if (value.contains("sony ericsson java platform 8")) {
4706 amit.gupta 1607
			os = "Proprietary Sony Ericsson software";
1608
		}
4964 amit.gupta 1609
		if (value.contains("s60")) {
4706 amit.gupta 1610
			os = "Symbian 60";
1611
		}
4964 amit.gupta 1612
		if (value.contains("symbian")) {
1613
			if (value.contains("40")) {
4706 amit.gupta 1614
				os = "Symbian 40";
1615
			}
4964 amit.gupta 1616
			if (value.contains("60")) {
4706 amit.gupta 1617
				os = "Symbian 60";
1618
			}
4964 amit.gupta 1619
			if (value.contains("^3")) {
4706 amit.gupta 1620
				os = "Symbian^3";
1621
			}
4964 amit.gupta 1622
			if (value.contains("anna")) {
4706 amit.gupta 1623
				os = "Symbian Anna";
1624
			}
4964 amit.gupta 1625
			if (value.contains("belle")) {
4706 amit.gupta 1626
				os = "Symbian Belle";
1627
			}
1628
		}
4964 amit.gupta 1629
		if (value.contains("ios 4")) {
4706 amit.gupta 1630
			os = "iOS 4";
1631
		}
4964 amit.gupta 1632
		if (value.contains("ios 5")) {
4706 amit.gupta 1633
			os = "iOS 5";
1634
		}
1635
		return map.get(os);
1636
	}
4964 amit.gupta 1637
 
1638
	private Map<String, Long> getOSEnumMap() {
4706 amit.gupta 1639
		Map<String, Long> map = new HashMap<String, Long>();
1640
		map.put("Android v1.5 (Cupcake)", 110335L);
1641
		map.put("Android v1.6 (Donut)", 110336L);
1642
		map.put("Android v2.1 (Eclair)", 110337L);
1643
		map.put("Android v2.2 (Froyo)", 110338L);
1644
		map.put("Android v2.3 (Gingerbread)", 110339L);
1645
		map.put("Android v3.0 (Honeycomb)", 110340L);
1646
		map.put("Android v3.1 (Honeycomb)", 110341L);
4964 amit.gupta 1647
		map.put("Android v3.2 (Honeycomb)", 110342L);
4706 amit.gupta 1648
		map.put("BlackBerry OS", 110343L);
1649
		map.put("BlackBerry OS 5.0", 110344L);
1650
		map.put("BlackBerry OS 6.0", 110345L);
1651
		map.put("BlackBerry OS 7.0", 110346L);
1652
		map.put("BlackBerry Tablet OS", 110347L);
1653
		map.put("Brew Mobile Platform", 110348L);
1654
		map.put("Maemo 5", 110349L);
1655
		map.put("Windows Phone 7", 110350L);
1656
		map.put("Windows Phone 7.5 Mango", 110351L);
1657
		map.put("Proprietary LG software", 110352L);
1658
		map.put("Proprietary Micromax software", 110353L);
1659
		map.put("Proprietary Samsung software", 110354L);
1660
		map.put("Proprietary Sony Ericsson software", 110355L);
1661
		map.put("Proprietary Spice software", 110356L);
1662
		map.put("Proprietary Lava software", 110367L);
1663
		map.put("Proprietary Karbonn software", 110368L);
1664
		map.put("Proprietary Motorola software", 110369L);
1665
		map.put("Proprietary Alcatel software", 110370L);
4964 amit.gupta 1666
		map.put("Proprietary software", 110371L);
4706 amit.gupta 1667
		map.put("Samsung bada", 110357L);
1668
		map.put("Samsung bada 1.2", 110358L);
1669
		map.put("Symbian 40", 110360L);
1670
		map.put("Symbian 60", 110361L);
1671
		map.put("Symbian^3", 110362L);
1672
		map.put("Symbian Anna", 110363L);
1673
		map.put("Symbian Belle", 110364L);
1674
		map.put("iOS 4", 110365L);
1675
		map.put("iOS 5", 110366L);
4964 amit.gupta 1676
 
4706 amit.gupta 1677
		return map;
4964 amit.gupta 1678
 
4706 amit.gupta 1679
	}
5370 amit.gupta 1680
 
1681
	private Object clone(Object object) throws Exception{
1682
		// Serializing and deserializing to clone the slide
1683
		// serialize
1684
		ByteArrayOutputStream bos = new ByteArrayOutputStream();
1685
		ObjectOutputStream out = new ObjectOutputStream(bos);
1686
		out.writeObject(object);
4964 amit.gupta 1687
 
5370 amit.gupta 1688
		// De-serialization
1689
		ByteArrayInputStream bis = new ByteArrayInputStream(
1690
				bos.toByteArray());
1691
		ObjectInputStream in = new ObjectInputStream(bis);
1692
		return in.readObject();
1693
 
1694
	}
1695
 
1696
	/**
1697
	 * 
1698
	 * @throws Exception
1699
	 */
1700
	private void copyMedia(String newEntityId, String oldEntityId, Media media) throws Exception {
1701
		String mediaDirPath = Utils.CONTENT_DB_PATH + "media" + File.separator + newEntityId;
1702
		File mediaDir = new File(mediaDirPath);
1703
		if(!mediaDir.exists()) {
1704
			mediaDir.mkdir();
1705
		} 
1706
 
1707
		String mediaFilePath = mediaDirPath + File.separator + media.getFileName();
1708
		String oldMediaFilePath = media.getLocation();
1709
 
1710
		File mediaFile = new File(mediaFilePath);
1711
		mediaFile.createNewFile();
1712
 
1713
		File oldMediaFile = new File(oldMediaFilePath);
1714
 
1715
		InputStream in = new FileInputStream(oldMediaFile);
1716
 
1717
		// appending output stream
1718
		// @rajveer : replacing the existing file 
1719
		OutputStream out = new FileOutputStream(mediaFile); 
1720
 
1721
		try {
1722
			IOUtils.copy(in, out);
1723
		}
1724
		finally {
1725
			IOUtils.closeQuietly(in);
1726
			IOUtils.closeQuietly(out);
1727
		}
1728
		media.setLocation(mediaFilePath);
1729
	}
5396 amit.gupta 1730
 
1731
	private void migrateHeadSetBack() throws Exception {
1732
		Map<Long, Long>migratorMap = new HashMap<Long, Long>();
1733
		migratorMap.put(77777000L,1000291L);
1734
		migratorMap.put(77777001L,1000292L);
1735
		migratorMap.put(77777002L,1000293L);
1736
		migratorMap.put(77777003L,1000294L);
1737
		migratorMap.put(77777004L,1000295L);
1738
		migratorMap.put(77777005L,1000296L);
1739
		migratorMap.put(77777006L,1000297L);
1740
		migratorMap.put(77777007L,1000298L);
1741
		migratorMap.put(77777008L,1000299L);
1742
		migratorMap.put(77777009L,1000300L);
1743
		migratorMap.put(77777010L,1000301L);
1744
		migratorMap.put(77777011L,1000302L);
1745
		migratorMap.put(77777012L,1000303L);
1746
		migratorMap.put(77777013L,1000304L);
1747
		migratorMap.put(77777014L,1000305L);
1748
		migratorMap.put(77777015L,1000306L);
1749
		migratorMap.put(77777016L,1000351L);
1750
		migratorMap.put(77777017L,1000352L);
1751
		migratorMap.put(77777018L,1000353L);
1752
		migratorMap.put(77777019L,1000363L);
1753
		migratorMap.put(77777020L,1000364L);
1754
		migratorMap.put(77777021L,1000365L);
1755
		migratorMap.put(77777022L,1000425L);
1756
		migratorMap.put(77777023L,1000426L);
1757
		migratorMap.put(77777024L,1000430L);
1758
		migratorMap.put(77777025L,1000434L);
1759
		migratorMap.put(77777026L,1000435L);
1760
		migratorMap.put(77777027L,1000436L);
1761
		migratorMap.put(77777028L,1000437L);
1762
		migratorMap.put(77777029L,1000438L);
1763
		migratorMap.put(77777030L,1000439L);
1764
		migratorMap.put(77777031L,1000440L);
1765
		migratorMap.put(77777032L,1000441L);
1766
		migratorMap.put(77777033L,1000442L);
1767
		migratorMap.put(77777034L,1000443L);
1768
		migratorMap.put(77777035L,1000444L);
1769
		migratorMap.put(77777036L,1000445L);
1770
		migratorMap.put(77777037L,1000446L);
1771
		migratorMap.put(77777038L,1000447L);
1772
		migratorMap.put(77777039L,1000449L);
1773
		migratorMap.put(77777040L,1000450L);
1774
		migratorMap.put(77777041L,1000451L);
1775
		migratorMap.put(77777042L,1000452L);
1776
		migratorMap.put(77777043L,1000453L);
1777
		migratorMap.put(77777044L,1000454L);
1778
		migratorMap.put(77777045L,1000455L);
1779
		migratorMap.put(77777046L,1000518L);
1780
		migratorMap.put(77777047L,1000521L);
1781
		migratorMap.put(77777048L,1000572L);
1782
		migratorMap.put(77777049L,1000575L);
1783
		migratorMap.put(77777050L,1000623L);
1784
		migratorMap.put(77777051L,1000625L);
1785
		migratorMap.put(77777052L,1000626L);
1786
		migratorMap.put(77777053L,1000627L);
1787
		migratorMap.put(77777054L,1000628L);
1788
		migratorMap.put(77777055L,1000874L);
1789
		migratorMap.put(77777056L,1001200L);
1790
		migratorMap.put(77777057L,1001375L);
1791
		migratorMap.put(77777058L,1001376L);
1792
		migratorMap.put(77777059L,1001378L);
1793
		migratorMap.put(77777060L,1001382L);
1794
		migratorMap.put(77777061L,1001808L);
1795
		migratorMap.put(77777062L,1001809L);
1796
		migratorMap.put(77777063L,1001810L);
1797
		migratorMap.put(77777064L,1001811L);
1798
		migratorMap.put(77777065L,1001812L);
1799
		migratorMap.put(77777066L,1001814L);
1800
		migratorMap.put(77777067L,1001815L);
1801
		migratorMap.put(77777068L,1001816L);
1802
		migratorMap.put(77777069L,1001817L);
1803
		migratorMap.put(77777070L,1001818L);
1804
		migratorMap.put(77777071L,1001819L);
1805
		migratorMap.put(77777072L,1001820L);
1806
		migratorMap.put(77777073L,1001821L);
1807
		migratorMap.put(77777074L,1001822L);
1808
		migratorMap.put(77777075L,1001823L);
1809
		migratorMap.put(77777076L,1001824L);
1810
		migratorMap.put(77777077L,1001825L);
1811
		migratorMap.put(77777078L,1002318L);
1812
		migratorMap.put(77777079L,1002320L);
1813
		migratorMap.put(77777080L,1003852L);
1814
		migratorMap.put(77777081L,1003853L);
1815
		migratorMap.put(77777082L,1003854L);
1816
		migratorMap.put(77777083L,1003855L);
1817
		migratorMap.put(77777084L,1003856L);
1818
		migratorMap.put(77777085L,1003857L);
1819
		migratorMap.put(77777086L,1003916L);
1820
		migratorMap.put(77777087L,1003917L);
1821
		migratorMap.put(77777088L,1003918L);
1822
		migratorMap.put(77777089L,1003919L);
1823
		migratorMap.put(77777090L,1003920L);
1824
		migratorMap.put(77777091L,1003921L);
1825
		migratorMap.put(77777092L,1003922L);
1826
		migratorMap.put(77777093L,1003923L);
1827
		migratorMap.put(77777094L,1003924L);
1828
		migratorMap.put(77777095L,1003925L);
1829
		migratorMap.put(77777096L,1003926L);
1830
		migratorMap.put(77777097L,1003927L);
1831
		migratorMap.put(77777098L,1004087L);
1832
		migratorMap.put(77777099L,1004088L);
1833
		migratorMap.put(77777100L,1004089L);
1834
		migratorMap.put(77777101L,1004134L);
1835
		migratorMap.put(77777102L,1004135L);
1836
		migratorMap.put(77777103L,1004139L);
1837
 
1838
		for(Map.Entry<Long, Long> entry : migratorMap.entrySet()) {
1839
			Long newId  = entry.getKey();
1840
			Long validId  = entry.getValue();
1841
			Entity entity  = CreationUtils.getEntity(newId);
1842
			EntityState es = CreationUtils.getEntityState(newId);
1843
			Slide sl = entity.getSlide(130130);
1844
			entity.setID(validId);
1845
			es.setID(validId);
1846
 
1847
			long newCategoryId = 10015;
1848
			if(sl==null){
1849
				newCategoryId = 10082;
1850
			}else{			
1851
				for (Feature f : sl.getFeatures()){
1852
					if(f.getFeatureDefinitionID() == 120323){
1853
						newCategoryId = 10015;
1854
					} else {
1855
						newCategoryId = 10082;
1856
					}
1857
				}
1858
			}
1859
			entity.setCategoryID(newCategoryId);
1860
			es.setCategoryID(newCategoryId);
5370 amit.gupta 1861
 
5396 amit.gupta 1862
			if(entity.getSlides()!=null){
1863
				for(Slide sl1 : entity.getSlides()) {
1864
					FreeformContent ffc = sl1.getFreeformContent();
1865
					if(ffc != null){
1866
						Map<String, Media> mediaMap = ffc.getMedias();
1867
						if(mediaMap!=null){
1868
							for(Media media : mediaMap.values()){
1869
								if(media.getType().equals(Type.IMAGE) || media.getType().equals(Type.DOCUMENT)){
1870
									copyMedia(String.valueOf(validId), String.valueOf(newId),media);
1871
								}
1872
							}
1873
						}
1874
					}
1875
				}
1876
			}
1877
			CreationUtils.updateEntity(entity);
1878
			CreationUtils.updateEntityState(es);
1879
			CreationUtils.deleteEntity(newId);
1880
			System.out.println(validId + " : " + es.getCategoryID() + ", removed entity id:" + newId);
1881
 
1882
		}
1883
 
1884
	}
1885
 
457 rajveer 1886
}
5370 amit.gupta 1887