mercoledì 14 ottobre 2015

Attivare VirtueMart SEO senza utilizzare il suffisso nella pagina del dettaglio

Dalla versione 1.0 di Joomla! è consuetudine considerare Virtuemart l'estensione per fare e-commerce per eccellenza.

Oggi ci sono moltissime alternative (più o meno valide) ma VM ha indubbiamente ancora la community più forte, in particolare qui in Italia. Rispetto al passato è anche meglio integrato in Joomla! e dalla versione 2 è anche MVC e gestisce i campi come plugin per Joomla, cosa non trascurabile.

Al di là di questo VM ha ancora alcuni limiti che gli fanno preferire altri componenti o altre piattaforme.

Uno di questi limiti è la gestione delle url SEO. Infatti le impostazioni SEO impongono l'utilizzo di un suffisso alla pagina di dettaglio del prodotto (con il valore predefinito detail).

Ovviamente questo in taluni casi può non essere accettabile, soprattutto se si devono preservare delle vecchia e URL.

Nel caso non venga impostato un suffisso le opzioni SEO non funzioneranno.
L'unico modo di risolvere sarà quindi l'utilizzo di ulteriori componenti che permettano la riscrittura completa dell'url.

venerdì 9 ottobre 2015

MySQL non fa più accedere l'utente ROOT

Non riesco più a accedere a MySQL

Può capitare che la password di root di MySQL non funzioni più o che semplicemente sia stata smarrita.

Al di là della classica domanda iniziale "Perchè!?" quella di cui vi preoccuperà nei minuti successivi la scoperta sarà "che fare????"

In questo post cercherò di fornire una risposta efficace alla seconda, lasciando a voi il piacere (!) di scoprire la risposta alla prima.

Reimpostare la password di root di MySQL

Per reimpostare la password di root di MySQL è sufficiente eseguire la stessa operazione che fate quando reimpostate quella del Vs. CMS preferito: tramite una query.

Se nel caso di Wordpress, Drupal, Joomla, Magento o altro CMS che dir si voglia, basta accedere a phpMyAdmin o, per gli amanti del nero, alla riga di comando del terminale, per eseguire l'UPDATE di un campo, qui la situazione è apparentemente drammatica, perchè non si riesce ad accedere proprio alle tabelle i MySQL.

E' però possibile avviare MySQL senza i permessi (GRANT) per cui il problema "password" viene bypassato e sarà possibile eseguire la query di update per il reset della password.

Inutile dire che l'operazione NON VA ESEGUITA su di un server di produzione quando è accessibile da altri utenti.

Vediamo quindi i passaggi da eseguire da terminale:

1) fermate il servizio MySQL, su Debian / Mint / Ubuntu:
sudo service mysql stop
2) avviate MySQL disabilitando le GRANT sulle tabelle:
sudo mysqld --skip-grant-tables
non apparirà nessun prompt dei comandi, non potrete quindi aggiungere altri comandi e la schermata sembrerà bloccata. E' NORMALE

3) aprite una nuova istanza del terminale.

4) avviate mysql:
mysql start
5) selezionate il database di sistema di MySQL:
use mysql
6) eseguite una query di update:
update user set password=password('lamiapasswordsupersicura') where user='root'
A questo punto potrete accedere nuovamente con l'utente root utilizzando la password che avete impostato, "lamiapasswordsupersicura" nel caso abbiate fatto copia/incolla della riga qui sopra.

Ora che potete di nuovo accedere ai vostri dati, avete tutto il tempo per tornare ad interrogarvi sull'origine del problema.

Per saperne di più leggete questo post nel forum di Ubuntu

mercoledì 7 ottobre 2015

Alcuni semplici ma utili script per Joomla!

Ottenere il nome del template corrente di Joomla!

Questo script può tornare utile quando si sta scrivendo il percorso di un css su Joomla e lo si sta caricando tramite il metodo addStylesheet() di JDocument.

Ottenere il prefisso delle tabelle indicato nella configurazione in Joomla!

Questo script (da usare solo in debug) è particolarmente comodo quando si fa scrive la query di un modello nell'output della pagina e lo si vuole incollare in phpMyAdmin o Heidi per eseguire la query, in questo modo eliminerete gli antipatici cancelletti.

Caricare un modulo di Joomla con il codice

Con questo script potrete caricare all'interno di qualsiasi file un modulo di Joomla! Vi consiglio di impostare la visibilità del modulo su Tutte le pagine e assegnare come posizione un non nome dedicato (in questo Gist "statistics"), in questo modo il modulo comparirà solo nelle pagine dove avrete inserito il codice.

Effettuare il dump di un DB Joomla senza accedere a phpMyAdmin

In questo caso al posto del Gist inserisco direttamente il link allo script su GitHub.
Basta copiarlo sulla root e lanciare lo script dalla barra dell'indirizzo, creerà automaticamente il dump in una cartella dedicata sulla root.

Provatelo e commentatelo su GitHub!