Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21723 ashik.ali 1
package com.spice.profitmandi.dao.repository.dtr;
21545 ashik.ali 2
 
22097 kshitij.so 3
import java.lang.reflect.Type;
4
import java.util.ArrayList;
23793 tejbeer 5
import java.util.Arrays;
24995 amit.gupta 6
import java.util.HashMap;
27120 amit.gupta 7
import java.util.Iterator;
22097 kshitij.so 8
import java.util.List;
22125 ashik.ali 9
import java.util.Map;
24995 amit.gupta 10
import java.util.stream.Collectors;
21545 ashik.ali 11
 
24031 amit.gupta 12
import org.apache.logging.log4j.LogManager;
23568 govind 13
import org.apache.logging.log4j.Logger;
23793 tejbeer 14
import org.bson.Document;
24031 amit.gupta 15
import org.json.JSONObject;
21545 ashik.ali 16
 
22097 kshitij.so 17
import com.google.gson.Gson;
18
import com.google.gson.reflect.TypeToken;
21545 ashik.ali 19
import com.mongodb.BasicDBObject;
20
import com.mongodb.DB;
21
import com.mongodb.DBCollection;
22097 kshitij.so 22
import com.mongodb.DBCursor;
21545 ashik.ali 23
import com.mongodb.DBObject;
24
import com.mongodb.MongoClient;
23793 tejbeer 25
import com.mongodb.client.AggregateIterable;
26
import com.mongodb.client.MongoCollection;
27
import com.mongodb.client.MongoDatabase;
21545 ashik.ali 28
import com.mongodb.util.JSON;
27122 amit.gupta 29
import com.spice.profitmandi.common.util.Utils;
24011 tejbeer 30
import com.spice.profitmandi.dao.entity.dtr.NotificationCampaigns;
25380 amit.gupta 31
import com.spice.profitmandi.dao.model.ContentPojo;
22097 kshitij.so 32
import com.spice.profitmandi.dao.model.FofoForm;
22496 amit.gupta 33
import com.spice.profitmandi.dao.model.RetailerFofoInterest;
21545 ashik.ali 34
 
