Utilizzando questa procedura, è possibile creare autonomamente i file WAR di cui si ha necessità partendo da un template già esistente su Artifactory.
E' vivamente consigliato, anche se non mandatorio, che tale procedura venga attuata nelle folder appositamente predisposte nella versione locale del Repository di Commessa, descritto qui.
Prima di procedere, ci si deve assicurare di aver installato nel proprio pc sia Apache Maven (Installazione di Maven) sia Git (Installazione di Git).
La prima cosa da fare per creare un progetto di base nel proprio pc cliccare sul seguente link e avviare il download della cartella ZIP, in base alla versione major del progetto da generare:
Dopo aver decompresso makegproj-4.6.x.zip, salvare il file makegproj-4.6.x.bat nella cartella del repository di prodotto/commessa. Step:
La finestra di shell mostrerà l'avanzamento del download.
Alla fine del processo, la finestra si chiuderà automaticamente e si avrà una cartella con il nome del progetto (cioè quello inserito precedentemente in makeproj.bat) che conterrà tutti i file di configurazione con setting di base.
Il file makegproj*.bat, quindi, è utilizzato una tantum, cioè solo nella fase iniziale della creazione del nuovo progetto.
La prima operazione da fare è intervenire sul file pom.xml:
<dependency> <groupId>com.geowebframework</groupId> <artifactId>ispplugin</artifactId> <version>1.0.0</version> </dependency>
In aggiunta, devono essere eventualmente modificati anche alcuni file di configurazione. In particolare, nel percorso [nome_progetto]\src\main\resources\ ci sono:
Invece, nel percorso [nome_progetto]\src\main\webapp\WEB-INF\ si trovano:
Le modifiche apportate ai vari file dipendono dal progetto, ma anche dall'ambiente in cui il progetto deve essere utilizzato.
Sono provvisti nel modello 3 file spring-security.xml
Di default è utilizzato lo spring-security-keycloak.xml Questa configurazione può essere modificata nel file web.xml
<!-- Spring Security STARTS --> <context-param> <param-name>contextConfigLocation</param-name> <param-value> <!-- TODO CONFIGURE, choose one between: --> <!-- /WEB-INF/spring-security.xml --> <!-- /WEB-INF/spring-security-keycloak.xml --> /WEB-INF/spring-security-keycloak.xml </param-value> </context-param>
Lasciare solo lo spring-security*.xml di interesse, eliminando gli altri, e verificare la coerenza nel web.xml
Nel pom.xml sono commentati tutti i plugin disponibili allo stato attuale nel repository del framework. Come sempre, decommentare i necessari moduli ed eliminare gli altri. Aggiungere inoltre le dipendenze di eventuali repository di prodotto o di commessa.
Le versione 4.5.0-SNAPSHOT era, secondo corrette politiche aziendali, destinata solo allo sviluppo. Logiche di commessa hanno portato di fatto all'utilizzo di questa versione. Il dispiegamento sui clienti ha forzato anche il relativo versionamento: 4.5.1, 4.5.2, etc.. Per le versioni 4.5.X non è stato prodotto uno specifico makegproj.bat. In attesa di uno specifico, la prassi da seguire è utilizzare il makegproj.bat precedente, avendo cura di modificare lo spring-security.xml in alcune parti
dentro il tag
<http auto-config="true" use-expressions="true" disable-url-rewriting="true"> ... </http>
va aggiunta la parte:
<intercept-url pattern="/resources/#{ T(com.geowebframework.metadataservice.registry.GwReleaseInfos).getRevision() }/fontawesome/**" access="permitAll" /> <!--issue #509--> <intercept-url pattern="/resources/#{ T(com.geowebframework.metadataservice.registry.GwReleaseInfos).getRevision() }/images/favicon.png" access="permitAll" /> <intercept-url pattern="/resources/#{ T(com.geowebframework.metadataservice.registry.GwReleaseInfos).getRevision() }/images/${images.login.form.logo:gw4_enterprise.png}" access="permitAll" /> <intercept-url pattern="/resources/#{ T(com.geowebframework.metadataservice.registry.GwReleaseInfos).getRevision() }/${images.IndexBackground:IndexBackground.jpg}" access="permitAll" />
immediatamente sotto la parte:
<intercept-url pattern="/resources/#{ T(com.geowebframework.metadataservice.registry.GwReleaseInfos).getRevision() }/icons/**" access="permitAll" />
Senza il fix potrebbe comparire navigando la schermata:
Terminate tutte le operazioni di configurazione e personalizzazione del progetto maven, bisogna assicurarsi di avere sotto la cartella dell'ambiente specifico, a seconda dell'OS, uno dei seguenti file:
E' possibile fare il download della seguente cartella compressa, che li contiene entrambi: makegwar.zip
Doppio click per eseguire il file. Si aprirà una finestra di shell che mostrerà l'avanzamento dell'operazione. Al termine della procedura, nella finestra verrà riportato un messaggio di successo se tutto è andato a buon fine, oppure un messaggio di errore in caso di eventuali problemi. Il file WAR viene automaticamente salvato all'interno si mvn_project_name/target.
(Dalla versione 4.6.12) issue #1257
L'eccessivo ingombro degli artefatti webadmin (circa 250MB), che andavano a finire su Artifactory ad ogni tag, combinato al contestuale cambiamento delle policy di rilascio che ha previsto un tag esclusivo per ogni fix (sulla quarta cifra di versionamento 4.6.x.y), ha spinto per la trasformazione del modulo maven gw-webadmin in jar, in maniera che potesse essere inglobato in un pom.xml generico per la creazione del war.
Considerando anche gli effetti della issue #1256, i peso dell'artifact gw-webadmin è passato da 250MB a meno di 2MB su Artifactory
Analogamente alla metodologia di produzione del war del webclient, è disponibile un template specifico da cui partire (valido per 4.6.* e 4.7.*)
Vanno eseguiti passaggi del tutto simili alla produzione dei war webclient.
In generale non ci sarà mai bisogno di aggiungere maven dependency al pom.xml.
Le dipendenze che erano supportate precedentemente continuano ad esserlo Widget e servizi interni al progetto geowebframework di:
Widget e servizi esterni al progetto geowebframework
Widget e servizi deprecati:
Se necessario ulteriori plugin di commessa/progetto che coinvolgano widget/tipi di menu possono essere sviluppati con la medesima modalità. L'unica accortezza, nell'eventuale aggiunta della relativa dependency al pom.xml del webadmin, e solo se questa abbia come propria dependency webclient, è quella di aggiungere solo le class:
Questo dovrebbe essere fatto in una delle modalità consentite da maven, da adattare in base al caso specifico.