Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SB-21700 - Conflicts Resolve ( Release 4.4.0 Into Master ) #494

Open
wants to merge 677 commits into
base: master
Choose a base branch
from
Open
Changes from 27 commits
Commits
Show all changes
677 commits
Select commit Hold shift + click to select a range
90a7388
Issue #SB-24872: Validate invalid batchId in data-exhaust job
utk14 Jun 30, 2021
9e6dc20
Merge branch 'release-4.1.0' of https://github.com/Sunbird-Ed/sunbird…
utk14 Jun 30, 2021
07731e6
Issue #SB-24872: Added testcase for failed scenario if all batches ar…
utk14 Jul 1, 2021
13abd20
Merge pull request #412 from ishawakankar/4.0.0
sowmya-dixit Jul 1, 2021
b559f6d
Merge branch 'release-4.0.0' of https://github.com/Sunbird-Ed/sunbird…
utk14 Jul 1, 2021
72ba3e0
Merge Conflict issue resolved
utk14 Jul 1, 2021
3330be0
Merge pull request #414 from utk14/merge-branch-4.0
sowmya-dixit Jul 1, 2021
42e4597
SB-24841 checking cluster and block locations of user, since block an…
Hari-stackroute Jul 1, 2021
3cb0239
Issue SC-000: Code changes to load parallel batches from report cluster
RevathiKotla Jul 2, 2021
a562998
Merge remote-tracking branch 'upstream/release-4.1.0' into SB-24841
Hari-stackroute Jul 2, 2021
fa514ae
Merge branch 'release-4.1.0' of https://github.com/Sunbird-Ed/sunbird…
utk14 Jul 2, 2021
ca5ccaf
Merge Conflict issue resolved
utk14 Jul 2, 2021
4678eda
Merge pull request #413 from utk14/validate-batch-4.1
SanthoshVasabhaktula Jul 2, 2021
27aae6e
Issue SC-000: Remove the println statement
RevathiKotla Jul 2, 2021
12239c0
SB-24841 checking cluster and block locations of user, since block an…
Hari-stackroute Jul 2, 2021
24507a7
Issue SC-000:Merge branch 'release-4.0.0' of https://github.com/Sunbi…
RevathiKotla Jul 2, 2021
e90d629
Merge pull request #410 from RevathiKotla/release-4.0.0
SanthoshVasabhaktula Jul 2, 2021
d336d2e
Issue SC-000: Fix the persist code issue
RevathiKotla Jul 2, 2021
eea1b9e
Issue SC-000:Merge branch 'release-4.0.0' of https://github.com/Sunbi…
RevathiKotla Jul 2, 2021
b64f9f6
Merge pull request #415 from RevathiKotla/release-4.0.0
sowmya-dixit Jul 2, 2021
88fdec7
Issue DIK-5379 fix: Collection Summary V2 Job Issue fix
manjudr Jul 6, 2021
0d28092
Issue DIK-5379 fix: Collection Summary V2 Job Issue fix
manjudr Jul 6, 2021
8d085c5
Issue DIK-5379 fix: Collection Summary V2 Job Issue fix
manjudr Jul 6, 2021
2baf21c
Issue DIK-5379 fix: Added batchsize config
manjudr Jul 6, 2021
4471fc7
Merge pull request #417 from manjudr/collection-summary-v2-job-fix
SanthoshVasabhaktula Jul 6, 2021
dba1521
SB-24841 shadow-user, validated-user reports code
Hari-stackroute Jun 29, 2021
1ab6eaf
SB-24841 checking cluster and block locations of user, since block an…
Hari-stackroute Jul 1, 2021
3c7de7c
SB-24841 checking cluster and block locations of user, since block an…
Hari-stackroute Jul 2, 2021
739bc05
Issue DIK-5379 fix: removed the duplicate cassandra connection
manjudr Jul 7, 2021
4462d65
Merge pull request #418 from manjudr/collection-summary-v2-job-fix
manjudr Jul 7, 2021
abfafc4
Issue #TG-1016 feat: Fix JOB_END log and metrics generation for exhau…
sowmya-dixit Jul 8, 2021
aa80462
Issue #TG-1016 feat: Fix JOB_END log and metrics generation for exhau…
sowmya-dixit Jul 8, 2021
1adab42
Merge pull request #419 from sowmya-dixit/release-4.1.0
RevathiKotla Jul 8, 2021
6053fed
fix(Jenkinsfile): remove hardcoded tag
rjshrjndrn Jul 8, 2021
9ea7464
Issue merge DIK-5379: - Merge remote-tracking branch 'upstream/releas…
manjudr Jul 8, 2021
a883e08
Issue #SB-25551: Enhancement in data exhuast jobs
utk14 Jul 8, 2021
ddd80c4
Issue #SB-25551: Review comments resolved
utk14 Jul 8, 2021
46e2e2a
Issue #SB-25551: Review comments resolved
utk14 Jul 8, 2021
11270b0
Issue DIK-5379 fix: Optimised the imports
manjudr Jul 8, 2021
05b414f
Issue #SB-25551: Enhancement in data exhuast jobs for excluding expir…
utk14 Jul 8, 2021
86fd6c2
Issue #SB-25551: Circle ci issue resolved
utk14 Jul 8, 2021
41b2997
Merge pull request #422 from utk14/validate-batch-4.1
manjudr Jul 8, 2021
38c98ee
Issue #SB-24966: Course User Info exhaust to exclude rows for users w…
utk14 Jul 9, 2021
14addb4
Issue DIK-5431 fix: Users not able to join the Course Issue fix
manjudr Jul 9, 2021
79dd0e8
Issue DIK-5431 fix: Removed the unused job
manjudr Jul 9, 2021
8df030f
Issue DIK-5431 fix: Removed the unused job
manjudr Jul 9, 2021
6454728
Issue DIK-5431 fix: Removed the unused job
manjudr Jul 9, 2021
c5ee52a
Issue DIK-5431 fix: Adding persist to collection summary v2 job
manjudr Jul 9, 2021
0443d4f
Issue #SB-24966: Testcase issue resolved
utk14 Jul 9, 2021
eed8eaa
Issue #SB-24966: Testcase issue resolved
utk14 Jul 9, 2021
7a627d3
Issue #SB-24966: Testcase issue resolved
utk14 Jul 9, 2021
ef256e0
Merge pull request #424 from manjudr/course-batch-status-updater-fix
RevathiKotla Jul 9, 2021
5d8f94f
Merge pull request #423 from utk14/validate-batch-4.1
manjudr Jul 9, 2021
1dfdd3f
Issue #DIK5379 merge: Merge remote-tracking branch 'upstream/release-…
manjudr Jul 12, 2021
b7fb9c9
Merge remote-tracking branch 'upstream/release-4.1.0' into conflict-r…
manjudr Jul 12, 2021
37d9ecb
Merge pull request #421 from manjudr/conflict-resolve
RevathiKotla Jul 13, 2021
a1f0c63
Merge remote-tracking branch 'upstream/release-4.1.0' into SB-25676
Hari-stackroute Jul 14, 2021
1604621
SB-25676 user declared phone is not coming, taken the value from user…
Hari-stackroute Jul 14, 2021
26e3516
Merge pull request #428 from Hari-stackroute/SB-25676
anandp504 Jul 15, 2021
693bce4
Password Protected CSV Data Product Completed
Jul 15, 2021
3227858
Data Product for Password Protection CSV
Jul 16, 2021
334115a
Issue #SB-25480 feat: UCI Response Exhaust - initial commit
sowmya-dixit Jul 20, 2021
e044fd3
Issue #SB-25480 feat: UCI Response Exhaust - base trait implementation
sowmya-dixit Jul 20, 2021
0c69d67
Issue #SB-25480 feat: UCI Response Exhaust - base trait implementation
sowmya-dixit Jul 20, 2021
cf26b52
Issue SB-25481 feat: Implementation of UCI Private Exhaust Job
manjudr Jul 20, 2021
52d7356
Issue SB-25481 feat: Testcase Implementation of UCI Private Exhaust Job
manjudr Jul 20, 2021
309514e
Issue SB-25481 feat: Code refactor - Moved the connection logic to ba…
manjudr Jul 20, 2021
6e5d52e
Issue SB-25481 feat: Testcase fixes UCI Private Exhaust Job
manjudr Jul 20, 2021
4278576
Issue SB-25481 feat: Testcase Configuration Update UCI Private Exhaus…
manjudr Jul 20, 2021
bc6b934
Issue SB-25481 feat: Testcase Configuration Update UCI Private Exhaus…
manjudr Jul 20, 2021
070c4a1
Issue SB-25481 feat: Testcase Configuration Update UCI Private Exhaus…
manjudr Jul 20, 2021
8a01649
Issue SB-25481 feat: UCI Exhaust Job - File path changes
manjudr Jul 20, 2021
87064e9
Issue SB-25481 feat: UCI Exhaust Job - Testcase fixes
manjudr Jul 20, 2021
aa309bf
Issue SB-25481 feat: UCI Exhaust Job - Testcase fixes
manjudr Jul 20, 2021
e6690c7
Issue SB-25481 feat: UCI Exhaust Job - Enhancements of UCI Testcases
manjudr Jul 21, 2021
6fc6acc
Issue #SB-25480 feat: UCI Response Exhaust - implementation
sowmya-dixit Jul 21, 2021
79a1e2a
Issue #SB-25480 feat: UCI Response Exhaust - implementation
sowmya-dixit Jul 21, 2021
b394ff6
SC-000: Fix the druid report submitter issue to handle exceptions
RevathiKotla Jul 21, 2021
c643851
Issue SB-25481 feat: AEC Decryption logic to decrypt the username to …
manjudr Jul 21, 2021
f79bff2
Issue SB-25481:merge Merge branch 'UCI-exhaust' of https://github.com…
manjudr Jul 21, 2021
9a20b68
Issue SB-25481 feat: Added more testcase assertions
manjudr Jul 21, 2021
7cdc32c
Merge pull request #433 from RevathiKotla/release-4.1.0
anandp504 Jul 21, 2021
538a210
Issue #SB-25480 feat: UCI Response Exhaust - implementation
sowmya-dixit Jul 21, 2021
17dcde2
Merge branch 'UCI-exhaust' of github.com:sowmya-dixit/sunbird-data-pr…
sowmya-dixit Jul 21, 2021
f7b51e9
Issue SB-25481 feat: Classname issue fix
manjudr Jul 21, 2021
50be913
Issue SB-25481 feat: UCI Response exhaust test telemetry data
manjudr Jul 21, 2021
b9366a6
On Demand Druid getDateRange datasource parameter addition
Jul 21, 2021
f2d7ba9
On Demand Druid getDateRange datasource parameter addition
Jul 21, 2021
a645dbb
Delete TestOnDemandDruidExhaust.scala
Shakthieshwari Jul 21, 2021
580f0ba
On Demand Druid getDateRange datasource parameter addition
Jul 21, 2021
8adf5f3
Merge branch 'SB-24105' of github.com:shikshalokam/sunbird-data-produ…
Jul 21, 2021
290aaf8
SB-25851 in geo-reports location details now picked from orglocation …
Hari-stackroute Jul 21, 2021
191eee5
Merge remote-tracking branch 'upstream/release-4.1.0' into SB-25851
Hari-stackroute Jul 21, 2021
069c3a3
SB-25851 removed deleted columns from data.cql
Hari-stackroute Jul 22, 2021
5eaa85e
Merge pull request #435 from Hari-stackroute/SB-25851
RevathiKotla Jul 22, 2021
f855d14
Issue #SB-25480 feat: UCI Response Exhaust - implementation
sowmya-dixit Jul 22, 2021
0ae458b
Merge branch 'UCI-exhaust' of github.com:sowmya-dixit/sunbird-data-pr…
sowmya-dixit Jul 22, 2021
909c05b
Issue #SB-25480 feat: UCI Response Exhaust - implementation
sowmya-dixit Jul 22, 2021
23178f5
Issue #SB-25480 feat: UCI Response Exhaust - test cases
sowmya-dixit Jul 22, 2021
02f1ef5
Issue #SB-25480 feat: UCI Response Exhaust - test cases
sowmya-dixit Jul 22, 2021
5eef990
Issue SB-25481 feat: UCI Private Exhaust Job Testcase Enhancement
manjudr Jul 22, 2021
b53f554
Issue SB-25481 feat: UCI Private Exhaust Job Testcase Enhancement
manjudr Jul 22, 2021
af9713d
Merge branch 'UCI-exhaust' of https://github.com/sowmya-dixit/sunbird…
manjudr Jul 22, 2021
8c4cd85
Issue #SB-25480 feat: UCI Response Exhaust - remove commented code
sowmya-dixit Jul 22, 2021
7530eb0
Merge branch 'UCI-exhaust' of github.com:sowmya-dixit/sunbird-data-pr…
sowmya-dixit Jul 22, 2021
2d467a1
Issue SB-25481 feat: Removed the null value from the AES Decryption l…
manjudr Jul 22, 2021
7dede85
Merge branch 'UCI-exhaust' of https://github.com/sowmya-dixit/sunbird…
manjudr Jul 22, 2021
8caafe4
Issue #SB-25287 fix : Fixed CourseBatch status update issue
Jul 22, 2021
92189de
Issue SB-25481 fix: Disabling the course consumption testcase
manjudr Jul 23, 2021
fb06da9
Ignored test case
Jul 23, 2021
6637016
Issue SB-25481 fix: Disabling the assessment correction job testcase
manjudr Jul 23, 2021
de67f4d
Ignored test case
Jul 23, 2021
70c5af5
Merge pull request #434 from sowmya-dixit/UCI-exhaust
sowmya-dixit Jul 23, 2021
a719407
Issue #SB-25287 fix : Fixed CourseBatch status update issue
Jul 23, 2021
9d68e6b
Merge remote-tracking branch 'upstream/release-4.1.0' into SB-25287-f…
Jul 27, 2021
92aa61e
Merge pull request #441 from PradyumnaNagendra/SB-25287-fix-4.1.0
manjudr Jul 27, 2021
3ef725a
circle cli build failed issue fix by mocking the test case
Jul 28, 2021
7c8be36
circle cli build failed issue fix by mocking the test case
Jul 28, 2021
22e40af
circle cli build failed issue fix by mocking the test case
Jul 28, 2021
514af78
test assessment correction event print
Jul 29, 2021
9555f35
Issue #0000: AssessmentCorrectionModel testcase fixed for V3Event des…
utk14 Jul 29, 2021
9687a57
Issue #0000: AssessmentCorrectionModel testcase fixed for V3Event des…
utk14 Jul 29, 2021
556b859
Issue #0000: AssessmentCorrectionModel testcase fixed for V3Event des…
utk14 Jul 29, 2021
8a07b1f
Merge branch 'release-4.2.0' of github.com:Sunbird-Ed/sunbird-data-pr…
Jul 29, 2021
e4b9432
test assessment correct model event change
Jul 29, 2021
7057bc7
Merge pull request #442 from utk14/release-4.2.0
sowmya-dixit Jul 29, 2021
cbe14e7
test assessment correct model event change
Jul 29, 2021
0c7b247
test assessment correct model event change
Jul 29, 2021
0f4878c
Issue SB-25287 feat: course batch status updater job error handling -…
manjudr Aug 2, 2021
6f9b51a
Merge pull request #446 from manjudr/course-batch
manjudr Aug 2, 2021
f0bd834
Modify the code according to PR changes
Ashwiniev95 Aug 5, 2021
f0a37f8
Merge branch 'SB-24105' of https://github.com/shikshalokam/sunbird-da…
Ashwiniev95 Aug 5, 2021
a50b704
re-used existing case class
Aug 5, 2021
8c7c28a
re-used existing case class
Aug 5, 2021
a2f17b7
re-used existing case class
Aug 5, 2021
942f41a
filesMutable variable issue fixed
Aug 6, 2021
eb5f8ea
changes raised by santhosh
Aug 6, 2021
8325ab0
Modify according to design
Ashwiniev95 Aug 11, 2021
619c5ea
Merge pull request #431 from shikshalokam/SB-24105
SanthoshVasabhaktula Aug 12, 2021
116af90
Issue #000 feat: Assessment Score Correction Job
manjudr Aug 16, 2021
2dbe620
Issue SB-24793 feat: Assessment score migration Job
manjudr Aug 16, 2021
b8d8602
Issue SB-24793 feat: Assessment score migration Job
manjudr Aug 16, 2021
a9929d2
Issue SB-24793 feat: Enabling the code coverage
manjudr Aug 16, 2021
cbd393a
Issue #DIK-5641 feat: Review comments chagnes - Correcting the score…
manjudr Aug 17, 2021
53e62f6
Issue #DIK-5641 feat: Reverting unwanted changes
manjudr Aug 17, 2021
18a7bc4
Issue #SB-25381: Sourcing report changes
ishawakankar Aug 17, 2021
162ddce
Issue #DIK-5641 feat: Enabling the code coverage
manjudr Aug 17, 2021
10d3c62
Test case changes
ishawakankar Aug 17, 2021
c639669
Merge pull request #454 from ishawakankar/4.2
sowmya-dixit Aug 17, 2021
f84736d
Issue #SB-26292: Exhaust job fix to restrict expired collection reque…
utk14 Aug 18, 2021
f1bd026
Issue #SB-26292: print statements removed
utk14 Aug 18, 2021
28671cb
Issue #SB-26292: fix for invalid batchid testcase failure
utk14 Aug 18, 2021
47eb257
Merge pull request #455 from utk14/release-4.1
sowmya-dixit Aug 18, 2021
39a02a5
Issue #DIK-5641 feat: Save csv file issue fix
manjudr Aug 19, 2021
a46f91e
Merge pull request #447 from Sunbird-Ed/release-4.1.0
manjudr Aug 19, 2021
c342246
Issue SB-24793 feat: Assessment score migration data product job imp…
manjudr Aug 22, 2021
4078195
Issue SB-24793 feat: Assessment score correction cleanup
manjudr Aug 23, 2021
ec5ed08
Issue SB-24793 feat: Assessment score correction cleanup
manjudr Aug 23, 2021
f9ef9cb
Issue SB-24793 feat: Score metrics correction script update
manjudr Aug 23, 2021
60afe37
Issue SB-24793 feat: Score metrics correction script update
manjudr Aug 23, 2021
5dd8aed
Issue SB-24793 feat: Score metrics correction script job config update
manjudr Aug 23, 2021
f5702c2
Issue SB-24793 feat: Score migration testcase issue fix
manjudr Aug 25, 2021
a82e20b
Issue #0 | lastcompletedtime field issue fixes
kumarks1122 Aug 25, 2021
1a5d03d
Issue SB-24793 feat: Score migration testcase issue fix
manjudr Aug 25, 2021
95ab162
Merge pull request #457 from kumarks1122/release-4.1.0-collection-rec…
manjudr Aug 25, 2021
4e25923
Issue #0 | Refresh user data feature in Usercacheindexer
kumarks1122 Aug 25, 2021
7aef423
Issue SB-24793 feat: Code review comments changes -
manjudr Aug 26, 2021
1bce986
Issue SB-24793 feat: Code review comments changes -
manjudr Aug 26, 2021
673f833
Issue #0 | language field removed in Usercacheindexer
kumarks1122 Aug 27, 2021
5c08eb0
Issue #0 | language field removed in Usercacheindexer
kumarks1122 Aug 27, 2021
a4933d5
Issue SB-24793 feat: Certificate deletion logic implementation
manjudr Aug 30, 2021
474317d
Issue SB-24793 feat: Certificate deletion logic implementation
manjudr Aug 30, 2021
a29b5df
Unknown job type Bug Fix
Ashwiniev95 Aug 31, 2021
f55a647
Issue SB-24793 feat: Certificate deletion logic implementation
manjudr Aug 31, 2021
ac0c3fc
Merge pull request #459 from shikshalokam/SB-24105
sowmya-dixit Aug 31, 2021
3c55414
Issue SB-24793 feat: assessment record deletion
manjudr Aug 31, 2021
3fa2342
Issue SB-24793 feat: Assessment logic change for removing invalid att…
manjudr Sep 1, 2021
3fb0dc5
Issue SB-24793 feat: Assessment logic change for removing invalid att…
manjudr Sep 1, 2021
aacd825
Issue SB-24793 feat: Adding write consistency level to the job.
manjudr Sep 1, 2021
11efe75
Issue SB-24793 feat: Testcase fixes
manjudr Sep 1, 2021
5895880
Issue SB-24793 feat: Code coverage update
manjudr Sep 2, 2021
0e6a937
Remove state_slug from code
Ashwiniev95 Sep 2, 2021
6280714
Issue SB-24793 feat: Code review comments fixes
manjudr Sep 2, 2021
5943ba0
close sparksession in main method under onDemandDruidExhaustJob
Sep 3, 2021
85b24d7
Issue SB-24793 feat: removed the unwanted files
manjudr Sep 3, 2021
8df916c
Issue SB-24793 feat: Added the error handling in the file write
manjudr Sep 3, 2021
5b9db79
druid datasource name and project status column add
Sep 3, 2021
7c1e530
druid datasource name and project status column add
Sep 3, 2021
859dc35
coverage bug fix on new code
Sep 3, 2021
3f24e7d
coverage bug fix on new code
Sep 3, 2021
997a6cd
Issue #0 | Usercacheindexer fixes added
kumarks1122 Sep 4, 2021
430d315
coverage off for main methof exception block
Sep 6, 2021
3e92c9a
Merge pull request #461 from shikshalokam/SB-24105
RevathiKotla Sep 6, 2021
2d51efa
Issue SB-24793 feat: Code review comments fixes -
manjudr Sep 7, 2021
a95db0b
Issue #0 | Usercacheindexer fixes added
kumarks1122 Sep 7, 2021
cbdac81
Merge pull request #456 from manjudr/assessment-score-migration-update
sowmya-dixit Sep 8, 2021
c8c8ca3
Merge pull request #458 from kumarks1122/release-4.1.0-user-cache-ind…
anandp504 Sep 8, 2021
2e24cc6
Issue SB-24793 feat: Changing the reporting cluster IP
manjudr Sep 13, 2021
ac5a898
Issue SB-24793 feat: Changing the reporting cluster IP
manjudr Sep 13, 2021
532e672
Issue SB-24793 feat: Changing the reporting cluster IP
manjudr Sep 13, 2021
1729755
Merge pull request #463 from manjudr/assessment-score-migration-update
RevathiKotla Sep 13, 2021
189b909
Merge pull request #464 from Sunbird-Ed/release-4.1.0
sowmya-dixit Sep 15, 2021
8eea3d3
Revert "SB-24793 Release 4.1.0 into Release-4.2.0"
manjudr Sep 15, 2021
1c1e28a
Add Logger statements
Ashwiniev95 Sep 15, 2021
323b606
Merge pull request #468 from shikshalokam/SB-24105_1
sowmya-dixit Sep 15, 2021
9576235
Merge pull request #465 from Sunbird-Ed/revert-464-release-4.1.0
manjudr Sep 16, 2021
bf7ab1c
Issue #0 | 4.1 user cache indexer and collection reconciliation chang…
kumarks1122 Sep 16, 2021
80d36fe
Merge pull request #469 from kumarks1122/release-4.2.0-etl-cache-indexer
manjudr Sep 16, 2021
c4e2fad
Issue #0000: VDN Reports Job Start Logs Added
utk14 Sep 16, 2021
76faa33
Issue #0000: VDN Reports Job Error handling added
utk14 Sep 16, 2021
f014fca
Merge pull request #472 from utk14/VDN-reports-4.2
manjudr Sep 16, 2021
b22a162
Non-Password CSV Logic Fix
Sep 16, 2021
b95986f
Non-Password CSV Logic Fix
Sep 16, 2021
d85eac7
Merge branch 'release-4.2.0' of github.com:Sunbird-Ed/sunbird-data-pr…
Sep 16, 2021
f5b14be
Non-Password CSV Logic Fix
Sep 16, 2021
d839feb
Merge pull request #473 from shikshalokam/SB-24105_1
sowmya-dixit Sep 16, 2021
35e101f
Issue DIK-5812: Soucing Metrics Report Fix With Druid Stream Query Pa…
utk14 Sep 20, 2021
0f82409
Issue DIK-5812: Testcase resolved
utk14 Sep 20, 2021
f3c59b2
Issue DIK-5812: Testcase resolved
utk14 Sep 20, 2021
71c008d
Merge pull request #474 from utk14/VDN-reports-4.2
RevathiKotla Sep 20, 2021
475beab
Revert "SB-24793 - " Revert Release 4.1.0 into Release-4.2.0""
manjudr Sep 21, 2021
efa4459
Merge pull request #478 from Sunbird-Ed/release-4.2.0
manjudr Sep 21, 2021
f1ca95b
Merge pull request #476 from Sunbird-Ed/revert-465-revert-464-release…
sowmya-dixit Sep 21, 2021
fd7edba
Issue #0000: ETB Metrics fix for druid issue
utk14 Sep 22, 2021
d305517
Issue #0000: Testcase fixed
utk14 Sep 22, 2021
410dcb4
Merge pull request #479 from utk14/release-4.2.1
RevathiKotla Sep 22, 2021
eb7e776
Issue #TG-1089 fix: Remove On-demand druid exhaust jobs from this rep…
sowmya-dixit Sep 27, 2021
21754db
Merge pull request #480 from sowmya-dixit/release-4.3.0
RevathiKotla Oct 4, 2021
e0ce038
Merge remote-tracking branch 'upstream/release-4.2.1' into conflict-f…
manjudr Oct 6, 2021
0353ccb
Merge pull request #483 from manjudr/conflict-fixes
manjudr Oct 6, 2021
2a81465
Merge pull request #484 from Sunbird-Ed/release-4.3.0
manjudr Oct 7, 2021
7c9fe87
Issue DD-1717 feat: Generating the duplicate metric to check the numb…
manjudr Oct 8, 2021
d53a6ee
Issue DD-1717 feat: Generating the duplicate metric to check the numb…
manjudr Oct 8, 2021
afd7d67
Issue DD-1717 feat: Generating the duplicate metric to check the numb…
manjudr Oct 8, 2021
4680c09
Issue DD-1717 feat: Testcase update
manjudr Oct 8, 2021
cb57979
Issue DD-1717 feat: Testcase update
manjudr Oct 8, 2021
9952930
Merge pull request #485 from manjudr/update-metrics
sowmya-dixit Oct 8, 2021
8c5739f
Issue #TG-1114 fix: Logging for Cassandra migration script
sowmya-dixit Oct 8, 2021
5b57558
Issue #TG-1114 fix: Logging for Cassandra migration script
sowmya-dixit Oct 8, 2021
5081ade
Merge pull request #486 from sowmya-dixit/release-4.3.0
RevathiKotla Oct 11, 2021
dc9bd3b
SB-26472 filtering active user consent into the reports
reshmi-nair Oct 26, 2021
dc6e69a
Merge pull request #489 from Sunbird-Ed/release-4.3.0
RevathiKotla Oct 26, 2021
97ca886
SB-26472 filtering active user consent into the reports
reshmi-nair Oct 26, 2021
63e4dee
SB-26472 filtering active user consent into the reports
reshmi-nair Oct 26, 2021
90ba2ce
SB-26472 filtering active user consent into the reports
reshmi-nair Oct 26, 2021
30b5e2f
Merge pull request #490 from reshmi-nair/SB-26472
anandp504 Oct 26, 2021
f517779
SB-27386 filtering common rows in consent and user_declarations
Hari-stackroute Oct 27, 2021
56cbd33
SB-27386 join condition first should be done on userid's
Hari-stackroute Oct 27, 2021
b3ee6d1
Merge pull request #491 from Hari-stackroute/SB-27386
anandp504 Oct 27, 2021
b38f2df
Merge remote-tracking branch 'upstream/release-4.4.0' into HEAD
manjudr Nov 30, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -2,7 +2,7 @@ package org.sunbird.analytics.audit

