Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
29451 manish 1
package com.smartdukaan.cron.scheduled;
2
 
3
import java.io.IOException;
4
import java.nio.file.Files;
5
import java.nio.file.Paths;
6
import java.time.LocalDate;
7
import java.time.LocalDateTime;
8
import java.time.format.DateTimeFormatter;
9
import java.util.ArrayList;
10
import java.util.HashMap;
29471 amit.gupta 11
import java.util.HashSet;
29451 manish 12
import java.util.List;
13
import java.util.Map;
29466 amit.gupta 14
import java.util.stream.Collectors;
29451 manish 15
 
16
import org.apache.logging.log4j.LogManager;
17
import org.apache.logging.log4j.Logger;
18
import org.json.JSONObject;
19
import org.springframework.beans.factory.annotation.Autowired;
20
import org.springframework.stereotype.Component;
21
import org.springframework.util.StringUtils;
22
 
23
import com.smartdukaan.cron.migrations.RunOnceTasks;
24
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
25
import com.spice.profitmandi.dao.entity.fofo.ActivatedImei;
26
import com.spice.profitmandi.dao.model.VivoImeiAndActivationTimeStampModel;
27
import com.spice.profitmandi.dao.repository.fofo.ActivatedImeiRepository;
28
import com.spice.profitmandi.service.inventory.InventoryService;
29
 
30
import okhttp3.Cookie;
31
import okhttp3.CookieJar;
32
import okhttp3.FormBody;
33
import okhttp3.HttpUrl;
34
import okhttp3.OkHttpClient;
35
import okhttp3.Request;
36
import okhttp3.RequestBody;
37
import okhttp3.Response;
38
 
