Eindeutige Profil-Felder definieren
![](http://www.drupalcenter.de/files/noavatar_mini.gif)
am 05.08.2009 - 16:53 Uhr in
Hallo,
ich bin auf der Suche nach einer Möglichkeit, wie in einem Benutzerprofil eigene Felder angelegt werden können, bei denen die Inhalte nur einmal vorkommen können, z.B. ein Autokennzeichen.
Ich habe ein zusätzliches Feld anlegen können, aber auf welchem Weg bzw. mit welchem Modul kann ich relativ einfach einen Code einbauen, der
1. Das Feld auf ein gewisses Eingabeformat hin prüft und
2. sicherstellt, daß es den Inhalt nicht bereits gibt.
Nachdem Drupal zusätzliche Profilfelder nicht 1:1 in der MySQL-Datenbank abbildet, scheidet der Versuch, das entsprechende Feld einfach "unique" zu setzen, aus (mal davon abgesehen, daß wohl die mySQL-Fehlermeldung direkt ausgegeben würde, was unschön aussieht).
Ich hoffe, es kennt jemand diese Problematik und weiß eine Lösung, ich bin noch recht frisch, was Drupal angeht.
Vielen Dank im Voraus
korinor
- Anmelden oder Registrieren um Kommentare zu schreiben
Ideen: in einem eigenen
am 06.08.2009 - 13:11 Uhr
Ideen:
in einem eigenen Modul eine validate function für das Formular definieren.
http://api.drupal.org/api/file/developer/topics/forms_api.html
Oder falls deine Profile Nodes sind:
http://www.drupalcenter.de/handbuch/14954
Es mit einem von diesen versuchen:
http://drupal.org/project/validation_api
http://drupal.org/project/ajax
Hallo luzer, erst mal sorry,
am 19.08.2009 - 17:29 Uhr
Hallo luzer,
erst mal sorry, daß meine Antwort etwas spät kommt. Ich hatte mich zwischenzeitlich in deine Vorschläge etwas eingelesen und bin dann bei der validation_api hängengeblieben, da ich ganz normale "Core profile" von Drupal benutze.
Da ich nicht ganz der Profi bin, hatte ich mit der validation_api etwas zu kämpfen, weil mir die Dokumentation etwas zu knapp ist. Aber ich habe es geschafft, was ich wollte.
Wie schon beschrieben, habe ich ein Feld angelegt, welches der User selber eintragen darf, ist also kein Pflichtfeld. Aber wenn er was reinschreibt, soll es eindeutig sein, d.h. ein anderer User kann nicht das gleiche reinschreiben. Zusätzliche habe ich eine Regel eingebaut, die die Eingabe auf gewisse Formatierungen prüft, das hat mit einer REGEX-Regel von validation_api ganz gut geklappt.
Als PHP-Script habe ich folgendes eingetragen:
<?php
// UID des aktuellen Users
$my_uid = $GLOBALS['user']->uid;
// Datenbank prüfen, ob das Kennzeichen bereits vorhanden ist
// fid = Feld-ID von Feld KFZ-Kennzeichen, in Tabelle profile_fields ersichtlich
$query = "SELECT count(*) AS anzahl FROM profile_values WHERE fid = 2 AND value = '".$value."' AND uid <> ".$my_uid;
$result = db_query($query, array(), array('fetch' => PDO::FETCH_ASSOC,) );
$anzahl = $result->fetch_row();
// Wenn die Anzahl = 0, dann wurde das eingegebene Kennzeichen nicht in der Datenbank gefunden,
// Eingabe ist also in Ordnung und kann gespeichert werden (return TRUE). Ansonsten ist der Wert
// bereits vorhanden und kann nicht gespeichert werden.
if ($anzahl[0] == 0) { return TRUE; } else { return FALSE; }
?>
Ich hoffe, daß das jemandem weiterhilft. Ich finde nämlich die validation_api sehr gelungen, ist für Einsteiger aber schwer verdaulich, wenn die Dokumentation mehr für Profis ausgerichtet ist. Ehrlich gesagt hatte ich das auch nicht umrissen, daß ich die
<?php ?>
am Anfang und Ende nicht mit eingeben darf, man in jedem Eintrag zum Thema Google aber in der Form so vorfindet. Das verwirrt.Grüße
korinor