commit 174566c0ed5798685bbab89d7d0e32ecf1a9a1b4 Author: Massimiliano Assante Date: Wed Mar 8 11:45:20 2023 +0100 first commit diff --git a/.classpath b/.classpath new file mode 100644 index 0000000..1e8b7fe --- /dev/null +++ b/.classpath @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..b83d222 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/target/ diff --git a/.project b/.project new file mode 100644 index 0000000..ca89616 --- /dev/null +++ b/.project @@ -0,0 +1,37 @@ + + + vlabs-display-portlet2 + + + + + + org.eclipse.jdt.core.javabuilder + + + + + org.eclipse.wst.common.project.facet.core.builder + + + + + org.eclipse.wst.validation.validationbuilder + + + + + org.eclipse.m2e.core.maven2Builder + + + + + + org.eclipse.jem.workbench.JavaEMFNature + org.eclipse.wst.common.modulecore.ModuleCoreNature + org.eclipse.jdt.core.javanature + org.eclipse.m2e.core.maven2Nature + org.eclipse.wst.common.project.facet.core.nature + org.eclipse.wst.jsdt.core.jsNature + + diff --git a/.settings/.jsdtscope b/.settings/.jsdtscope new file mode 100644 index 0000000..81672d4 --- /dev/null +++ b/.settings/.jsdtscope @@ -0,0 +1,12 @@ + + + + + + + + + + + + diff --git a/.settings/org.eclipse.core.resources.prefs b/.settings/org.eclipse.core.resources.prefs new file mode 100644 index 0000000..abdea9a --- /dev/null +++ b/.settings/org.eclipse.core.resources.prefs @@ -0,0 +1,4 @@ +eclipse.preferences.version=1 +encoding//src/main/java=UTF-8 +encoding//src/main/resources=UTF-8 +encoding/=UTF-8 diff --git a/.settings/org.eclipse.jdt.core.prefs b/.settings/org.eclipse.jdt.core.prefs new file mode 100644 index 0000000..cac0df4 --- /dev/null +++ b/.settings/org.eclipse.jdt.core.prefs @@ -0,0 +1,11 @@ +eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error +org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning +org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=ignore +org.eclipse.jdt.core.compiler.release=disabled +org.eclipse.jdt.core.compiler.source=1.8 diff --git a/.settings/org.eclipse.jst.jsp.core.prefs b/.settings/org.eclipse.jst.jsp.core.prefs new file mode 100644 index 0000000..3a5c98d --- /dev/null +++ b/.settings/org.eclipse.jst.jsp.core.prefs @@ -0,0 +1,3 @@ +eclipse.preferences.version=1 +validateFragments=false +validation.use-project-settings=true diff --git a/.settings/org.eclipse.m2e.core.prefs b/.settings/org.eclipse.m2e.core.prefs new file mode 100644 index 0000000..f897a7f --- /dev/null +++ b/.settings/org.eclipse.m2e.core.prefs @@ -0,0 +1,4 @@ +activeProfiles= +eclipse.preferences.version=1 +resolveWorkspaceProjects=true +version=1 diff --git a/.settings/org.eclipse.wst.common.component b/.settings/org.eclipse.wst.common.component new file mode 100644 index 0000000..7143077 --- /dev/null +++ b/.settings/org.eclipse.wst.common.component @@ -0,0 +1,10 @@ + + + + + + + + + + diff --git a/.settings/org.eclipse.wst.common.project.facet.core.xml b/.settings/org.eclipse.wst.common.project.facet.core.xml new file mode 100644 index 0000000..3ab5c75 --- /dev/null +++ b/.settings/org.eclipse.wst.common.project.facet.core.xml @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/.settings/org.eclipse.wst.jsdt.ui.superType.container b/.settings/org.eclipse.wst.jsdt.ui.superType.container new file mode 100644 index 0000000..3bd5d0a --- /dev/null +++ b/.settings/org.eclipse.wst.jsdt.ui.superType.container @@ -0,0 +1 @@ +org.eclipse.wst.jsdt.launching.baseBrowserLibrary \ No newline at end of file diff --git a/.settings/org.eclipse.wst.jsdt.ui.superType.name b/.settings/org.eclipse.wst.jsdt.ui.superType.name new file mode 100644 index 0000000..05bd71b --- /dev/null +++ b/.settings/org.eclipse.wst.jsdt.ui.superType.name @@ -0,0 +1 @@ +Window \ No newline at end of file diff --git a/.settings/org.eclipse.wst.validation.prefs b/.settings/org.eclipse.wst.validation.prefs new file mode 100644 index 0000000..04cad8c --- /dev/null +++ b/.settings/org.eclipse.wst.validation.prefs @@ -0,0 +1,2 @@ +disabled=06target +eclipse.preferences.version=1 diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..a33d65b --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,10 @@ + +# Changelog for SBD Upload and Share Portlet + +All notable changes to this project will be documented in this file. +This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + + +## [v1.0.0-SNAPSHOT] - 2023-03-03 + +First Release diff --git a/FUNDING.md b/FUNDING.md new file mode 100644 index 0000000..6fa9eac --- /dev/null +++ b/FUNDING.md @@ -0,0 +1,26 @@ +# Acknowledgments + +The projects leading to this software have received funding from a series of European Union programmes including: + +- the Sixth Framework Programme for Research and Technological Development + - [DILIGENT](https://cordis.europa.eu/project/id/004260) (grant no. 004260). +- the Seventh Framework Programme for research, technological development and demonstration + - [D4Science](https://cordis.europa.eu/project/id/212488) (grant no. 212488); + - [D4Science-II](https://cordis.europa.eu/project/id/239019) (grant no.239019); + - [ENVRI](https://cordis.europa.eu/project/id/283465) (grant no. 283465); + - [iMarine](https://cordis.europa.eu/project/id/283644) (grant no. 283644); + - [EUBrazilOpenBio](https://cordis.europa.eu/project/id/288754) (grant no. 288754). +- the H2020 research and innovation programme + - [SoBigData](https://cordis.europa.eu/project/id/654024) (grant no. 654024); + - [PARTHENOS](https://cordis.europa.eu/project/id/654119) (grant no. 654119); + - [EGI-Engage](https://cordis.europa.eu/project/id/654142) (grant no. 654142); + - [ENVRI PLUS](https://cordis.europa.eu/project/id/654182) (grant no. 654182); + - [BlueBRIDGE](https://cordis.europa.eu/project/id/675680) (grant no. 675680); + - [PerformFISH](https://cordis.europa.eu/project/id/727610) (grant no. 727610); + - [AGINFRA PLUS](https://cordis.europa.eu/project/id/731001) (grant no. 731001); + - [DESIRA](https://cordis.europa.eu/project/id/818194) (grant no. 818194); + - [ARIADNEplus](https://cordis.europa.eu/project/id/823914) (grant no. 823914); + - [RISIS 2](https://cordis.europa.eu/project/id/824091) (grant no. 824091); + - [EOSC-Pillar](https://cordis.europa.eu/project/id/857650) (grant no. 857650); + - [Blue Cloud](https://cordis.europa.eu/project/id/862409) (grant no. 862409); + - [SoBigData-PlusPlus](https://cordis.europa.eu/project/id/871042) (grant no. 871042); \ No newline at end of file diff --git a/LICENSE.md b/LICENSE.md new file mode 100644 index 0000000..c25566d --- /dev/null +++ b/LICENSE.md @@ -0,0 +1,311 @@ +#European Union Public Licence V.1.1 + +##*EUPL © the European Community 2007* + + +This **European Union Public Licence** (the **“EUPL”**) applies to the Work or Software +(as defined below) which is provided under the terms of this Licence. Any use of +the Work, other than as authorised under this Licence is prohibited (to the +extent such use is covered by a right of the copyright holder of the Work). + +The Original Work is provided under the terms of this Licence when the Licensor +(as defined below) has placed the following notice immediately following the +copyright notice for the Original Work: + +**Licensed under the EUPL V.1.1** + +or has expressed by any other mean his willingness to license under the EUPL. + + + +##1. Definitions + +In this Licence, the following terms have the following meaning: + +- The Licence: this Licence. + +- The Original Work or the Software: the software distributed and/or + communicated by the Licensor under this Licence, available as Source Code and + also as Executable Code as the case may be. + +- Derivative Works: the works or software that could be created by the Licensee, + based upon the Original Work or modifications thereof. This Licence does not + define the extent of modification or dependence on the Original Work required + in order to classify a work as a Derivative Work; this extent is determined by + copyright law applicable in the country mentioned in Article 15. + +- The Work: the Original Work and/or its Derivative Works. + +- The Source Code: the human-readable form of the Work which is the most + convenient for people to study and modify. + +- The Executable Code: any code which has generally been compiled and which is + meant to be interpreted by a computer as a program. + +- The Licensor: the natural or legal person that distributes and/or communicates + the Work under the Licence. + +- Contributor(s): any natural or legal person who modifies the Work under the + Licence, or otherwise contributes to the creation of a Derivative Work. + +- The Licensee or “You”: any natural or legal person who makes any usage of the + Software under the terms of the Licence. + +- Distribution and/or Communication: any act of selling, giving, lending, + renting, distributing, communicating, transmitting, or otherwise making + available, on-line or off-line, copies of the Work or providing access to its + essential functionalities at the disposal of any other natural or legal + person. + + + +##2. Scope of the rights granted by the Licence + +The Licensor hereby grants You a world-wide, royalty-free, non-exclusive, +sub-licensable licence to do the following, for the duration of copyright vested +in the Original Work: + +- use the Work in any circumstance and for all usage, reproduce the Work, modify +- the Original Work, and make Derivative Works based upon the Work, communicate +- to the public, including the right to make available or display the Work or +- copies thereof to the public and perform publicly, as the case may be, the +- Work, distribute the Work or copies thereof, lend and rent the Work or copies +- thereof, sub-license rights in the Work or copies thereof. + +Those rights can be exercised on any media, supports and formats, whether now +known or later invented, as far as the applicable law permits so. + +In the countries where moral rights apply, the Licensor waives his right to +exercise his moral right to the extent allowed by law in order to make effective +the licence of the economic rights here above listed. + +The Licensor grants to the Licensee royalty-free, non exclusive usage rights to +any patents held by the Licensor, to the extent necessary to make use of the +rights granted on the Work under this Licence. + + + +##3. Communication of the Source Code + +The Licensor may provide the Work either in its Source Code form, or as +Executable Code. If the Work is provided as Executable Code, the Licensor +provides in addition a machine-readable copy of the Source Code of the Work +along with each copy of the Work that the Licensor distributes or indicates, in +a notice following the copyright notice attached to the Work, a repository where +the Source Code is easily and freely accessible for as long as the Licensor +continues to distribute and/or communicate the Work. + + + +##4. Limitations on copyright + +Nothing in this Licence is intended to deprive the Licensee of the benefits from +any exception or limitation to the exclusive rights of the rights owners in the +Original Work or Software, of the exhaustion of those rights or of other +applicable limitations thereto. + + + +##5. Obligations of the Licensee + +The grant of the rights mentioned above is subject to some restrictions and +obligations imposed on the Licensee. Those obligations are the following: + +Attribution right: the Licensee shall keep intact all copyright, patent or +trademarks notices and all notices that refer to the Licence and to the +disclaimer of warranties. The Licensee must include a copy of such notices and a +copy of the Licence with every copy of the Work he/she distributes and/or +communicates. The Licensee must cause any Derivative Work to carry prominent +notices stating that the Work has been modified and the date of modification. + +Copyleft clause: If the Licensee distributes and/or communicates copies of the +Original Works or Derivative Works based upon the Original Work, this +Distribution and/or Communication will be done under the terms of this Licence +or of a later version of this Licence unless the Original Work is expressly +distributed only under this version of the Licence. The Licensee (becoming +Licensor) cannot offer or impose any additional terms or conditions on the Work +or Derivative Work that alter or restrict the terms of the Licence. + +Compatibility clause: If the Licensee Distributes and/or Communicates Derivative +Works or copies thereof based upon both the Original Work and another work +licensed under a Compatible Licence, this Distribution and/or Communication can +be done under the terms of this Compatible Licence. For the sake of this clause, +“Compatible Licence” refers to the licences listed in the appendix attached to +this Licence. Should the Licensee’s obligations under the Compatible Licence +conflict with his/her obligations under this Licence, the obligations of the +Compatible Licence shall prevail. + +Provision of Source Code: When distributing and/or communicating copies of the +Work, the Licensee will provide a machine-readable copy of the Source Code or +indicate a repository where this Source will be easily and freely available for +as long as the Licensee continues to distribute and/or communicate the Work. + +Legal Protection: This Licence does not grant permission to use the trade names, +trademarks, service marks, or names of the Licensor, except as required for +reasonable and customary use in describing the origin of the Work and +reproducing the content of the copyright notice. + + + +##6. Chain of Authorship + +The original Licensor warrants that the copyright in the Original Work granted +hereunder is owned by him/her or licensed to him/her and that he/she has the +power and authority to grant the Licence. + +Each Contributor warrants that the copyright in the modifications he/she brings +to the Work are owned by him/her or licensed to him/her and that he/she has the +power and authority to grant the Licence. + +Each time You accept the Licence, the original Licensor and subsequent +Contributors grant You a licence to their contributions to the Work, under the +terms of this Licence. + + + +##7. Disclaimer of Warranty + +The Work is a work in progress, which is continuously improved by numerous +contributors. It is not a finished work and may therefore contain defects or +“bugs” inherent to this type of software development. + +For the above reason, the Work is provided under the Licence on an “as is” basis +and without warranties of any kind concerning the Work, including without +limitation merchantability, fitness for a particular purpose, absence of defects +or errors, accuracy, non-infringement of intellectual property rights other than +copyright as stated in Article 6 of this Licence. + +This disclaimer of warranty is an essential part of the Licence and a condition +for the grant of any rights to the Work. + + + +##8. Disclaimer of Liability + +Except in the cases of wilful misconduct or damages directly caused to natural +persons, the Licensor will in no event be liable for any direct or indirect, +material or moral, damages of any kind, arising out of the Licence or of the use +of the Work, including without limitation, damages for loss of goodwill, work +stoppage, computer failure or malfunction, loss of data or any commercial +damage, even if the Licensor has been advised of the possibility of such +damage. However, the Licensor will be liable under statutory product liability +laws as far such laws apply to the Work. + + + +##9. Additional agreements + +While distributing the Original Work or Derivative Works, You may choose to +conclude an additional agreement to offer, and charge a fee for, acceptance of +support, warranty, indemnity, or other liability obligations and/or services +consistent with this Licence. However, in accepting such obligations, You may +act only on your own behalf and on your sole responsibility, not on behalf of +the original Licensor or any other Contributor, and only if You agree to +indemnify, defend, and hold each Contributor harmless for any liability incurred +by, or claims asserted against such Contributor by the fact You have accepted +any such warranty or additional liability. + + + +##10. Acceptance of the Licence + +The provisions of this Licence can be accepted by clicking on an icon “I agree” +placed under the bottom of a window displaying the text of this Licence or by +affirming consent in any other similar way, in accordance with the rules of +applicable law. Clicking on that icon indicates your clear and irrevocable +acceptance of this Licence and all of its terms and conditions. + +Similarly, you irrevocably accept this Licence and all of its terms and +conditions by exercising any rights granted to You by Article 2 of this Licence, +such as the use of the Work, the creation by You of a Derivative Work or the +Distribution and/or Communication by You of the Work or copies thereof. + + + +##11. Information to the public + +In case of any Distribution and/or Communication of the Work by means of +electronic communication by You (for example, by offering to download the Work +from a remote location) the distribution channel or media (for example, a +website) must at least provide to the public the information requested by the +applicable law regarding the Licensor, the Licence and the way it may be +accessible, concluded, stored and reproduced by the Licensee. + + + +##12. Termination of the Licence + +The Licence and the rights granted hereunder will terminate automatically upon +any breach by the Licensee of the terms of the Licence. + +Such a termination will not terminate the licences of any person who has +received the Work from the Licensee under the Licence, provided such persons +remain in full compliance with the Licence. + + + +##13. Miscellaneous + +Without prejudice of Article 9 above, the Licence represents the complete +agreement between the Parties as to the Work licensed hereunder. + +If any provision of the Licence is invalid or unenforceable under applicable +law, this will not affect the validity or enforceability of the Licence as a +whole. Such provision will be construed and/or reformed so as necessary to make +it valid and enforceable. + +The European Commission may publish other linguistic versions and/or new +versions of this Licence, so far this is required and reasonable, without +reducing the scope of the rights granted by the Licence. New versions of the +Licence will be published with a unique version number. + +All linguistic versions of this Licence, approved by the European Commission, +have identical value. Parties can take advantage of the linguistic version of +their choice. + + + +##14. Jurisdiction + +Any litigation resulting from the interpretation of this License, arising +between the European Commission, as a Licensor, and any Licensee, will be +subject to the jurisdiction of the Court of Justice of the European Communities, +as laid down in article 238 of the Treaty establishing the European Community. + +Any litigation arising between Parties, other than the European Commission, and +resulting from the interpretation of this License, will be subject to the +exclusive jurisdiction of the competent court where the Licensor resides or +conducts its primary business. + + + +##15. Applicable Law + +This Licence shall be governed by the law of the European Union country where +the Licensor resides or has his registered office. + +This licence shall be governed by the Belgian law if: + +- a litigation arises between the European Commission, as a Licensor, and any +- Licensee; the Licensor, other than the European Commission, has no residence +- or registered office inside a European Union country. + + +--- + + +##Appendix + + +**“Compatible Licences”** according to article 5 EUPL are: + + +- GNU General Public License (GNU GPL) v. 2 + +- Open Software License (OSL) v. 2.1, v. 3.0 + +- Common Public License v. 1.0 + +- Eclipse Public License v. 1.0 + +- Cecill v. 2.0 \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..27470f7 --- /dev/null +++ b/README.md @@ -0,0 +1,42 @@ +# gCube System - VLABs display Portlet + +This component is a Liferay 6.2.6 CE Porlet which iinteracts with the VRE Modeler service during new VRE Creations +## Structure of the project + +* The source code is present in the src folder. + +## Built With + +* [OpenJDK](https://openjdk.java.net/) - The JDK used +* [Maven](https://maven.apache.org/) - Dependency Management + +## Documentation + +* No Documentation is provided + +## Change log + +See [Releases](https://code-repo.d4science.org/gCubeSystem/sbd-uploadshare-portlet/releases). + +## Authors + +* **Massimiliano Assante** - [ISTI-CNR Infrascience Group](http://nemis.isti.cnr.it/groups/infrascience) + +## Maintainers + +* **Massimiliano Assante** - [ISTI-CNR Infrascience Group](http://nemis.isti.cnr.it/groups/infrascience) + +## License + +This project is licensed under the EUPL V.1.1 License - see the [LICENSE.md](LICENSE.md) file for details. + + +## About the gCube Framework +This software is part of the [gCubeFramework](https://www.gcube-system.org/ "gCubeFramework"): an +open-source software toolkit used for building and operating Hybrid Data +Infrastructures enabling the dynamic deployment of Virtual Research Environments +by favouring the realisation of reuse oriented policies. + +The projects leading to this software have received funding from a series of European Union programmes see [FUNDING.md](FUNDING.md) + + \ No newline at end of file diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..2e9b540 --- /dev/null +++ b/pom.xml @@ -0,0 +1,136 @@ + + + 4.0.0 + + maven-parent + org.gcube.tools + 1.1.0 + + + org.gcube.portlets.user + vlabs-display-portlet + war + VLabs Display Portlet + 1.0.0-SNAPSHOT + + VLabs Display Portle + + + UTF-8 + UTF-8 + 1.8 + 1.8 + UTF-8 + 6.2.5 + 6.2.10.12 + + + scm:git:https://code-repo.d4science.org/gCubeSystem/${project.artifactId}.git + scm:git:https://code-repo.d4science.org/gCubeSystem/${project.artifactId}.git + https://code-repo.d4science.org/gCubeSystem/${project.artifactId} + + + + + org.gcube.distribution + maven-portal-bom + 3.6.4-SNAPSHOT + pom + import + + + + + + org.gcube.common.portal + portal-manager + + + org.gcube.dvos + usermanagement-core + + + com.liferay.portal + portal-service + provided + + + com.liferay.portal + util-bridges + ${liferay.version} + provided + + + com.liferay.portal + util-taglib + ${liferay.version} + provided + + + com.liferay.portal + util-java + provided + + + javax.portlet + portlet-api + provided + + + javax.servlet + servlet-api + 2.4 + provided + + + javax.servlet.jsp + jsp-api + 2.0 + provided + + + javax.servlet + jstl + 1.2 + + + + + + com.liferay.maven.plugins + liferay-maven-plugin + ${liferay.maven.plugin.version} + + + generate-sources + + + + ${liferay.auto.deploy.dir} + ${liferay.app.server.deploy.dir} + ${liferay.app.server.lib.global.dir} + ${liferay.app.server.portal.dir} + ${liferay.version} + portlet + + + + maven-compiler-plugin + + UTF-8 + ${maven.compiler.source} + ${maven.compiler.target} + + + + maven-resources-plugin + 2.5 + + UTF-8 + + + + + \ No newline at end of file diff --git a/src/main/java/org/gcube/portlets/user/vlabs/Utils.java b/src/main/java/org/gcube/portlets/user/vlabs/Utils.java new file mode 100644 index 0000000..b475afe --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/vlabs/Utils.java @@ -0,0 +1,48 @@ +package org.gcube.portlets.user.vlabs; + +import org.gcube.common.portal.GCubePortalConstants; +import org.gcube.vomanagement.usermanagement.GroupManager; +import org.gcube.vomanagement.usermanagement.impl.LiferayGroupManager; +import org.gcube.vomanagement.usermanagement.model.GCubeGroup; +import org.gcube.vomanagement.usermanagement.model.GroupMembershipType; + +import com.liferay.portal.kernel.log.Log; +import com.liferay.portal.kernel.log.LogFactoryUtil; +import com.liferay.portal.model.User; +import com.liferay.portal.service.GroupLocalServiceUtil; + +public class Utils { + private static Log _log = LogFactoryUtil.getLog(Utils.class); + /** + * + * @param currentUser + * @param urlContainingGroupId + * @return the access policy and the direct VRE Url if the member belongs to the VRE, the page to ask for registration on this VRE othwerise + */ + public static VLabBean getVLabBean(User currentUser, String urlContainingGroupId) { + VLabBean toReturn = new VLabBean(); + toReturn.setFriendlyURL(""); + String[] splits = urlContainingGroupId.split("="); + long groupId = -1; + try { + if (splits.length > 0) { + groupId = Long.parseLong(splits[1]); + GroupManager gm = new LiferayGroupManager(); + GCubeGroup theGroup = gm.getGroup(groupId); + GroupMembershipType ap =theGroup.getMembershipType(); + System.out.println("Access Policy for " + theGroup.getGroupName() + ": " + ap.name()); + toReturn.setAccessPolicy(ap); + long[] userGroupIds = currentUser.getGroupIds(); + for (int i = 0; i < userGroupIds.length; i++) { + if (groupId == userGroupIds[i]) + toReturn.setFriendlyURL(GCubePortalConstants.PREFIX_GROUP_URL +GroupLocalServiceUtil.getGroup(groupId).getFriendlyURL()); + } + } + toReturn.setFriendlyURL(urlContainingGroupId); + } catch (Exception e) { + _log.error("Something is wrong in the url passed: " + urlContainingGroupId); + return toReturn; + } + return toReturn; + } +} diff --git a/src/main/java/org/gcube/portlets/user/vlabs/VLabBean.java b/src/main/java/org/gcube/portlets/user/vlabs/VLabBean.java new file mode 100644 index 0000000..b2676f5 --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/vlabs/VLabBean.java @@ -0,0 +1,45 @@ +package org.gcube.portlets.user.vlabs; + +import org.gcube.vomanagement.usermanagement.model.GroupMembershipType; + +public class VLabBean { + + private GroupMembershipType accessPolicy; + private String friendlyURL; + + /** + * + */ + public VLabBean() { + super(); + // TODO Auto-generated constructor stub + } + /** + * @param accessPolicy + * @param friendlyURL + */ + public VLabBean(GroupMembershipType accessPolicy, String friendlyURL) { + super(); + this.accessPolicy = accessPolicy; + this.friendlyURL = friendlyURL; + } + public GroupMembershipType getAccessPolicy() { + return accessPolicy; + } + public void setAccessPolicy(GroupMembershipType accessPolicy) { + this.accessPolicy = accessPolicy; + } + public String getFriendlyURL() { + return friendlyURL; + } + public void setFriendlyURL(String friendlyURL) { + this.friendlyURL = friendlyURL; + } + @Override + public String toString() { + return "VLabBean [accessPolicy=" + accessPolicy + ", friendlyURL=" + friendlyURL + "]"; + } + + + +} diff --git a/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplay.java b/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplay.java new file mode 100644 index 0000000..1335090 --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplay.java @@ -0,0 +1,19 @@ +package org.gcube.portlets.user.vlabs; + +import com.liferay.portal.kernel.log.Log; +import com.liferay.portal.kernel.log.LogFactoryUtil; +import com.liferay.util.bridges.mvc.MVCPortlet; + +/** + * Portlet implementation class VLabsDisplay + */ +public class VLabsDisplay extends MVCPortlet { + private static Log _log = LogFactoryUtil.getLog(VLabsDisplay.class); + + +} + + + + + diff --git a/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplayConfigurationAction.java b/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplayConfigurationAction.java new file mode 100644 index 0000000..d10523e --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/vlabs/VLabsDisplayConfigurationAction.java @@ -0,0 +1,67 @@ +package org.gcube.portlets.user.vlabs; +import javax.portlet.ActionRequest; +import javax.portlet.ActionResponse; +import javax.portlet.PortletConfig; +import javax.portlet.PortletPreferences; +import javax.portlet.RenderRequest; +import javax.portlet.RenderResponse; + +import com.liferay.portal.kernel.log.Log; +import com.liferay.portal.kernel.log.LogFactoryUtil; +import com.liferay.portal.kernel.portlet.DefaultConfigurationAction; + +public class VLabsDisplayConfigurationAction extends DefaultConfigurationAction { + private static Log _log = LogFactoryUtil.getLog(VLabsDisplayConfigurationAction.class); + @Override + public void processAction(PortletConfig portletConfig, ActionRequest actionRequest, ActionResponse actionResponse) throws Exception { + super.processAction(portletConfig, actionRequest, actionResponse); + PortletPreferences prefs = actionRequest.getPreferences(); + String icondocURL = prefs.getValue("icondocURL", "0"); + _log.info("icondocURL = " + icondocURL + " in ConfigurationAction.processAction() saved correctly"); + + String exploratoryName1Title = prefs.getValue("exploratoryName1-Title", ""); + _log.info("exploratoryName1-Title = " + exploratoryName1Title + " in ConfigurationAction.processAction() saved correctly"); + String exploratoryName2Title = prefs.getValue("exploratoryName2-Title", ""); + _log.info("exploratoryName2-Title = " + exploratoryName2Title + " in ConfigurationAction.processAction() saved correctly"); + String exploratoryName3Title = prefs.getValue("exploratoryName3-Title", ""); + _log.info("exploratoryName3-Title = " + exploratoryName3Title + " in ConfigurationAction.processAction() saved correctly"); + String exploratoryName4Title = prefs.getValue("exploratoryName4-Title", ""); + _log.info("exploratoryName4-Title = " + exploratoryName4Title + " in ConfigurationAction.processAction() saved correctly"); + String exploratoryName5Title = prefs.getValue("exploratoryName5-Title", ""); + _log.info("exploratoryName5-Title = " + exploratoryName5Title + " in ConfigurationAction.processAction() saved correctly"); + + + long exploratoryName1DocumentId = Long.parseLong(prefs.getValue("exploratoryName1-DocumentId", "0")); + _log.info("exploratoryName1-DocumentId = " + exploratoryName1DocumentId + " in ConfigurationAction.processAction() saved correctly"); + long exploratoryName2DocumentId = Long.parseLong(prefs.getValue("exploratoryName2-DocumentId", "0")); + _log.info("exploratoryName2-DocumentId = " + exploratoryName2DocumentId + " in ConfigurationAction.processAction() saved correctly"); + long exploratoryName3DocumentId = Long.parseLong(prefs.getValue("exploratoryName3-DocumentId", "0")); + _log.info("exploratoryName3-DocumentId = " + exploratoryName3DocumentId + " in ConfigurationAction.processAction() saved correctly"); + long exploratoryName4DocumentId = Long.parseLong(prefs.getValue("exploratoryName4-DocumentId", "0")); + _log.info("exploratoryName4-DocumentId = " + exploratoryName4DocumentId + " in ConfigurationAction.processAction() saved correctly"); + long exploratoryName5DocumentId = Long.parseLong(prefs.getValue("exploratoryName5-DocumentId", "0")); + _log.info("exploratoryName4-DocumentId = " + exploratoryName5DocumentId + " in ConfigurationAction.processAction() saved correctly"); + + + String exploratory1Url = prefs.getValue("exploratory1-Url", ""); + _log.info("exploratory1-Url = " + exploratory1Url + " in ConfigurationAction.processAction() saved correctly"); + String exploratory2Url = prefs.getValue("exploratory2-Url", ""); + _log.info("exploratory2-Url = " + exploratory2Url + " in ConfigurationAction.processAction() saved correctly"); + String exploratory3Url = prefs.getValue("exploratory3-Url", ""); + _log.info("exploratory3-Url = " + exploratory3Url + " in ConfigurationAction.processAction() saved correctly"); + String exploratory4Url = prefs.getValue("exploratory4-Url", ""); + _log.info("exploratory4-Url = " + exploratory4Url + " in ConfigurationAction.processAction() saved correctly"); + String exploratory5Url = prefs.getValue("exploratory5-Url", ""); + _log.info("exploratory5-Url = " + exploratory5Url + " in ConfigurationAction.processAction() saved correctly"); + + + } + + @Override + public String render(PortletConfig portletConfig, + RenderRequest renderRequest, RenderResponse renderResponse) + throws Exception { + return "/html/vlabsdisplay/config.jsp"; + } + +} \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/liferay-display.xml b/src/main/webapp/WEB-INF/liferay-display.xml new file mode 100644 index 0000000..1ddeb54 --- /dev/null +++ b/src/main/webapp/WEB-INF/liferay-display.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/liferay-plugin-package.properties b/src/main/webapp/WEB-INF/liferay-plugin-package.properties new file mode 100644 index 0000000..8053c4b --- /dev/null +++ b/src/main/webapp/WEB-INF/liferay-plugin-package.properties @@ -0,0 +1,11 @@ +name=vlabs-display-portlet +module-group-id=liferay +module-incremental-version=1 +tags= +short-description= +change-log= +page-url=https://gcube-system.org +author=M. Assante +licenses=EUPL +portal-dependency-jars=\ + vaadin.jar diff --git a/src/main/webapp/WEB-INF/liferay-portlet.xml b/src/main/webapp/WEB-INF/liferay-portlet.xml new file mode 100644 index 0000000..62e84da --- /dev/null +++ b/src/main/webapp/WEB-INF/liferay-portlet.xml @@ -0,0 +1,35 @@ + + + + + + vlabs-display-portlet + /icon.png + org.gcube.portlets.user.vlabs.VLabsDisplayConfigurationAction + true + false + /css/main.css + + /js/main.js + + + virtual-labs-widget + + + + administrator + Administrator + + + guest + Guest + + + power-user + Power User + + + user + User + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/portlet.xml b/src/main/webapp/WEB-INF/portlet.xml new file mode 100644 index 0000000..f08b9e7 --- /dev/null +++ b/src/main/webapp/WEB-INF/portlet.xml @@ -0,0 +1,42 @@ + + + + + vlabs-display-portlet + Virtual Labs Display + + org.gcube.portlets.user.vlabs.VLabsDisplay + + + view-template + /html/vlabsdisplay/view.jsp + + + config-template + /html/vlabsdisplay/config.jsp + + 0 + + text/html + view + config + + + Virtual Labs Display + Virtual Labs Display + + + + administrator + + + guest + + + power-user + + + user + + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/web.xml b/src/main/webapp/WEB-INF/web.xml new file mode 100644 index 0000000..7d8c082 --- /dev/null +++ b/src/main/webapp/WEB-INF/web.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/src/main/webapp/css/main.css b/src/main/webapp/css/main.css new file mode 100644 index 0000000..8bdfe06 --- /dev/null +++ b/src/main/webapp/css/main.css @@ -0,0 +1,36 @@ +.virtual-labs-widget .asset-title { + border-bottom: 1px solid #DDD; + margin-right: 8px; + padding-bottom: 1px; +} + +.virtual-labs-widget .asset-summary { + font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; + font-size: 14px; + line-height: 20px; +} + +.virtual-labs-widget .access-policy { + float: right; + font-size: 13px; + font-weight: 300; + padding: 10px; + line-height: 17px; + height: 17px; +} + +.open-color { + color: #008000; +} + +.restricted-color { + color: #f2994a; +} + +.private-color { + color: #AAA; +} + +.virtual-labs-widget .access-policy img { + width: 14px; +} \ No newline at end of file diff --git a/src/main/webapp/html/vlabsdisplay/config.jsp b/src/main/webapp/html/vlabsdisplay/config.jsp new file mode 100644 index 0000000..6aa4a34 --- /dev/null +++ b/src/main/webapp/html/vlabsdisplay/config.jsp @@ -0,0 +1,306 @@ +<%@include file="init.jsp"%> + + + +Here you can customise the icon to show besides the vlab name + +<% + String icondocURL = GetterUtil.getString(portletPreferences.getValue("icondocURL", StringPool.BLANK)); + + String vlabName1Title = GetterUtil.getString(portletPreferences.getValue("vlabName1-Title", StringPool.BLANK)); + String vlabName2Title = GetterUtil.getString(portletPreferences.getValue("vlabName2-Title", StringPool.BLANK)); + String vlabName3Title = GetterUtil.getString(portletPreferences.getValue("vlabName3-Title", StringPool.BLANK)); + String vlabName4Title = GetterUtil.getString(portletPreferences.getValue("vlabName4-Title", StringPool.BLANK)); + String vlabName5Title = GetterUtil.getString(portletPreferences.getValue("vlabName5-Title", StringPool.BLANK)); + String vlabName6Title = GetterUtil.getString(portletPreferences.getValue("vlabName6-Title", StringPool.BLANK)); + String vlabName7Title = GetterUtil.getString(portletPreferences.getValue("vlabName7-Title", StringPool.BLANK)); + String vlabName8Title = GetterUtil.getString(portletPreferences.getValue("vlabName8-Title", StringPool.BLANK)); + String vlabName9Title = GetterUtil.getString(portletPreferences.getValue("vlabName9-Title", StringPool.BLANK)); + + + long vlabName1DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName1-DocumentId", StringPool.BLANK)); + long vlabName2DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName2-DocumentId", StringPool.BLANK)); + long vlabName3DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName3-DocumentId", StringPool.BLANK)); + long vlabName4DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName4-DocumentId", StringPool.BLANK)); + long vlabName5DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName5-DocumentId", StringPool.BLANK)); + long vlabName6DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName6-DocumentId", StringPool.BLANK)); + long vlabName7DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName7-DocumentId", StringPool.BLANK)); + long vlabName8DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName8-DocumentId", StringPool.BLANK)); + long vlabName9DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName9-DocumentId", StringPool.BLANK)); + + + String vlab1Url = GetterUtil.getString(portletPreferences.getValue("vlab1-Url", StringPool.BLANK)); + String vlab2Url = GetterUtil.getString(portletPreferences.getValue("vlab2-Url", StringPool.BLANK)); + String vlab3Url = GetterUtil.getString(portletPreferences.getValue("vlab3-Url", StringPool.BLANK)); + String vlab4Url = GetterUtil.getString(portletPreferences.getValue("vlab4-Url", StringPool.BLANK)); + String vlab5Url = GetterUtil.getString(portletPreferences.getValue("vlab5-Url", StringPool.BLANK)); + String vlab6Url = GetterUtil.getString(portletPreferences.getValue("vlab6-Url", StringPool.BLANK)); + String vlab7Url = GetterUtil.getString(portletPreferences.getValue("vlab7-Url", StringPool.BLANK)); + String vlab8Url = GetterUtil.getString(portletPreferences.getValue("vlab8-Url", StringPool.BLANK)); + String vlab9Url = GetterUtil.getString(portletPreferences.getValue("vlab9-Url", StringPool.BLANK)); + + + + String displayName_cfg = ""; +%> + + + + + + +

