Come faccio ad aggiungere i valori di default per una tabella di database utilizzando hook_install ()?

drupal.stackexchange https://drupal.stackexchange.com/questions/9462

  •  16-10-2019
  •  | 
  •  

Domanda

Io sono la creazione di un modulo personalizzato con un proprio schema di pochi tavoli. Queste tabelle devono avere alcuni valori pre-popolati in loro per il modulo di lavoro (posizioni predefinite, selezionare le opzioni, ecc).

Qual è il modo migliore pratiche per inserire i valori di default in queste tabelle durante hook_install?

Dato drupal_write_record non è disponibile, posso usare db_query, ma voglio solo fare in modo che non sto rompendo le regole cardinali in questo modo.

È stato utile?

Soluzione

Il modo migliore è quello di farlo all'interno hook_enable () ; al momento in cui il gancio viene richiamato, il modulo è già installato, e lo schema del proprio database è disponibile per Drupal, e drupal_write_record(). Poiché il gancio viene richiamato costantemente un modulo è abilitato, e non solo quando è installato il modulo, l'attuazione gancio deve controllare se non aggiunto quelle file di database già (ad esempio, dovrebbe utilizzare una variabile Drupal contenente un valore booleano) .

Come esempio di modulo che usi hook_enable() per uno scopo simile, è possibile controllare forum_enable () o php_enable () (che aggiunge il "formato di input codice PHP").

function php_enable() {
  $format_exists = (bool) db_query_range('SELECT 1 FROM {filter_format} WHERE name = :name', 0, 1, array(':name' => 'PHP code'))->fetchField();
  // Add a PHP code text format, if it does not exist. Do this only for the
  // first install (or if the format has been manually deleted) as there is no
  // reliable method to identify the format in an uninstall hook or in
  // subsequent clean installs.
  if (!$format_exists) {
    $php_format = array(
      'format' => 'php_code', 
      'name' => 'PHP code',
      // 'Plain text' format is installed with a weight of 10 by default. Use a
      // higher weight here to ensure that this format will not be the default
      // format for anyone. 
      'weight' => 11, 
      'filters' => array(
        // Enable the PHP evaluator filter.
        'php_code' => array(
          'weight' => 0, 
          'status' => 1,
        ),
      ),
    );
    $php_format = (object) $php_format;
    filter_format_save($php_format);

    drupal_set_message(t('A <a href="@php-code">PHP code</a> text format has been created.', array('@php-code' => url('admin/config/content/formats/' . $php_format->format))));
  }
}

Come mostrato da tali implementazioni gancio, il codice potrebbe necessariamente essere eseguito ogni momento viene eseguito il gancio; potrebbe anche essere il codice deve solo eseguito una volta, come nel caso i valori di default aggiunti al database non possono essere modificati dall'utente, che non dispone di un'interfaccia utente di modificare / cancellare quei valori.

Altri suggerimenti

mi piacerebbe andare con db_query / db_insert (D6 / D7) in hook_install ().

Non è considerato cattiva pratica (e nessuno è mai ti costringe a usare drupal_write_record()).

Non è raro per le persone di disattivare e riattivare i moduli, e in tal caso il codice in hook_enable() avrebbe sparato ogni volta. che non è bello.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a drupal.stackexchange
scroll top