35
public class Mongo {
22384 amit.gupta 36
 
23568 govind 37
	private static final Logger LOGGER = LogManager.getLogger(Mongo.class);
21545 ashik.ali 38
 
22165 amit.gupta 39
	private static final String CONTENT = "CONTENT";
21545 ashik.ali 40
	private static final String SITE_CONTENT = "siteContent";
41
	private static final String CATALOG_DB = "Catalog";
42
	private static final String MASTER_DATA = "MasterData";
22097 kshitij.so 43
	private static final String FOFO_DB = "Fofo";
22335 amit.gupta 44
	private static final String FOFO_BRANDS = "brands";
22446 amit.gupta 45
	private static final String PROFITMANDI_BANNERS = "banners";
22496 amit.gupta 46
	private static final String RETAILER_FOFO_INTEREST = "RetailerFofoInterest";
22097 kshitij.so 47
	private static final String FOFO_FORM_COLLECTION = "RegistrationForm";
24011 tejbeer 48
	private static final String NOTIFICATION_CAMPAIGNS = "notificationcampaigns";
49
	private static final String USER_DB = "User";
21545 ashik.ali 50
	private static final int MONGO_PORT = 27017;
25380 amit.gupta 51
 
52
	private static final Gson gson = new Gson();
27278 amit.gupta 53
	private static final List<String> BLOCKED_BRANDS = Arrays.asList();
25560 amit.gupta 54
	public static final Map<Integer, List<String>> PARTNER_BLoCKED_BRANDS = new HashMap<>();
27120 amit.gupta 55
	public static final Map<Integer, List<String>> PARTNER_ALLOWED_BRANDS = new HashMap<>();
56
 
22165 amit.gupta 57
 
24995 amit.gupta 58
	static {
26343 tejbeer 59
		PARTNER_BLoCKED_BRANDS.put(175135597, Arrays.asList("Vivo"));
60
		PARTNER_BLoCKED_BRANDS.put(175135183, Arrays.asList("Vivo"));
61
		PARTNER_BLoCKED_BRANDS.put(175137445, Arrays.asList("Vivo"));
62
		PARTNER_BLoCKED_BRANDS.put(175137557, Arrays.asList("Vivo"));
63
		PARTNER_BLoCKED_BRANDS.put(175138281, Arrays.asList("Vivo"));
64
		PARTNER_BLoCKED_BRANDS.put(175138441, Arrays.asList("Vivo"));
65
		PARTNER_BLoCKED_BRANDS.put(175138447, Arrays.asList("Vivo"));
66
		PARTNER_BLoCKED_BRANDS.put(175138570, Arrays.asList("Vivo"));
67
		// TITU
68
		PARTNER_BLoCKED_BRANDS.put(175138610, Arrays.asList("Vivo"));
27865 amit.gupta 69
		//HRPHK204 = MOBILE ZONE
70
		PARTNER_BLoCKED_BRANDS.put(175138917, Arrays.asList("Vivo"));
26343 tejbeer 71
		PARTNER_BLoCKED_BRANDS.put(175138611, Arrays.asList("Vivo"));
72
		PARTNER_BLoCKED_BRANDS.put(175138639, Arrays.asList("Vivo"));
73
		PARTNER_BLoCKED_BRANDS.put(175138716, Arrays.asList("Vivo"));
27716 amit.gupta 74
		//Laxmi Communication - Shahbad
27854 amit.gupta 75
		//PARTNER_BLoCKED_BRANDS.put(175138911, Arrays.asList("Vivo"));
27602 amit.gupta 76
		//Chaudhary Electronics
77
		//PARTNER_BLoCKED_BRANDS.put(175138906, Arrays.asList("Vivo"));
27216 amit.gupta 78
		//DY Venturs
27245 amit.gupta 79
		//PARTNER_BLoCKED_BRANDS.put(175138874, Arrays.asList("Vivo"));
26811 amit.gupta 80
		//Pardeep Telecom
26869 amit.gupta 81
		//PARTNER_BLoCKED_BRANDS.put(175138843, Arrays.asList("Vivo"));
26343 tejbeer 82
		// PARTNER_BLoCKED_BRANDS.put(175138733,Arrays.asList("Vivo"));
26600 amit.gupta 83
		//Venus Agencies
84
		//PARTNER_BLoCKED_BRANDS.put(175138801, Arrays.asList("Vivo"));
26459 tejbeer 85
		//PARTNER_BLoCKED_BRANDS.put(175138717, Arrays.asList("Vivo"));
26343 tejbeer 86
		PARTNER_BLoCKED_BRANDS.put(175138803, Arrays.asList("Vivo"));
27484 amit.gupta 87
		//PARTNER_BLoCKED_BRANDS.put(175138821, Arrays.asList("Vivo"));
26343 tejbeer 88
		// PARTNER_BLoCKED_BRANDS.put(175138820,Arrays.asList("Vivo"));
89
		PARTNER_BLoCKED_BRANDS.put(175138718, Arrays.asList("Vivo"));
27216 amit.gupta 90
		//Gaurav Electronics
91
		PARTNER_BLoCKED_BRANDS.put(175138637, Arrays.asList("Vivo"));
26343 tejbeer 92
		// PARTNER_BLoCKED_BRANDS.put(175138814,Arrays.asList("Vivo"));
26421 tejbeer 93
		//PARTNER_BLoCKED_BRANDS.put(175138833, Arrays.asList("Vivo"));
26397 amit.gupta 94
		//Durga Enterprises
26459 tejbeer 95
		//PARTNER_BLoCKED_BRANDS.put(175138832, Arrays.asList("Vivo"));
27120 amit.gupta 96
		PARTNER_ALLOWED_BRANDS.put(172157716, Arrays.asList("Realme"));
27216 amit.gupta 97
		//DY Ventures
98
		PARTNER_ALLOWED_BRANDS.put(175138874, Arrays.asList("Realme"));
27120 amit.gupta 99
		PARTNER_ALLOWED_BRANDS.put(175135227, Arrays.asList("Realme"));
100
		PARTNER_ALLOWED_BRANDS.put(175135707, Arrays.asList("Realme"));
101
		PARTNER_ALLOWED_BRANDS.put(175135923, Arrays.asList("Realme"));
102
		PARTNER_ALLOWED_BRANDS.put(175138372, Arrays.asList("Realme"));
103
		PARTNER_ALLOWED_BRANDS.put(175138520, Arrays.asList("Realme"));
104
		PARTNER_ALLOWED_BRANDS.put(175138522, Arrays.asList("Realme"));
105
		PARTNER_ALLOWED_BRANDS.put(175138541, Arrays.asList("Realme"));
106
		PARTNER_ALLOWED_BRANDS.put(175138674, Arrays.asList("Realme"));
107
		PARTNER_ALLOWED_BRANDS.put(175138716, Arrays.asList("Realme"));
108
		PARTNER_ALLOWED_BRANDS.put(175138801, Arrays.asList("Realme"));
109
		PARTNER_ALLOWED_BRANDS.put(175138812, Arrays.asList("Realme"));
110
		PARTNER_ALLOWED_BRANDS.put(175138813, Arrays.asList("Realme"));
111
		PARTNER_ALLOWED_BRANDS.put(175138814, Arrays.asList("Realme"));
112
		PARTNER_ALLOWED_BRANDS.put(175138816, Arrays.asList("Realme"));
113
		PARTNER_ALLOWED_BRANDS.put(175138820, Arrays.asList("Realme"));
114
		PARTNER_ALLOWED_BRANDS.put(175138836, Arrays.asList("Realme"));
115
		PARTNER_ALLOWED_BRANDS.put(175138838, Arrays.asList("Realme"));
116
		PARTNER_ALLOWED_BRANDS.put(175138840, Arrays.asList("Realme"));
117
		PARTNER_ALLOWED_BRANDS.put(175138842, Arrays.asList("Realme"));
118
		PARTNER_ALLOWED_BRANDS.put(175138843, Arrays.asList("Realme"));
119
		PARTNER_ALLOWED_BRANDS.put(175138847, Arrays.asList("Realme"));
120
		PARTNER_ALLOWED_BRANDS.put(175138858, Arrays.asList("Realme"));
121
		PARTNER_ALLOWED_BRANDS.put(175138859, Arrays.asList("Realme"));
122
		PARTNER_ALLOWED_BRANDS.put(175138860, Arrays.asList("Realme"));
123
		PARTNER_ALLOWED_BRANDS.put(175138862, Arrays.asList("Realme"));
124
		PARTNER_ALLOWED_BRANDS.put(175138863, Arrays.asList("Realme"));
125
		PARTNER_ALLOWED_BRANDS.put(175138865, Arrays.asList("Realme"));
126
		PARTNER_ALLOWED_BRANDS.put(175138868, Arrays.asList("Realme"));
27194 amit.gupta 127
		PARTNER_ALLOWED_BRANDS.put(175138829, Arrays.asList("Realme"));
27200 amit.gupta 128
		PARTNER_ALLOWED_BRANDS.put(175138864, Arrays.asList("Realme"));
27248 amit.gupta 129
		PARTNER_ALLOWED_BRANDS.put(175138878, Arrays.asList("Realme"));
130
		PARTNER_ALLOWED_BRANDS.put(175138876, Arrays.asList("Realme"));
131
		PARTNER_ALLOWED_BRANDS.put(175138883, Arrays.asList("Realme"));
27265 amit.gupta 132
		PARTNER_ALLOWED_BRANDS.put(175138862, Arrays.asList("Realme"));
133
		PARTNER_ALLOWED_BRANDS.put(175138847, Arrays.asList("Realme"));
134
		PARTNER_ALLOWED_BRANDS.put(175138870, Arrays.asList("Realme"));
135
		PARTNER_ALLOWED_BRANDS.put(175138873, Arrays.asList("Realme"));
136
		PARTNER_ALLOWED_BRANDS.put(175138879, Arrays.asList("Realme"));
137
		PARTNER_ALLOWED_BRANDS.put(175138884, Arrays.asList("Realme"));
138
		PARTNER_ALLOWED_BRANDS.put(175138872, Arrays.asList("Realme"));
139
		PARTNER_ALLOWED_BRANDS.put(175138866, Arrays.asList("Realme"));
26343 tejbeer 140
 
24995 amit.gupta 141
	}
142
 
22162 amit.gupta 143
	private MongoClient mongoClient;
144
	private MongoClient contentMongoClient;
145
 
22171 amit.gupta 146
	public Mongo(String mongoHost, String contentMongoHost) {
22165 amit.gupta 147
		try {
22170 amit.gupta 148
			LOGGER.info("mongoHost => {}, contentMongoHost {} ", mongoHost, contentMongoHost);
22165 amit.gupta 149
			mongoClient = new MongoClient(mongoHost, MONGO_PORT);
22169 amit.gupta 150
			contentMongoClient = new MongoClient(contentMongoHost, MONGO_PORT);
22165 amit.gupta 151
		} catch (Exception e) {
152
			e.printStackTrace();
153
		}
21545 ashik.ali 154
	}
24031 amit.gupta 155
 
25380 amit.gupta 156
	public ContentPojo getEntityById(long id) throws Exception {
22162 amit.gupta 157
		DB db = contentMongoClient.getDB(CONTENT);
21545 ashik.ali 158
		DBCollection collection = db.getCollection(SITE_CONTENT);
159
		BasicDBObject obj = new BasicDBObject();
160
		obj.append("_id", id);
161
		DBObject result = collection.findOne(obj);
22165 amit.gupta 162
		if (result == null) {
21545 ashik.ali 163
			throw new Exception();
164
		}
26480 amit.gupta 165
		ContentPojo cp = gson.fromJson(new BasicDBObject(result.toMap()).toJson(), ContentPojo.class);
26530 amit.gupta 166
		if(cp.getDefaultImageUrl()!=null) {
167
			cp.setDefaultImageUrl(cp.getDefaultImageUrl().replaceAll("saholic", "smartdukaan"));
168
		}
26480 amit.gupta 169
		return cp;
21545 ashik.ali 170
	}
25380 amit.gupta 171
 
24995 amit.gupta 172
	public List<DBObject> getMongoBrands(int fofoId, String email, int categoryId) {
173
		List<DBObject> brandsDisplay = this.getBrandsToDisplay(categoryId);
27122 amit.gupta 174
		if(fofoId==Utils.SYSTEM_PARTNER_ID) {
175
			return brandsDisplay; 
176
		}
27120 amit.gupta 177
		Iterator<DBObject> brandsDisplayIterator = brandsDisplay.iterator();
178
		List<String> partnerAllowedBrands = PARTNER_ALLOWED_BRANDS.get(fofoId);
179
		while(brandsDisplayIterator.hasNext()) {
180
			String brand = brandsDisplayIterator.next().get("name").toString();
181
			if(BLOCKED_BRANDS.contains(brand)) {
182
				if(partnerAllowedBrands == null || !partnerAllowedBrands.contains(brand)) {
183
					brandsDisplayIterator.remove();
184
				}
185
			}
186
		}
25560 amit.gupta 187
		if (PARTNER_BLoCKED_BRANDS.containsKey(fofoId)) {
188
			List<String> blockedBrands = PARTNER_BLoCKED_BRANDS.get(fofoId);
24995 amit.gupta 189
			brandsDisplay = brandsDisplay.stream().filter(x -> !blockedBrands.contains(x.get("name")))
190
					.collect(Collectors.toList());
191
		}
192
		return brandsDisplay;
25380 amit.gupta 193
 
24995 amit.gupta 194
	}
22165 amit.gupta 195
 
25380 amit.gupta 196
	public ContentPojo getEntityByName(String name) throws Exception {
22385 amit.gupta 197
		LOGGER.info("Name --- {}", name);
22384 amit.gupta 198
		DB db = contentMongoClient.getDB(CONTENT);
199
		DBCollection collection = db.getCollection(SITE_CONTENT);
200
		BasicDBObject obj = new BasicDBObject();
201
		obj.append("title", name);
25380 amit.gupta 202
		DBObject result = collection.findOne();
22384 amit.gupta 203
		if (result == null) {
204
			throw new Exception();
205
		}
25380 amit.gupta 206
		return gson.fromJson(new BasicDBObject(result.toMap()).toJson(), ContentPojo.class);
22384 amit.gupta 207
	}
208
 
25380 amit.gupta 209
	public void persistEntity(ContentPojo contentPojo) {
210
		DB db = contentMongoClient.getDB(CONTENT);
211
		DBCollection collection = db.getCollection(SITE_CONTENT);
212
		insertOrUpdateById(collection, contentPojo.getId(), contentPojo);
213
 
214
	}
215
 
216
	private static <T> void insertOrUpdateById(DBCollection collection, long id, T obj) {
217
		DBObject dbo = BasicDBObject.parse(gson.toJson(obj));
218
		dbo.put("_id", id);
219
		collection.update(new BasicDBObject("_id", id), dbo, true, false);
220
	}
221
 
22165 amit.gupta 222
	public JSONObject getItemsByBundleId(long bundleId) throws Exception {
22162 amit.gupta 223
		DB db = mongoClient.getDB(CATALOG_DB);
21545 ashik.ali 224
		DBCollection collection = db.getCollection(MASTER_DATA);
225
		BasicDBObject obj = new BasicDBObject();
226
		BasicDBObject in_query = new BasicDBObject();
227
		obj.append("skuBundleId", bundleId);
22165 amit.gupta 228
		in_query.append("$in", new int[] { 1, 2, 3, 4, 5, 6, 7 });
21545 ashik.ali 229
		obj.append("source_id", in_query);
230
		DBObject result = collection.findOne(obj);
22165 amit.gupta 231
		if (result == null) {
21545 ashik.ali 232
			throw new Exception();
233
		}
234
		return new JSONObject(JSON.serialize(result));
235
	}
22165 amit.gupta 236
 
237
	public JSONObject getItemByID(long id) throws Exception {
22162 amit.gupta 238
		DB db = mongoClient.getDB(CATALOG_DB);
21545 ashik.ali 239
		DBCollection collection = db.getCollection(MASTER_DATA);
240
		BasicDBObject obj = new BasicDBObject();
241
		obj.append("_id", id);
242
		DBObject result = collection.findOne(obj);
22165 amit.gupta 243
		if (result == null) {
21545 ashik.ali 244
			throw new Exception();
245
		}
246
		return new JSONObject(JSON.serialize(result));
247
	}
22165 amit.gupta 248
 
249
	public void persistFofoRegInfo(FofoForm ff) {
250
		DB db = mongoClient.getDB(FOFO_DB);
22097 kshitij.so 251
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
22165 amit.gupta 252
		if (ff.get_id() == 0) {
22097 kshitij.so 253
			BasicDBObject orderBy = new BasicDBObject();
254
			orderBy.put("_id", -1);
255
			DBCursor cursor = collection.find().sort(orderBy).limit(1);
256
			long id = 1l;
257
			while (cursor.hasNext()) {
258
				FofoForm existingFofo = gson.fromJson(cursor.next().toString(), FofoForm.class);
259
				id = existingFofo.get_id() + 1;
260
			}
261
			ff.set_id(id);
262
		}
25380 amit.gupta 263
		DBObject dbObject = (DBObject) JSON.parse(gson.toJson(ff));
22097 kshitij.so 264
		collection.save(dbObject);
265
	}
22165 amit.gupta 266
 
22162 amit.gupta 267
	public List<FofoForm> getFofoForms(int offset, int limit) {
22165 amit.gupta 268
		List<FofoForm> ffList = new ArrayList<FofoForm>();
22162 amit.gupta 269
		DB db = mongoClient.getDB(FOFO_DB);
22097 kshitij.so 270
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
271
		BasicDBObject orderBy = new BasicDBObject();
272
		orderBy.put("_id", -1);
273
		DBCursor dbc = collection.find().sort(orderBy).limit(limit).skip(offset);
274
		while (dbc.hasNext()) {
275
			ffList.add(convertJSONToPojo(dbc.next().toString()));
276
		}
277
		return ffList;
278
	}
22165 amit.gupta 279
 
280
	public String getFofoFormJsonStringByFofoId(int fofoId) {
22162 amit.gupta 281
		DB db = mongoClient.getDB(FOFO_DB);
22097 kshitij.so 282
		BasicDBObject filter = new BasicDBObject();
283
		filter.append("_id", fofoId);
284
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
22105 ashik.ali 285
		DBObject fofoDbOject = collection.findOne(filter);
22165 amit.gupta 286
		if (fofoDbOject != null) {
22161 amit.gupta 287
			return fofoDbOject.toString();
288
		} else {
289
			return null;
290
		}
22097 kshitij.so 291
	}
22165 amit.gupta 292
 
293
	public String getFofoFormJsonStringByEmail(String email) {
22162 amit.gupta 294
		DB db = mongoClient.getDB(FOFO_DB);
22155 amit.gupta 295
		BasicDBObject filter = new BasicDBObject();
296
		filter.append("registeredEmail1", email);
297
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
298
		DBObject fofoDbOject = collection.findOne(filter);
22165 amit.gupta 299
		if (fofoDbOject != null) {
22161 amit.gupta 300
			return fofoDbOject.toString();
301
		} else {
302
			return null;
303
		}
22155 amit.gupta 304
	}
22165 amit.gupta 305
 
306
	public String getFofoFormsJsonString() {
22162 amit.gupta 307
		DB db = mongoClient.getDB(FOFO_DB);
22125 ashik.ali 308
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
309
		DBCursor cursor = collection.find();
310
		StringBuilder fofoFormsJsonString = new StringBuilder();
311
		fofoFormsJsonString.append("[");
22165 amit.gupta 312
		while (cursor.hasNext()) {
22125 ashik.ali 313
			fofoFormsJsonString.append(cursor.next().toString());
22165 amit.gupta 314
			if (cursor.hasNext()) {
22125 ashik.ali 315
				fofoFormsJsonString.append(",");
316
			}
317
		}
318
		fofoFormsJsonString.append("]");
319
		return fofoFormsJsonString.toString();
320
	}
22165 amit.gupta 321
 
22162 amit.gupta 322
	public FofoForm getFofoForm(int fofoId) {
22097 kshitij.so 323
		String fofoFormJsonString = getFofoFormJsonStringByFofoId(fofoId);
324
		System.out.println(fofoFormJsonString);
325
		return new Gson().fromJson(fofoFormJsonString, FofoForm.class);
22165 amit.gupta 326
		// return convertJSONToPojo(fofoDbOject.toString());
22097 kshitij.so 327
	}
22165 amit.gupta 328
 
22162 amit.gupta 329
	public FofoForm getFofoForm(String email) {
22155 amit.gupta 330
		String fofoFormJsonString = getFofoFormJsonStringByEmail(email);
331
		System.out.println(fofoFormJsonString);
332
		return new Gson().fromJson(fofoFormJsonString, FofoForm.class);
22165 amit.gupta 333
		// return convertJSONToPojo(fofoDbOject.toString());
22155 amit.gupta 334
	}
21545 ashik.ali 335
 
22165 amit.gupta 336
	private static FofoForm convertJSONToPojo(String json) {
22097 kshitij.so 337
 
22165 amit.gupta 338
		Type type = new TypeToken<FofoForm>() {
339
		}.getType();
22097 kshitij.so 340
 
22165 amit.gupta 341
		return new Gson().fromJson(json, type);
342
 
22097 kshitij.so 343
	}
22165 amit.gupta 344
 
345
	public void updateColumnsById(Map<String, Integer> map, int fofoId) {
22162 amit.gupta 346
		DB db = mongoClient.getDB(FOFO_DB);
22125 ashik.ali 347
		BasicDBObject filter = new BasicDBObject();
348
		filter.append("_id", fofoId);
349
		DBCollection collection = db.getCollection(FOFO_FORM_COLLECTION);
350
		BasicDBObject updateFields = new BasicDBObject();
22165 amit.gupta 351
		for (Map.Entry<String, Integer> entry : map.entrySet()) {
22125 ashik.ali 352
			updateFields.append(entry.getKey(), entry.getValue());
353
		}
354
		BasicDBObject newDocument = new BasicDBObject();
355
		newDocument.append("$set", updateFields);
356
		collection.update(filter, newDocument);
357
	}
24031 amit.gupta 358
 
359
	public List<DBObject> getBrandsToDisplay(int categoryId) {
22335 amit.gupta 360
		DB db = mongoClient.getDB(FOFO_DB);
361
		BasicDBObject filter = new BasicDBObject();
362
		filter.append("active", true);
24031 amit.gupta 363
		if (categoryId != 0) {
364
			filter.append("categoryId", categoryId);
365
		}
22335 amit.gupta 366
		return db.getCollection(FOFO_BRANDS).find(filter).toArray();
367
	}
26343 tejbeer 368
 
26309 amit.gupta 369
	public List<DBObject> getAllBrandsToDisplay(int categoryId) {
370
		DB db = mongoClient.getDB(FOFO_DB);
371
		BasicDBObject filter = new BasicDBObject();
372
		if (categoryId != 0) {
373
			filter.append("categoryId", categoryId);
374
		}
375
		return db.getCollection(FOFO_BRANDS).find(filter).toArray();
376
	}
24031 amit.gupta 377
 
22447 amit.gupta 378
	public List<DBObject> getBannersByType(String bannerType) {
26661 amit.gupta 379
		DB db = mongoClient.getDB(FOFO_DB);
22446 amit.gupta 380
		BasicDBObject filter = new BasicDBObject();
22449 amit.gupta 381
		filter.append("type", bannerType);
22992 amit.gupta 382
		BasicDBObject orderBy = new BasicDBObject();
23008 amit.gupta 383
		orderBy.put("rank", 1);
22992 amit.gupta 384
		return db.getCollection(PROFITMANDI_BANNERS).find(filter).sort(orderBy).toArray();
22446 amit.gupta 385
	}
23793 tejbeer 386
 
387
	@SuppressWarnings("unchecked")
388
	public List<Document> getSubcategoriesToDisplay() {
389
		MongoDatabase db = mongoClient.getDatabase("Catalog");
390
		System.out.println("Connection to MongoDB database successfully");
391
		MongoCollection<Document> collection = db.getCollection("Deals");
24031 amit.gupta 392
 
393
		Document object = new Document().append("$match", new Document().append("category_id", 6).append("showDeal", 1)
394
				.append("dealRankPoints", new Document("$gt", 0)));
23793 tejbeer 395
		Document ob = new Document("$group",
24031 amit.gupta 396
				new Document().append("_id",
397
						new Document().append("subCategoryId", "$subCategoryId").append("subCategory", "$subCategory"))
398
						.append("count", new Document("$sum", 1)));
23793 tejbeer 399
		List<Document> pipeline = Arrays.asList(object, ob);
400
		AggregateIterable<Document> cursor = collection.aggregate(pipeline);
401
 
402
		List<Document> resultDocuments = new ArrayList<>();
403
		for (Document dbo : cursor) {
404
			System.out.println(dbo.toString());
405
			LOGGER.info("categories" + dbo.toString());
406
			resultDocuments.add(dbo);
407
		}
408
		return resultDocuments;
409
	}
410
 
22496 amit.gupta 411
	public boolean saveRetailerInterestOnFofo(RetailerFofoInterest retailerInterest) {
412
		DB db = mongoClient.getDB(FOFO_DB);
413
		Gson gs = new Gson();
414
		DBCollection fofoInterestCollection = db.getCollection(RETAILER_FOFO_INTEREST);
415
		DBObject dbObject = (DBObject) JSON.parse(gs.toJson(retailerInterest));
416
		fofoInterestCollection.save(dbObject);
417
		return true;
418
	}
23793 tejbeer 419
 
22496 amit.gupta 420
	public boolean hasRetailerShownInterest(int userId) {
421
		DB db = mongoClient.getDB(FOFO_DB);
422
		BasicDBObject filter = new BasicDBObject();
23793 tejbeer 423
		filter.append("userId", userId);
22496 amit.gupta 424
		DBCollection fofoInterestCollection = db.getCollection(RETAILER_FOFO_INTEREST);
23793 tejbeer 425
		return fofoInterestCollection.findOne(filter) != null;
22496 amit.gupta 426
	}
24031 amit.gupta 427
 
24011 tejbeer 428
	public void persistNotificationCmpInfo(NotificationCampaigns ff) {
24383 amit.gupta 429
		DB db = mongoClient.getDB(USER_DB);
24011 tejbeer 430
		DBCollection collection = db.getCollection(NOTIFICATION_CAMPAIGNS);
431
		if (ff.get_id() == 0) {
432
			BasicDBObject orderBy = new BasicDBObject();
433
			orderBy.put("_id", -1);
434
			DBCursor cursor = collection.find().sort(orderBy).limit(1);
435
			long id = 1l;
436
			while (cursor.hasNext()) {
437
				Gson gson = new Gson();
24031 amit.gupta 438
				NotificationCampaigns existingFofo = gson.fromJson(cursor.next().toString(),
439
						NotificationCampaigns.class);
24011 tejbeer 440
				id = existingFofo.get_id() + 1;
441
			}
442
			ff.set_id(id);
443
		}
444
		Gson gs = new Gson();
445
		DBObject dbObject = (DBObject) JSON.parse(gs.toJson(ff));
446
		collection.save(dbObject);
447
	}
22097 kshitij.so 448
 
21545 ashik.ali 449
}