Rev 1778 | Rev 1782 | 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) |
||
1670 | jmachado | 59 | .include(RepositoryDocumentImpl.class) |
60 | .include(DocumentPersons.class) |
||
61 | .include(DocumentPerson.class) |
||
62 | .include(RepositoryDocumentCollectionImpl.class) |
||
63 | .include(RepositoryDocumentFileImpl.class) |
||
64 | .include("authorsJson", RepositoryDocumentImpl.class) |
||
65 | .include("contributorsJson", RepositoryDocumentImpl.class) |
||
66 | .include("persons", DocumentPersons.class) |
||
67 | .include("contributorsJson") |
||
68 | .include("collection", RepositoryDocumentImpl.class) |
||
69 | .include(1.5.0/docs/api/java/lang/String.html">String.class) |
||
70 | .include("repositoryDocumentFiles", RepositoryDocumentImpl.class) |
||
71 | .include(RepositoryFileProxy.class) |
||
72 | .include(RepositoryFileImpl.class) |
||
73 | .include(RepositoryFileVersionImpl.class) |
||
74 | .include("repositoryFileProxy", RepositoryDocumentFileImpl.class) |
||
75 | .include("lastVersion", RepositoryFileImpl.class) |
||
76 | .exclude("repositoryFile", RepositoryFileVersion.class) |
||
77 | .exclude("publishDate", RepositoryDocumentImpl.class) |
||
78 | .exclude("closeDate", RepositoryDocumentImpl.class) |
||
79 | //O sistema nao constroi o RepositoryFile a partir da classe |
||
80 | //mas como guarda o stream quando serializar aparece outra vez o ficheiro |
||
81 | .include("repositoryFile", RepositoryFileProxy.class) //DIFERENCA COM O ANTERIOR |
||
82 | .create(); |
||
83 | |||
84 | |||
85 | static Genson gensonDeserialize = new Genson.Builder() |
||
86 | .exclude(5+0%2Fdocs%2Fapi+Object">Object.class) |
||
1778 | jmachado | 87 | .include(1.5.0/docs/api/java/lang/Boolean.html">Boolean.class) |
88 | .include(1.5.0/docs/api/java/lang/Integer.html">Integer.class) |
||
89 | .include(1.5.0/docs/api/java/lang/Long.html">Long.class) |
||
90 | .include(1.5.0/docs/api/java/lang/Double.html">Double.class) |
||
91 | .include(1.5.0/docs/api/java/lang/Float.html">Float.class) |
||
1670 | jmachado | 92 | .include(RepositoryDocumentImpl.class) |
93 | .include(DocumentPersons.class) |
||
94 | .include(DocumentPerson.class) |
||
95 | .include(RepositoryDocumentCollectionImpl.class) |
||
96 | .include(RepositoryDocumentFileImpl.class) |
||
97 | .include("authorsJson", RepositoryDocumentImpl.class) |
||
98 | .include("contributorsJson", RepositoryDocumentImpl.class) |
||
99 | .include("persons", DocumentPersons.class) |
||
100 | .include("contributorsJson") |
||
101 | .include("collection", RepositoryDocumentImpl.class) |
||
102 | .include(1.5.0/docs/api/java/lang/String.html">String.class) |
||
103 | .include("repositoryDocumentFiles", RepositoryDocumentImpl.class) |
||
104 | .include(RepositoryFileProxy.class) |
||
105 | .include(RepositoryFileImpl.class) |
||
106 | .include(RepositoryFileVersionImpl.class) |
||
107 | .include("repositoryFileProxy", RepositoryDocumentFileImpl.class) |
||
108 | .include("lastVersion", RepositoryFileImpl.class) |
||
109 | .exclude("repositoryFile", RepositoryFileVersion.class) |
||
110 | .exclude("publishDate", RepositoryDocumentImpl.class) |
||
111 | .exclude("closeDate", RepositoryDocumentImpl.class) |
||
112 | //O sistema nao constroi o RepositoryFile a partir da classe |
||
113 | //mas como guarda o stream quando serializar aparece outra vez o ficheiro |
||
114 | .exclude("repositoryFile", RepositoryFileProxy.class) //DIFERENCA COM O ANTERIOR |
||
115 | .create(); |
||
116 | |||
117 | |||
118 | |||
119 | |||
1780 | jmachado | 120 | public 1.5.0/docs/api/java/lang/String.html">String toJson() { |
1670 | jmachado | 121 | return gensonSerialize.serialize(this); |
122 | } |
||
123 | |||
1776 | jmachado | 124 | public static JSONArray toJsonArray(List<RepositoryDocumentImpl> docs) throws 1.5.0/docs/api/java/io/IOException.html">IOException, JSONException { |
1675 | jmachado | 125 | return new JSONArray(gensonSerialize.serialize(docs)); |
126 | } |
||
127 | |||
1776 | jmachado | 128 | 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 | 129 | return gensonDeserialize.deserialize(json, RepositoryDocumentImpl.class); |
130 | } |
||
131 | |||
1780 | jmachado | 132 | public JSONObject toJsonObject() throws JSONException { |
1670 | jmachado | 133 | return new JSONObject(toJson()); |
134 | } |
||
135 | |||
1776 | jmachado | 136 | 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 | 137 | AbstractDao.getCurrentSession().beginTransaction(); |
138 | DocumentPerson p = new DocumentPerson(); |
||
139 | p.setFirstNames("jorge"); |
||
140 | p.setLastName("Machado"); |
||
141 | DocumentPersons ps = new DocumentPersons(); |
||
142 | ps.getPersons().add(p); |
||
143 | |||
144 | RepositoryDocumentCollectionImpl c = (RepositoryDocumentCollectionImpl) DaoFactory.getRepositoryDocumentCollectionDaoImpl().findAll().get(0); |
||
145 | |||
146 | RepositoryDocumentImpl r = new RepositoryDocumentImpl(); |
||
147 | r.setCollection(c); |
||
148 | r.setAuthorsJson(ps); |
||
149 | r.setContributorsJson(ps); |
||
150 | |||
151 | |||
152 | RepositoryDocumentFileImpl f = new RepositoryDocumentFileImpl(); |
||
153 | //f.setRepositoryStream("241"); |
||
154 | RepositoryFileProxy proxy =new RepositoryFileProxy(); |
||
155 | proxy.setRepositoryStream("242"); |
||
156 | |||
157 | |||
158 | r.setRepositoryDocumentFiles(new HashSet<RepositoryDocumentFileImpl>()); |
||
159 | r.getRepositoryDocumentFiles().add(f); |
||
160 | |||
161 | f.setRepositoryFileProxy(proxy); |
||
162 | DaoFactory.getRepositoryDocumentFileDaoImpl().save(f); |
||
163 | DaoFactory.getRepositoryDocumentDaoImpl().save(r); |
||
164 | AbstractDao.getCurrentSession().getTransaction().commit(); |
||
165 | |||
166 | |||
167 | AbstractDao.getCurrentSession().beginTransaction(); |
||
168 | r = (RepositoryDocumentImpl) DaoFactory.getRepositoryDocumentDaoImpl().get(r.getId()); |
||
169 | 1.5.0/docs/api/java/lang/System.html">System.out.println(r.toJson()); |
||
170 | |||
171 | 1.5.0/docs/api/java/lang/System.html">System.out.println(RepositoryDocumentImpl.loadFromJson(r.toJson()).toJson()); |
||
172 | AbstractDao.getCurrentSession().getTransaction().commit(); |
||
173 | } |
||
1637 | jmachado | 174 | } |