Enter the vlab in the following:

+ + + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + + + + + +
+ + +
+
+ + + +
\ No newline at end of file diff --git a/src/main/webapp/html/vlabsdisplay/init.jsp b/src/main/webapp/html/vlabsdisplay/init.jsp new file mode 100644 index 0000000..789a346 --- /dev/null +++ b/src/main/webapp/html/vlabsdisplay/init.jsp @@ -0,0 +1,22 @@ +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + +<%@ taglib uri="http://liferay.com/tld/aui" prefix="aui" %> +<%@ taglib uri="http://liferay.com/tld/portlet" prefix="liferay-portlet" %> +<%@ taglib uri="http://liferay.com/tld/theme" prefix="liferay-theme" %> + + + +<%@ page import="org.gcube.portlets.user.vlabs.VLabBean" %> +<%@ page import="com.liferay.portal.kernel.util.Constants" %> +<%@ page import="com.liferay.portal.kernel.util.GetterUtil" %> +<%@ page import="com.liferay.portal.kernel.util.StringPool" %> +<%@ page import="com.liferay.portlet.journal.model.JournalArticle" %> +<%@ page import="com.liferay.portlet.journal.service.JournalArticleLocalServiceUtil" %> +<%@ page import="com.liferay.portal.kernel.xml.Document" %> +<%@ page import="com.liferay.portal.kernel.xml.Node" %> +<%@ page import="com.liferay.portal.kernel.xml.SAXReaderUtil" %> +<%@ page import="com.liferay.portal.kernel.util.HtmlUtil" %> +<%@ taglib uri="http://java.sun.com/portlet_2_0" prefix="portlet"%> + + + \ No newline at end of file diff --git a/src/main/webapp/html/vlabsdisplay/view.jsp b/src/main/webapp/html/vlabsdisplay/view.jsp new file mode 100644 index 0000000..27a3ec2 --- /dev/null +++ b/src/main/webapp/html/vlabsdisplay/view.jsp @@ -0,0 +1,420 @@ +<%@include file="init.jsp"%> +<%@ page import="org.gcube.portlets.user.vlabs.Utils" %> +<%@ page import="com.liferay.portal.model.User" %> +<%@ page import="com.liferay.portal.util.PortalUtil" %> + +<% + final int abstractCharsLenghtMax = 256; + + long groupId = themeDisplay.getLayout().getGroupId(); + User currentUser = PortalUtil.getUser( request ); + pageContext.setAttribute("icondocURL", + GetterUtil.getString(portletPreferences.getValue("icondocURL", StringPool.BLANK))); + + pageContext.setAttribute("vlabName1Title", + GetterUtil.getString(portletPreferences.getValue("vlabName1-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName2Title", + GetterUtil.getString(portletPreferences.getValue("vlabName2-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName3Title", + GetterUtil.getString(portletPreferences.getValue("vlabName3-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName4Title", + GetterUtil.getString(portletPreferences.getValue("vlabName4-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName5Title", + GetterUtil.getString(portletPreferences.getValue("vlabName5-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName6Title", + GetterUtil.getString(portletPreferences.getValue("vlabName6-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName7Title", + GetterUtil.getString(portletPreferences.getValue("vlabName7-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName8Title", + GetterUtil.getString(portletPreferences.getValue("vlabName8-Title", StringPool.BLANK))); + pageContext.setAttribute("vlabName9Title", + GetterUtil.getString(portletPreferences.getValue("vlabName9-Title", StringPool.BLANK))); + + + long vlabName1DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName1-DocumentId", StringPool.BLANK)); + long vlabName2DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName2-DocumentId", StringPool.BLANK)); + long vlabName3DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName3-DocumentId", StringPool.BLANK)); + long vlabName4DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName4-DocumentId", StringPool.BLANK)); + long vlabName5DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName5-DocumentId", StringPool.BLANK)); + long vlabName6DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName6-DocumentId", StringPool.BLANK)); + long vlabName7DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName7-DocumentId", StringPool.BLANK)); + long vlabName8DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName8-DocumentId", StringPool.BLANK)); + long vlabName9DocumentId = GetterUtil.getLong(portletPreferences.getValue("vlabName9-DocumentId", StringPool.BLANK)); + + + String url1 = GetterUtil.getString(portletPreferences.getValue("vlab1-Url", StringPool.BLANK)); + VLabBean vLabBean1 = Utils.getVLabBean(currentUser, url1); + pageContext.setAttribute("vlab1Url", vLabBean1.getFriendlyURL()); + String ap1 = vLabBean1.getAccessPolicy().toString().toLowerCase(); + pageContext.setAttribute("ap1",ap1); + + String url2 = GetterUtil.getString(portletPreferences.getValue("vlab2-Url", StringPool.BLANK)); + VLabBean vLabBean2 = Utils.getVLabBean(currentUser, url2); + pageContext.setAttribute("vlab2Url", vLabBean2.getFriendlyURL()); + String ap2 = vLabBean2.getAccessPolicy().toString().toLowerCase(); + pageContext.setAttribute("ap2",ap2); + + String url3 = GetterUtil.getString(portletPreferences.getValue("vlab3-Url", StringPool.BLANK)); + VLabBean vLabBean3 = Utils.getVLabBean(currentUser, url3); + pageContext.setAttribute("vlab3Url", vLabBean3.getFriendlyURL()); + String ap3 = vLabBean3.getAccessPolicy().toString().toLowerCase(); + pageContext.setAttribute("ap3",ap3); + + String url4 = GetterUtil.getString(portletPreferences.getValue("vlab4-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab4Url", Utils.getVLabBean(currentUser, url4).getFriendlyURL()); + + String url5 = GetterUtil.getString(portletPreferences.getValue("vlab5-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab5Url", Utils.getVLabBean(currentUser, url5).getFriendlyURL()); + + String url6 = GetterUtil.getString(portletPreferences.getValue("vlab6-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab6Url", Utils.getVLabBean(currentUser, url6).getFriendlyURL()); + + String url7 = GetterUtil.getString(portletPreferences.getValue("vlab7-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab7Url", Utils.getVLabBean(currentUser, url7).getFriendlyURL()); + + String url8 = GetterUtil.getString(portletPreferences.getValue("vlab8-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab8Url", Utils.getVLabBean(currentUser, url8).getFriendlyURL()); + + String url9 = GetterUtil.getString(portletPreferences.getValue("vlab9-Url", StringPool.BLANK)); + pageContext.setAttribute("vlab9Url", Utils.getVLabBean(currentUser, url9).getFriendlyURL()); + + String content1 = ""; + if (vlabName1DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName1DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content1 = node.getText(); + } + + String content2 = ""; + if (vlabName2DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName2DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content2 = node.getText(); + } + + String content3 = ""; + if (vlabName3DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName3DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content3 = node.getText(); + } + String content4 = ""; + if (vlabName4DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName4DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } + String content5 = ""; + if (vlabName5DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName5DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } + String content6 = ""; + if (vlabName6DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName6DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } + String content7 = ""; + if (vlabName4DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName7DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } + String content8 = ""; + if (vlabName8DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName8DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } + String content9 = ""; + if (vlabName9DocumentId > 0) { + JournalArticle article = JournalArticleLocalServiceUtil.getArticle(groupId, + "" + vlabName9DocumentId); + Document document = SAXReaderUtil.read(article.getContent()); + Node node = document.selectSingleNode("/root/static-content"); + content4 = node.getText(); + } +%> + + +
+

+ + ${vlabName1Title}  ${ap1} +

+
+
+ <% + if (content1.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content1.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + +
+

+ + ${vlabName2Title}  ${ap2} +

+
+
+ <% + if (content2.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content2.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + +
+

+ + ${vlabName3Title}  ${ap3} +

+
+
+ <% + if (content3.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content3.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + +
+

+ + ${vlabName4Title} +

+
+
+ <% + if (content4.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content4.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + + +
+

+ + ${vlabName5Title} +

+
+
+ <% + if (content5.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content5.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + + +
+

+ + ${vlabName6Title} +

+
+
+ <% + if (content6.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content6.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + + +
+

+ + ${vlabName7Title} +

+
+
+ <% + if (content7.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content7.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + + + +
+

+ + ${vlabName8Title} +

+
+
+ <% + if (content8.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content8.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
+ + + + +
+

+ + ${vlabName9Title} +

+
+
+ <% + if (content9.length() > abstractCharsLenghtMax) + out.println(HtmlUtil.stripHtml(content9.substring(0, abstractCharsLenghtMax) + " ...")); + %> + + +
+ +
+
+ +
+
+
\ No newline at end of file diff --git a/src/main/webapp/icon.png b/src/main/webapp/icon.png new file mode 100644 index 0000000..807b862 Binary files /dev/null and b/src/main/webapp/icon.png differ diff --git a/src/main/webapp/images/open.png b/src/main/webapp/images/open.png new file mode 100644 index 0000000..0f755a5 Binary files /dev/null and b/src/main/webapp/images/open.png differ diff --git a/src/main/webapp/images/private.png b/src/main/webapp/images/private.png new file mode 100644 index 0000000..0c63682 Binary files /dev/null and b/src/main/webapp/images/private.png differ diff --git a/src/main/webapp/images/restricted.png b/src/main/webapp/images/restricted.png new file mode 100644 index 0000000..631a921 Binary files /dev/null and b/src/main/webapp/images/restricted.png differ diff --git a/src/main/webapp/js/main.js b/src/main/webapp/js/main.js new file mode 100644 index 0000000..e69de29