import com.datastax.spark.connector.cql.CassandraConnectorConf
import org.apache.spark.SparkContext
import org.apache.spark.sql.functions.{col, lit, when}
import org.apache.spark.sql.functions.{col, lit, unix_timestamp, when}
import org.apache.spark.sql.types.StructType
import org.apache.spark.sql.{DataFrame, Row, SaveMode, SparkSession}
import org.ekstep.analytics.framework.Level.INFO
@@ -62,8 +62,8 @@ object CourseBatchStatusUpdaterJob extends optional.Application with IJob with B
def updateBatchStatus(updaterConfig: JobConfig, collectionBatchDF: DataFrame)(implicit sc: SparkContext): CourseBatchStatusMetrics = {
val currentDate = getDateFormat().format(new Date)
val computedDF = collectionBatchDF.withColumn("updated_status",
when(lit(currentDate).gt(col("enddate")), 2).otherwise(
when(lit(currentDate).geq(col("startdate")), 1).otherwise(col("status"))
when(unix_timestamp(lit(currentDate), "yyyy-MM-dd").gt(unix_timestamp(col("enddate"), "yyyy-MM-dd")), 2).otherwise(
when(unix_timestamp(lit(currentDate), "yyyy-MM-dd").geq(unix_timestamp(col("startdate"), "yyyy-MM-dd")), 1).otherwise(col("status"))
))
val finalDF = computedDF.filter(col("updated_status") =!= col("status"))
.drop("status").withColumnRenamed("updated_status", "status")
Original file line number Diff line number Diff line change
@@ -1,33 +1,29 @@
package org.sunbird.analytics.exhaust.collection

import java.security.MessageDigest
import java.util.concurrent.atomic.AtomicInteger

import com.datastax.spark.connector.cql.CassandraConnectorConf
import org.apache.spark.SparkContext
import org.apache.spark.sql.{DataFrame, Dataset, Encoders, SparkSession, Row}
import org.apache.spark.sql.cassandra._
import org.apache.spark.sql.functions._
import org.apache.spark.sql.types.StructType
import org.ekstep.analytics.framework.{FrameworkContext, IJob, JobConfig}
import org.ekstep.analytics.framework.Level.INFO
import org.apache.spark.sql._
import org.ekstep.analytics.framework.Level.{ERROR, INFO}
import org.ekstep.analytics.framework.conf.AppConf
import org.ekstep.analytics.framework.dispatcher.KafkaDispatcher
import org.ekstep.analytics.framework.driver.BatchJobDriver.getMetricJson
import org.ekstep.analytics.framework.util.DatasetUtil.extensions
import org.ekstep.analytics.framework.util.{CommonUtil, JSONUtils, JobLogger, RestUtil}
import org.ekstep.analytics.framework.{FrameworkContext, IJob, JobConfig, StorageConfig}
import org.ekstep.analytics.util.Constants
import org.joda.time.{DateTime, DateTimeZone}
import org.joda.time.format.{DateTimeFormat, DateTimeFormatter}
import org.sunbird.analytics.exhaust.{BaseReportsJob, JobRequest, OnDemandExhaustJob, RequestStatus}
import org.joda.time.{DateTime, DateTimeZone}
import org.sunbird.analytics.exhaust.{BaseReportsJob, JobRequest, OnDemandExhaustJob}
import org.sunbird.analytics.util.DecryptUtil

import scala.collection.immutable.List
import java.security.MessageDigest
import java.util.concurrent.CompletableFuture

import org.ekstep.analytics.framework.StorageConfig
import org.ekstep.analytics.framework.dispatcher.KafkaDispatcher
import org.ekstep.analytics.framework.driver.BatchJobDriver.getMetricJson
import org.ekstep.analytics.framework.Level.ERROR
import scala.collection.mutable.{Buffer, ListBuffer}
import java.util.concurrent.atomic.AtomicInteger
import scala.collection.immutable.List
import scala.collection.mutable.ListBuffer


case class UserData(userid: String, state: Option[String] = Option(""), district: Option[String] = Option(""), orgname: Option[String] = Option(""), firstname: Option[String] = Option(""), lastname: Option[String] = Option(""), email: Option[String] = Option(""),
@@ -56,7 +52,7 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh

/** START - Job Execution Methods */
def main(config: String)(implicit sc: Option[SparkContext] = None, fc: Option[FrameworkContext] = None) {

JobLogger.init(jobName)
JobLogger.start(s"$jobName started executing - ver3", Option(Map("config" -> config, "model" -> jobName)))

@@ -118,7 +114,7 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh
executeOnDemand(custodianOrgId, userCachedDF);
}
}

def executeStandAlone(custodianOrgId: String, userCachedDF: DataFrame)(implicit spark: SparkSession, fc: FrameworkContext, config: JobConfig): Metrics = {
val modelParams = config.modelParams.getOrElse(Map[String, Option[AnyRef]]());
val batchId = modelParams.get("batchId").asInstanceOf[Option[String]];
@@ -313,36 +309,44 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh
JobLogger.log("Channel details at processBatches", Some(Map("channel" -> requestChannel, "file size" -> processedSize, "completed batches" -> processedCount)), INFO)

var newFileSize: Long = 0
for (batch <- filterCollectionBatches(collectionBatches)) yield {
if (checkRequestProcessCriteria(processedCount, processedSize)) {
val userEnrolmentBatchDF = getUserEnrolmentDF(batch.collectionId, batch.batchId, false)
.join(userCachedDF, Seq("userid"), "inner")
.withColumn("collectionName", lit(batch.collectionName))
.withColumn("batchName", lit(batch.batchName));
val filteredDF = filterUsers(batch, userEnrolmentBatchDF).persist();
val res = CommonUtil.time(filteredDF.count);
JobLogger.log("Time to fetch batch enrolment", Some(Map("timeTaken" -> res._1, "count" -> res._2)), INFO)
try {
val res = CommonUtil.time(processBatch(filteredDF, batch));
val reportDF = res._2
val files = reportDF.saveToBlobStore(storageConfig, "csv", getFilePath(batch.batchId,requestId.getOrElse("")), Option(Map("header" -> "true")), None)
newFileSize = fc.getHadoopFileUtil().size(files.head, spark.sparkContext.hadoopConfiguration)
CollectionBatchResponse(batch.batchId, files.head, "SUCCESS", "", res._1, newFileSize);
} catch {
case ex: Exception => ex.printStackTrace(); CollectionBatchResponse(batch.batchId, "", "FAILED", ex.getMessage, 0, 0);
} finally {
processedCount= processedCount + 1
processedSize=processedSize + newFileSize
unpersistDFs();
filteredDF.unpersist(true);
val batches = filterCollectionBatches(collectionBatches)
val parallelProcessLimit = AppConf.getConfig("exhaust.parallel.batch.load.limit").toInt
val parallelBatches = batches.sliding(parallelProcessLimit,parallelProcessLimit).toList
for(parallelBatch <- parallelBatches) yield {
val userEnrolmentDf = getUserEnrolmentDF(parallelBatch.map(f => f.batchId), true)
val batchResponseList= for (batch <- parallelBatch) yield {
if (checkRequestProcessCriteria(processedCount, processedSize)) {
val userEnrolmentBatchDF = userEnrolmentDf.where(col("batchid") === batch.batchId && col("courseid") === batch.collectionId)
.join(userCachedDF, Seq("userid"), "inner")
.withColumn("collectionName", lit(batch.collectionName))
.withColumn("batchName", lit(batch.batchName))
.repartition(AppConf.getConfig("exhaust.user.parallelism").toInt,col("userid"),col("courseid"),col("batchid"))
val filteredDF = filterUsers(batch, userEnrolmentBatchDF).persist()
val res = CommonUtil.time(filteredDF.count);
JobLogger.log("Time to fetch batch enrolment", Some(Map("timeTaken" -> res._1, "count" -> res._2)), INFO)
try {
val res = CommonUtil.time(processBatch(filteredDF, batch));
val reportDF = res._2
val files = reportDF.saveToBlobStore(storageConfig, "csv", getFilePath(batch.batchId, requestId.getOrElse("")), Option(Map("header" -> "true")), None)
newFileSize = fc.getHadoopFileUtil().size(files.head, spark.sparkContext.hadoopConfiguration)
CollectionBatchResponse(batch.batchId, files.head, "SUCCESS", "", res._1, newFileSize);
} catch {
case ex: Exception => ex.printStackTrace(); CollectionBatchResponse(batch.batchId, "", "FAILED", ex.getMessage, 0, 0);
} finally {
processedCount = processedCount + 1
processedSize = processedSize + newFileSize
unpersistDFs();
filteredDF.unpersist(true)
}
}
else {
CollectionBatchResponse("", "", "PROCESSING", "", 0, 0);
}
}
else
{
CollectionBatchResponse("", "", "PROCESSING", "", 0, 0);
}
userEnrolmentDf.unpersist(true);
batchResponseList
}
}
}.flatMap(f=>f)

// returns Map of request_id and list of its duplicate requests
def getDuplicateRequests(requests: Array[JobRequest]): Map[String, List[JobRequest]] = {
@@ -366,7 +370,6 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh
step-1: filter reqHashMap - with more than 1 entry in value list which indicates duplicates
sample filtered map data
Map<"hash-1", List<JobRequest1, JobRequest3>>

step-2: transform map to have first request_id as key and remaining req list as value
sample final map data
Map<"request_id-1", List<JobRequest3>>
@@ -413,11 +416,14 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh
.where(col("id") === "custodianOrgId" && col("field") === "custodianOrgId").select(col("value")).select("value").first().getString(0)
}

def getUserEnrolmentDF(collectionId: String, batchId: String, persist: Boolean)(implicit spark: SparkSession): DataFrame = {

def getUserEnrolmentDF(batchIds: List[String], persist: Boolean)(implicit spark: SparkSession): DataFrame = {
val cols = getEnrolmentColumns();
val df = loadData(userEnrolmentDBSettings, cassandraFormat, new StructType())
.where(col("batchid") === batchId && col("courseid") === collectionId && lower(col("active")).equalTo("true") && (col("enrolleddate").isNotNull || col("enrolled_date").isNotNull))
implicit val sqlContext = new SQLContext(spark.sparkContext)
import sqlContext.implicits._
val userDf = loadData(userEnrolmentDBSettings, cassandraFormat, new StructType())
val batchDf = spark.sparkContext.parallelize(batchIds).toDF("batchid")
val df =batchDf.join(userDf,Seq("batchid")).where(lower(col("active")).equalTo("true")
&& (col("enrolleddate").isNotNull || col("enrolled_date").isNotNull))
.withColumn("enrolleddate", UDFUtils.getLatestValue(col("enrolled_date"), col("enrolleddate")))
.select(cols.head, cols.tail: _*);

@@ -442,7 +448,8 @@ trait BaseCollectionExhaustJob extends BaseReportsJob with IJob with OnDemandExh

def getUserCacheDF(cols: Seq[String], persist: Boolean)(implicit spark: SparkSession): DataFrame = {
val schema = Encoders.product[UserData].schema
val df = loadData(userCacheDBSettings, redisFormat, schema).withColumn("username", concat_ws(" ", col("firstname"), col("lastname"))).select(cols.head, cols.tail: _*);
val df = loadData(userCacheDBSettings, redisFormat, schema).withColumn("username", concat_ws(" ", col("firstname"), col("lastname"))).select(cols.head, cols.tail: _*)
.repartition(AppConf.getConfig("exhaust.user.parallelism").toInt,col("userid"))
if (persist) df.persist() else df
}

@@ -530,10 +537,10 @@ object UDFUtils extends Serializable {
val completionPercentage = udf[Int, Map[String, Int], Int](completionPercentageFunction)

def getLatestValueFun(newValue: String, staleValue: String): String = {
Option(newValue)
.map(xValue => if (xValue.nonEmpty) xValue else staleValue)
.getOrElse(staleValue)
Option(newValue)
.map(xValue => if (xValue.nonEmpty) xValue else staleValue)
.getOrElse(staleValue)
}

val getLatestValue = udf[String, String, String](getLatestValueFun)
}
}
Original file line number Diff line number Diff line change
@@ -88,15 +88,17 @@ object ProgressExhaustJob extends optional.Application with BaseCollectionExhaus
def filterAssessmentDF(assessmentDF: DataFrame): DataFrame = {
val bestScoreReport = AppConf.getConfig("assessment.metrics.bestscore.report").toBoolean
val columnName: String = if (bestScoreReport) "total_score" else "last_attempted_on"
val df = Window.partitionBy("user_id", "batch_id", "course_id", "content_id").orderBy(desc(columnName))
val df = Window.partitionBy("userid", "batchid", "courseid", "content_id").orderBy(desc(columnName))
assessmentDF.withColumn("rownum", row_number.over(df)).where(col("rownum") === 1).drop("rownum")
}

def getAssessmentAggData(userEnrolmentDF: DataFrame)(implicit spark: SparkSession, fc: FrameworkContext, config: JobConfig): DataFrame = {
val df = loadData(assessmentAggDBSettings, cassandraFormat, new StructType());
val assessmentDF = userEnrolmentDF.join(df, userEnrolmentDF("userid") === df("user_id") && userEnrolmentDF("courseid") === df("course_id") && userEnrolmentDF("batchid") === df("batch_id"), "inner")
.select("course_id", "batch_id", "user_id", "content_id", "total_max_score", "total_score", "grand_total", "last_attempted_on").persist();
Console.println(assessmentDF.explain())
val df = loadData(assessmentAggDBSettings, cassandraFormat, new StructType())
.select("course_id", "batch_id", "user_id", "content_id", "total_max_score", "total_score", "grand_total", "last_attempted_on")
.withColumnRenamed("user_id", "userid")
.withColumnRenamed("batch_id", "batchid")
.withColumnRenamed("course_id", "courseid")
val assessmentDF = userEnrolmentDF.join(df, Seq("userid","courseid","batchid"), "inner").persist()
persistedDF.append(assessmentDF)
assessmentDF
}
@@ -108,20 +110,17 @@ object ProgressExhaustJob extends optional.Application with BaseCollectionExhaus
val hierarchy = JSONUtils.deserialize[Map[String, AnyRef]](row.getString(1))
filterAssessmentsFromHierarchy(List(hierarchy), List(AppConf.getConfig("assessment.metrics.supported.contenttype")), AssessmentData(row.getString(0), List()))
}).toDF()
.select(col("courseid"), explode_outer(col("assessmentIds")).as("contentid"))
.select(col("courseid"), explode_outer(col("assessmentIds")).as("contentid"))

val assessAggdf = filterAssessmentDF(getAssessmentAggData(userEnrolmentDF))
.select("course_id", "batch_id", "user_id", "content_id", "total_max_score", "total_score", "grand_total")
.withColumnRenamed("user_id", "userid")
.withColumnRenamed("batch_id", "batchid")
.withColumnRenamed("course_id", "courseid")

val dataDF = contentDataDF.join(assessAggdf, contentDataDF.col("courseid") === assessAggdf.col("courseid") && contentDataDF.col("contentid") === assessAggdf.col("content_id"), "inner").select(assessAggdf.col("*"))
.select("courseid", "batchid", "userid", "content_id", "total_max_score", "total_score", "grand_total")

val dataDF = contentDataDF.join(assessAggdf, contentDataDF.col("courseid") === assessAggdf.col("courseid")
&& contentDataDF.col("contentid") === assessAggdf.col("content_id"), "inner").select(assessAggdf.col("*"))
val assessmentAggSpec = Window.partitionBy("userid", "batchid", "courseid")
val df = dataDF.withColumn("agg_score", sum("total_score") over assessmentAggSpec)
.withColumn("agg_max_score", sum("total_max_score") over assessmentAggSpec)
.withColumn("total_sum_score", concat(ceil((col("agg_score") * 100) / col("agg_max_score")), lit("%"))).cache();
.withColumn("total_sum_score", concat(ceil((col("agg_score") * 100) / col("agg_max_score")), lit("%"))).persist()
persistedDF.append(df);
df;
}
Loading