39
@Component
40
class VivoImeiActivationService {
41
 
42
	@Autowired
43
	InventoryService inventoryService;
44
 
45
	@Autowired
46
	CaptchaService captchaService;
29466 amit.gupta 47
 
29451 manish 48
	@Autowired
49
	ActivatedImeiRepository activatedImeiRepository;
50
 
51
	private static final Logger LOGGER = LogManager.getLogger(RunOnceTasks.class);
52
 
53
	private final Map<String, List<Cookie>> cookieStore = new HashMap<>();
54
 
55
	public void checkImeiActivation() throws ProfitMandiBusinessException, IOException, Exception {
29466 amit.gupta 56
 
29451 manish 57
		OkHttpClient okHttpClient = new OkHttpClient.Builder().cookieJar(new CookieJar() {
58
			@Override
59
			public void saveFromResponse(HttpUrl httpUrl, List<Cookie> list) {
60
				LOGGER.info("SAVE fROM - {}", httpUrl.host());
61
				cookieStore.put(httpUrl.host(), list);
62
			}
63
 
64
			@Override
65
			public List<Cookie> loadForRequest(HttpUrl httpUrl) {
66
				List<Cookie> cookies = cookieStore.get(httpUrl.host());
67
				LOGGER.info("load from - {}", httpUrl.host());
68
				return cookies != null ? cookies : new ArrayList<Cookie>();
69
			}
70
		}).build();
29466 amit.gupta 71
 
29451 manish 72
		String captchaBreak = this.getNewCaptcha(okHttpClient);
73
 
74
		LOGGER.info("Captcha code {}", captchaBreak);
75
 
29466 amit.gupta 76
		List<VivoImeiAndActivationTimeStampModel> imeisActivationList = activatedImeiRepository
77
				.selectVivoImeiAndActivationTimeStamp();
29451 manish 78
 
29477 amit.gupta 79
		LOGGER.info("Complete list size is - {}", imeisActivationList.size());
29468 amit.gupta 80
		this.getImeiActivation(captchaBreak, okHttpClient, imeisActivationList);
29451 manish 81
 
29466 amit.gupta 82
	}
29451 manish 83
 
29466 amit.gupta 84
	public String getNewCaptcha(OkHttpClient okHttpClient) throws Exception {
29451 manish 85
 
86
		LOGGER.info("okHttpClient" + okHttpClient);
87
 
88
		HttpUrl vivoSupportUrl = HttpUrl.parse("https://www.vivo.com/in/support/generatingCodes");
89
		Request request = new Request.Builder().url(vivoSupportUrl).build();
90
 
91
		Response response = okHttpClient.newCall(request).execute();
92
		LOGGER.info("cookie {}", this.cookieStore.values());
29466 amit.gupta 93
 
29451 manish 94
		LOGGER.info("vivoSupportUrl" + vivoSupportUrl);
95
		LOGGER.info("request" + request);
96
		LOGGER.info("request" + request);
97
 
98
		String filePath = "/tmp/captcha.avif";
99
		Files.write(Paths.get(filePath), response.body().bytes());
100
 
101
		// Get all relevent imes from activatedImei and inventoryItem for vivo
102
 
29466 amit.gupta 103
		String captchaBreak = captchaService.getCaptchaCode(filePath);
29451 manish 104
 
105
		return captchaBreak;
106
	}
107
 
29469 amit.gupta 108
	public void getImeiActivation(String captchaBreak, OkHttpClient okHttpClient,
29468 amit.gupta 109
			List<VivoImeiAndActivationTimeStampModel> imeisActivationList) throws Exception {
29466 amit.gupta 110
 
29471 amit.gupta 111
		for (VivoImeiAndActivationTimeStampModel vivoImeiAndActivationTimeStampModel: new HashSet<>(imeisActivationList)) {
29468 amit.gupta 112
			String imei = vivoImeiAndActivationTimeStampModel.getSerialNumber();
113
			RequestBody formBody = new FormBody.Builder().add("imei", imei).add("code", captchaBreak).build();
29466 amit.gupta 114
 
29451 manish 115
			Request request1 = new Request.Builder().url("https://www.vivo.com/in/support/checkCode").post(formBody)
116
					.build();
117
 
118
			Response response2 = okHttpClient.newCall(request1).execute();
119
			JSONObject imeiActivationJson = new JSONObject(response2.body().string());
120
			JSONObject data = imeiActivationJson.getJSONObject("data");
29466 amit.gupta 121
 
29469 amit.gupta 122
			int status = data.getInt("status");
123
			if (status == 0) {
124
				captchaBreak = this.getNewCaptcha(okHttpClient);
125
				continue;
126
			} else if (status == 2) {
29470 amit.gupta 127
				LOGGER.info("Received status 2 for {}", imei);
29469 amit.gupta 128
				continue;
129
			}
130
 
29466 amit.gupta 131
			JSONObject imeiQueryDto = data.getJSONObject("imeiQueryDto");
132
 
29451 manish 133
			Object dueTimeObject = imeiQueryDto.get("dueTime");
29466 amit.gupta 134
			String dueTimeString = dueTimeObject.toString();
135
 
29451 manish 136
			DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
29466 amit.gupta 137
			String dueTimeSplit = dueTimeString.split(" ")[0];
138
 
29469 amit.gupta 139
 
29466 amit.gupta 140
 
141
			if (!StringUtils.isEmpty(dueTimeSplit)) {
142
				LocalDate dateTime = LocalDate.parse(dueTimeSplit, formatter);
29468 amit.gupta 143
				ActivatedImei activatedImei = activatedImeiRepository.selectBySerialNumber(imei);
29469 amit.gupta 144
				if (activatedImei == null) {
29466 amit.gupta 145
					activatedImei = new ActivatedImei();
146
					activatedImei.setActivationTimestamp(dateTime.atStartOfDay().minusYears(1));
29468 amit.gupta 147
					activatedImei.setSerialNumber(imei);
29466 amit.gupta 148
					activatedImei.setCreateTimestamp(LocalDateTime.now());
149
					activatedImeiRepository.persist(activatedImei);
150
 
151
				} else {
152
					activatedImei.setActivationTimestamp(dateTime.atStartOfDay().minusYears(1));
153
 
154
				}
155
 
156
				LOGGER.info("activatedImei" + activatedImei);
157
 
158
				LOGGER.info("vivoImeiStatusModel" + dateTime.atStartOfDay());
159
 
29451 manish 160
			}
29466 amit.gupta 161
 
29469 amit.gupta 162
 
29451 manish 163
		}
164
	}
165
}