-
Notifications
You must be signed in to change notification settings - Fork 0
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
Story/q20 19 #23
base: develop
Are you sure you want to change the base?
Story/q20 19 #23
Changes from 183 commits
03e7120
e4a5a8b
0a74117
2ada5f9
19f9069
ba4267b
2167f2a
bd62381
3d8be96
83e9aa8
df99e9e
a23bc9a
d31e504
b1c48b8
4b261e3
a2a3ccf
5ead2a8
5e63e67
e6db79d
ecab67d
d3cbe2a
dc4c9c3
4ddadf0
27ed3e7
ad11972
82122dc
1425d51
a6375e7
f2f3873
2035910
a52e64a
d73135f
f3d7a5a
8867145
91d1ea6
738db5f
4614aa9
4e9e6e9
44e7c24
33c05a4
4585d32
068ecf5
30298c1
e19ef10
85ad52a
44fb9ae
bd25d2d
1291e9d
d85dc80
3ea2023
58975fd
ef40d9c
3c9592c
a371610
935c843
569803a
a099184
7e9fb96
2558d75
f8d3d42
63dc182
bbfad1c
310a563
25c36b3
e6e07c4
3af5222
d191254
3956605
b25b927
e2e25cf
509e3cb
95bd65c
49981cf
5ebd99c
e1654dc
d77619d
d4e32a1
12ca58d
12e5325
1cc84ce
8a51ab0
7c2ed96
1a64864
a5be290
bbc9813
d0575da
5ecab8b
9815c06
ebf3325
3b08100
29acec1
2091064
ece353e
425ecaf
cc5b478
ebd5a60
e4c4ca4
2313e87
430ca90
b9c036c
a63b893
5d41516
ed1746a
8b8ae17
f2ff9e2
c1f4f09
e8718ee
2cba6cc
25513df
bc33ec1
43de630
419f668
14e261d
1305bb7
6f222c9
86208ab
433d214
23ad602
b22d407
4058d2c
a2d6d5b
e1c3b33
dde92e1
14b2ff4
aad3e95
830bdc4
cedf185
2eede6c
4d92223
7d7e144
af95ceb
28cc4c7
39e7bc5
54e39a3
7eaaa43
aecbb8e
cf42c39
6743f67
c8e2cfa
5be7a71
042da8f
d539efb
23c1dba
4bdd28c
11c7322
e374c05
468f35c
a194e14
4848a2f
a83519e
6ccb356
38d9994
1775498
643c0c1
def1c1a
489a236
46cfbd4
37d1f81
7784067
4c0ca46
517d697
0058a6c
c4c4436
ca54d84
56d6635
0ef1a95
fc99228
3e05448
2ca90e5
29ee7b9
fa56f02
47e1274
6e362ee
cc54be3
7b4acc0
24666d4
2492f19
740c589
5570d08
6626db7
ce57820
050afff
0a429ba
4f77dc2
2de4433
2db6fc6
7519a39
2527a8b
6fe474e
7edb536
09d697f
4228f31
c18e489
5cbc2a1
54f4fd2
76f159e
718301c
c361808
2f7c527
2e028dd
996f7d7
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
package edu.asu.diging.quadriga.core.conceptpower.data; | ||
|
||
import java.util.List; | ||
|
||
import org.springframework.data.jpa.repository.Query; | ||
import org.springframework.data.repository.PagingAndSortingRepository; | ||
import org.springframework.stereotype.Repository; | ||
|
||
import edu.asu.diging.quadriga.core.conceptpower.model.ConceptCache; | ||
|
||
/** | ||
* | ||
* An interface used to retrieve data from conceptpower_concept_entry table that | ||
* stores data extracted from ConceptPower | ||
* | ||
* @author poojakulkarni | ||
* | ||
*/ | ||
@Repository | ||
public interface ConceptCacheRepository extends PagingAndSortingRepository<ConceptCache, String> { | ||
|
||
@Query("SELECT c from ConceptCache c WHERE ?1 in elements(c.alternativeUris)") | ||
public List<ConceptCache> findConceptByAlternativeURI(String uri); | ||
|
||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
package edu.asu.diging.quadriga.core.conceptpower.data; | ||
|
||
import org.springframework.data.repository.PagingAndSortingRepository; | ||
import org.springframework.stereotype.Repository; | ||
|
||
import edu.asu.diging.quadriga.core.conceptpower.model.ConceptType; | ||
|
||
/** | ||
* An interface used to retrieve data from conceptpower_concept_type table that | ||
* stores information for a concept's type extracted from ConceptPower | ||
* | ||
* @author poojakulkarni | ||
* | ||
*/ | ||
@Repository | ||
public interface ConceptTypeRepository extends PagingAndSortingRepository<ConceptType, String> { | ||
|
||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,223 @@ | ||
package edu.asu.diging.quadriga.core.conceptpower.model; | ||
|
||
import java.io.Serializable; | ||
import java.time.LocalDateTime; | ||
import java.util.List; | ||
|
||
import javax.persistence.CollectionTable; | ||
import javax.persistence.ElementCollection; | ||
import javax.persistence.Entity; | ||
import javax.persistence.Id; | ||
import javax.persistence.Lob; | ||
import javax.persistence.Table; | ||
import javax.persistence.Transient; | ||
|
||
import org.apache.commons.lang3.StringUtils; | ||
import org.hibernate.annotations.LazyCollection; | ||
import org.hibernate.annotations.LazyCollectionOption; | ||
|
||
/** | ||
* This class represents the 'conceptpower_concept_cache' table present in the | ||
* database that stores cached concept data | ||
* | ||
* @author Digital Innovation Group | ||
* | ||
*/ | ||
@Entity | ||
@Table(name = "conceptpower_concept_cache") | ||
public class ConceptCache implements Serializable, Comparable<ConceptCache> { | ||
|
||
private static final long serialVersionUID = 6260562492095202271L; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. should start at 1 |
||
|
||
@Id | ||
private String uri; | ||
private String id; | ||
private String word; | ||
private String pos; | ||
|
||
@Lob | ||
private String description; | ||
|
||
private String conceptList; | ||
private String typeId; | ||
private boolean deleted; | ||
private LocalDateTime lastUpdated; | ||
|
||
@ElementCollection | ||
@LazyCollection(LazyCollectionOption.FALSE) | ||
@CollectionTable(name = "conceptpower_alternative_uris") | ||
private List<String> alternativeUris; | ||
|
||
@ElementCollection | ||
@LazyCollection(LazyCollectionOption.FALSE) | ||
@CollectionTable(name = "conceptpower_equal_to") | ||
private List<String> equalTo; | ||
|
||
@ElementCollection | ||
@LazyCollection(LazyCollectionOption.FALSE) | ||
@CollectionTable(name = "conceptpower_wordnetids") | ||
private List<String> wordNetIds; | ||
|
||
private String creatorId; | ||
|
||
@Transient | ||
private ConceptType conceptType; | ||
|
||
public ConceptCache() { | ||
this.lastUpdated = LocalDateTime.now(); | ||
} | ||
|
||
public String getUri() { | ||
return uri; | ||
} | ||
|
||
public void setUri(String uri) { | ||
this.uri = uri; | ||
} | ||
|
||
public String getId() { | ||
return id; | ||
} | ||
|
||
public void setId(String id) { | ||
this.id = id; | ||
} | ||
|
||
public String getWord() { | ||
return word; | ||
} | ||
|
||
public void setWord(String word) { | ||
this.word = word; | ||
} | ||
|
||
public String getPos() { | ||
return pos; | ||
} | ||
|
||
public void setPos(String pos) { | ||
this.pos = pos; | ||
} | ||
|
||
public String getDescription() { | ||
return description; | ||
} | ||
|
||
public void setDescription(String description) { | ||
this.description = description; | ||
} | ||
|
||
public String getConceptList() { | ||
return conceptList; | ||
} | ||
|
||
public void setConceptList(String conceptList) { | ||
this.conceptList = conceptList; | ||
} | ||
|
||
public String getTypeId() { | ||
return typeId; | ||
} | ||
|
||
public void setTypeId(String typeId) { | ||
this.typeId = typeId; | ||
} | ||
|
||
public boolean isDeleted() { | ||
return deleted; | ||
} | ||
|
||
public void setDeleted(boolean deleted) { | ||
this.deleted = deleted; | ||
} | ||
|
||
public LocalDateTime getLastUpdated() { | ||
return lastUpdated; | ||
} | ||
|
||
public void setLastUpdated(LocalDateTime lastUpdated) { | ||
this.lastUpdated = lastUpdated; | ||
} | ||
|
||
public List<String> getAlternativeUris() { | ||
return alternativeUris; | ||
} | ||
|
||
public void setAlternativeUris(List<String> alternativeUris) { | ||
this.alternativeUris = alternativeUris; | ||
} | ||
|
||
public List<String> getEqualTo() { | ||
return equalTo; | ||
} | ||
|
||
public void setEqualTo(List<String> equalTo) { | ||
this.equalTo = equalTo; | ||
} | ||
|
||
public List<String> getWordNetIds() { | ||
return wordNetIds; | ||
} | ||
|
||
public void setWordNetIds(List<String> wordNetIds) { | ||
this.wordNetIds = wordNetIds; | ||
} | ||
|
||
public String getCreatorId() { | ||
return creatorId; | ||
} | ||
|
||
public void setCreatorId(String creatorId) { | ||
this.creatorId = creatorId; | ||
} | ||
|
||
public ConceptType getConceptType() { | ||
return conceptType; | ||
} | ||
|
||
public void setConceptType(ConceptType conceptType) { | ||
this.conceptType = conceptType; | ||
} | ||
|
||
@Override | ||
public int compareTo(ConceptCache conceptCache) { | ||
// If both old and new cache values are null/blank/empty, nothing has changed | ||
// If old value is null/blank/empty, new value is not null/blank/empty, difference present | ||
// If old value is not null/blank/empty, new value is null/blank/empty, difference present | ||
// If both are not null/blank/empty, we need to check difference | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this should probably go into the javadoc (which is missing) |
||
|
||
if(isDifferentList(conceptCache.getAlternativeUris(), this.getAlternativeUris())) return -1; | ||
if(isDifferentList(conceptCache.getEqualTo(), this.getEqualTo())) return -1; | ||
if(isDifferentList(conceptCache.getWordNetIds(), this.getWordNetIds())) return -1; | ||
if (isDifferentString(conceptCache.getConceptList(), this.getConceptList())) return -1; | ||
if (isDifferentString(conceptCache.getCreatorId(), this.getCreatorId())) return -1; | ||
if (isDifferentString(conceptCache.getDescription(), this.getDescription())) return -1; | ||
if (isDifferentString(conceptCache.getId(), this.getId())) return -1; | ||
if (isDifferentString(conceptCache.getPos(), this.getPos())) return -1; | ||
if (isDifferentString(conceptCache.getTypeId(), this.getTypeId())) return -1; | ||
if (isDifferentString(conceptCache.getUri(), this.getUri())) return -1; | ||
if (isDifferentString(conceptCache.getWord(), this.getWord())) return -1; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this is not following our formatting guidelines. or it could be put as an OR statement (formatted one condition a line), so that only once -1 is returned. |
||
return 0; | ||
} | ||
|
||
private static boolean isDifferentString(String str1, String str2) { | ||
if(!(StringUtils.isEmpty(str1) && StringUtils.isEmpty(str2)) | ||
&& (StringUtils.isEmpty(str1) || !str1.equals(str2))) { | ||
return true; | ||
} | ||
return false; | ||
} | ||
|
||
private static boolean isDifferentList(List<String> list1, List<String> list2) { | ||
if (!(isNullOrEmpty(list1) && isNullOrEmpty(list2) | ||
&& (isNullOrEmpty(list1) || !list1.equals(list2)))) { | ||
return true; | ||
} | ||
return false; | ||
} | ||
|
||
private static boolean isNullOrEmpty(List<String> list) { | ||
return list == null || list.isEmpty(); | ||
} | ||
|
||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is that used anywhere?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jdamerow , It's value is currently defined in config.properties. Shall I remove this entry from pom.xml or give the value here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
remove it here