Rev 1782 | Rev 1814 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
1637 | jmachado | 1 | package pt.estgp.estgweb.domain; |
2 | |||
1670 | jmachado | 3 | import com.owlike.genson.Genson; |
4 | import jomm.dao.impl.AbstractDao; |
||
1675 | jmachado | 5 | import org.json.JSONArray; |
1670 | jmachado | 6 | import org.json.JSONException; |
7 | import org.json.JSONObject; |
||
8 | import pt.estgp.estgweb.domain.dao.DaoFactory; |
||
9 | import pt.estgp.estgweb.services.data.repositorydocuments.DocumentPerson; |
||
10 | import pt.estgp.estgweb.services.data.repositorydocuments.DocumentPersons; |
||
11 | import pt.estgp.estgweb.services.data.repositorydocuments.RepositoryFileProxy; |
||
12 | import pt.estgp.estgweb.web.utils.DatesUtils; |
||
13 | |||
14 | import java.io.IOException; |
||
1637 | jmachado | 15 | import java.io.Serializable; |
1670 | jmachado | 16 | import java.util.HashSet; |
1675 | jmachado | 17 | import java.util.List; |
1637 | jmachado | 18 | |
19 | /** |
||
20 | * Created by jorgemachado on 30/01/17. |
||
21 | */ |
||
22 | public class RepositoryDocumentImpl extends RepositoryDocument { |
||
23 | @1.5.0/docs/api/java/lang/Override.html">Override |
||
24 | public 1.5.0/docs/api/java/io/Serializable.html">Serializable getSerializable() { |
||
25 | return getId(); |
||
26 | } |
||
1670 | jmachado | 27 | |
28 | |||
29 | public void setPublishDateStr(1.5.0/docs/api/java/lang/String.html">String date) |
||
30 | { |
||
31 | setPublishDate(DatesUtils.getDateFromString(date)); |
||
32 | } |
||
33 | |||
34 | public void setCloseDateStr(1.5.0/docs/api/java/lang/String.html">String date) |
||
35 | { |
||
36 | setCloseDate(DatesUtils.getDateFromString(date)); |
||
37 | } |
||
38 | |||
39 | public 1.5.0/docs/api/java/lang/String.html">String getPublishDateStr() |
||
40 | { |
||
41 | if(getPublishDate() != null) |
||
42 | return DatesUtils.getStringFromDate(getPublishDate()); |
||
43 | return ""; |
||
44 | } |
||
45 | public 1.5.0/docs/api/java/lang/String.html">String getCloseDateStr() |
||
46 | { |
||
47 | if(getCloseDate() != null) |
||
48 | return DatesUtils.getStringFromDate(getCloseDate()); |
||
49 | return ""; |
||
50 | } |
||
51 | |||
52 | static Genson gensonSerialize = new Genson.Builder() |
||
53 | .exclude(5+0%2Fdocs%2Fapi+Object">Object.class) |
||
1778 | jmachado | 54 | .include(1.5.0/docs/api/java/lang/Boolean.html">Boolean.class) |
55 | .include(1.5.0/docs/api/java/lang/Integer.html">Integer.class) |
||
56 | .include(1.5.0/docs/api/java/lang/Long.html">Long.class) |
||
57 | .include(1.5.0/docs/api/java/lang/Double.html">Double.class) |
||
58 | .include(1.5.0/docs/api/java/lang/Float.html">Float.class) |
||
1782 | jmachado | 59 | //.include(ArrayList.class) |
1670 | jmachado | 60 | .include(RepositoryDocumentImpl.class) |
61 | .include(DocumentPersons.class) |
||
62 | .include(DocumentPerson.class) |
||
63 | .include(RepositoryDocumentCollectionImpl.class) |
||
64 | .include(RepositoryDocumentFileImpl.class) |
||
65 | .include("authorsJson", RepositoryDocumentImpl.class) |
||
66 | .include("contributorsJson", RepositoryDocumentImpl.class) |
||
67 | .include("persons", DocumentPersons.class) |
||
68 | .include("contributorsJson") |
||
69 | .include("collection", RepositoryDocumentImpl.class) |
||
70 | .include(1.5.0/docs/api/java/lang/String.html">String.class) |
||
71 | .include("repositoryDocumentFiles", RepositoryDocumentImpl.class) |
||
72 | .include(RepositoryFileProxy.class) |
||
73 | .include(RepositoryFileImpl.class) |
||
74 | .include(RepositoryFileVersionImpl.class) |
||
75 | .include("repositoryFileProxy", RepositoryDocumentFileImpl.class) |
||
76 | .include("lastVersion", RepositoryFileImpl.class) |
||
77 | .exclude("repositoryFile", RepositoryFileVersion.class) |
||
78 | .exclude("publishDate", RepositoryDocumentImpl.class) |
||
79 | .exclude("closeDate", RepositoryDocumentImpl.class) |
||
80 | //O sistema nao constroi o RepositoryFile a partir da classe |
||
81 | //mas como guarda o stream quando serializar aparece outra vez o ficheiro |
||
82 | .include("repositoryFile", RepositoryFileProxy.class) //DIFERENCA COM O ANTERIOR |
||
1784 | jmachado | 83 | .exclude("repositoryFileVersions",RepositoryFile.class) |
84 | .exclude("sourceModule",RepositoryFile.class) |
||
1670 | jmachado | 85 | .create(); |
86 | |||
87 | |||
88 | static Genson gensonDeserialize = new Genson.Builder() |
||
89 | .exclude(5+0%2Fdocs%2Fapi+Object">Object.class) |
||
1782 | jmachado | 90 | //.include(ArrayList.class) |
91 | //.include(Set.class) |
||
92 | //.include(List.class) |
||
1778 | jmachado | 93 | .include(1.5.0/docs/api/java/lang/Boolean.html">Boolean.class) |
94 | .include(1.5.0/docs/api/java/lang/Integer.html">Integer.class) |
||
95 | .include(1.5.0/docs/api/java/lang/Long.html">Long.class) |
||
96 | .include(1.5.0/docs/api/java/lang/Double.html">Double.class) |
||
97 | .include(1.5.0/docs/api/java/lang/Float.html">Float.class) |
||
1670 | jmachado | 98 | .include(RepositoryDocumentImpl.class) |
99 | .include(DocumentPersons.class) |
||
100 | .include(DocumentPerson.class) |
||
101 | .include(RepositoryDocumentCollectionImpl.class) |
||
102 | .include(RepositoryDocumentFileImpl.class) |
||
103 | .include("authorsJson", RepositoryDocumentImpl.class) |
||
104 | .include("contributorsJson", RepositoryDocumentImpl.class) |
||
105 | .include("persons", DocumentPersons.class) |
||
106 | .include("contributorsJson") |
||
107 | .include("collection", RepositoryDocumentImpl.class) |
||
108 | .include(1.5.0/docs/api/java/lang/String.html">String.class) |
||
109 | .include("repositoryDocumentFiles", RepositoryDocumentImpl.class) |
||
110 | .include(RepositoryFileProxy.class) |
||
111 | .include(RepositoryFileImpl.class) |
||
112 | .include(RepositoryFileVersionImpl.class) |
||
113 | .include("repositoryFileProxy", RepositoryDocumentFileImpl.class) |
||
114 | .include("lastVersion", RepositoryFileImpl.class) |
||
115 | .exclude("repositoryFile", RepositoryFileVersion.class) |
||
116 | .exclude("publishDate", RepositoryDocumentImpl.class) |
||
117 | .exclude("closeDate", RepositoryDocumentImpl.class) |
||
118 | //O sistema nao constroi o RepositoryFile a partir da classe |
||
119 | //mas como guarda o stream quando serializar aparece outra vez o ficheiro |
||
120 | .exclude("repositoryFile", RepositoryFileProxy.class) //DIFERENCA COM O ANTERIOR |
||
121 | .create(); |
||
122 | |||
123 | |||
124 | |||
125 | |||
1780 | jmachado | 126 | public 1.5.0/docs/api/java/lang/String.html">String toJson() { |
1670 | jmachado | 127 | return gensonSerialize.serialize(this); |
128 | } |
||
129 | |||
1776 | jmachado | 130 | public static JSONArray toJsonArray(List<RepositoryDocumentImpl> docs) throws 1.5.0/docs/api/java/io/IOException.html">IOException, JSONException { |
1675 | jmachado | 131 | return new JSONArray(gensonSerialize.serialize(docs)); |
132 | } |
||
133 | |||
1776 | jmachado | 134 | public static RepositoryDocumentImpl loadFromJson(1.5.0/docs/api/java/lang/String.html">String json) throws 1.5.0/docs/api/java/io/IOException.html">IOException { |
1670 | jmachado | 135 | return gensonDeserialize.deserialize(json, RepositoryDocumentImpl.class); |
136 | } |
||
137 | |||
1780 | jmachado | 138 | public JSONObject toJsonObject() throws JSONException { |
1670 | jmachado | 139 | return new JSONObject(toJson()); |
140 | } |
||
141 | |||
1776 | jmachado | 142 | public static void main(1.5.0/docs/api/java/lang/String.html">String[] args) throws 1.5.0/docs/api/java/io/IOException.html">IOException { |
1670 | jmachado | 143 | AbstractDao.getCurrentSession().beginTransaction(); |
144 | DocumentPerson p = new DocumentPerson(); |
||
145 | p.setFirstNames("jorge"); |
||
146 | p.setLastName("Machado"); |
||
147 | DocumentPersons ps = new DocumentPersons(); |
||
148 | ps.getPersons().add(p); |
||
149 | |||
150 | RepositoryDocumentCollectionImpl c = (RepositoryDocumentCollectionImpl) DaoFactory.getRepositoryDocumentCollectionDaoImpl().findAll().get(0); |
||
151 | |||
152 | RepositoryDocumentImpl r = new RepositoryDocumentImpl(); |
||
153 | r.setCollection(c); |
||
154 | r.setAuthorsJson(ps); |
||
155 | r.setContributorsJson(ps); |
||
156 | |||
157 | |||
158 | RepositoryDocumentFileImpl f = new RepositoryDocumentFileImpl(); |
||
159 | //f.setRepositoryStream("241"); |
||
160 | RepositoryFileProxy proxy =new RepositoryFileProxy(); |
||
161 | proxy.setRepositoryStream("242"); |
||
162 | |||
163 | |||
164 | r.setRepositoryDocumentFiles(new HashSet<RepositoryDocumentFileImpl>()); |
||
165 | r.getRepositoryDocumentFiles().add(f); |
||
166 | |||
167 | f.setRepositoryFileProxy(proxy); |
||
168 | DaoFactory.getRepositoryDocumentFileDaoImpl().save(f); |
||
169 | DaoFactory.getRepositoryDocumentDaoImpl().save(r); |
||
170 | AbstractDao.getCurrentSession().getTransaction().commit(); |
||
171 | |||
172 | |||
173 | AbstractDao.getCurrentSession().beginTransaction(); |
||
174 | r = (RepositoryDocumentImpl) DaoFactory.getRepositoryDocumentDaoImpl().get(r.getId()); |
||
175 | 1.5.0/docs/api/java/lang/System.html">System.out.println(r.toJson()); |
||
176 | |||
177 | 1.5.0/docs/api/java/lang/System.html">System.out.println(RepositoryDocumentImpl.loadFromJson(r.toJson()).toJson()); |
||
178 | AbstractDao.getCurrentSession().getTransaction().commit(); |
||
179 | } |
||
1637 | jmachado | 180 | } |