[gelöst]Rules account update
am 28.02.2012 - 16:24 Uhr in
Ich bin gerade dabei eine knifflige Aufgabe zu lösen und freue mich über Denkanstösse bzw. Lösungen.
Bei der Regsitrierung kann ein User zwischen drei Account-ARten wählen: 30 Tage Test-Account, 3 Monats-Account und 6-Monats-Account. Je nachdem welche Art er wählt bekommt er eine spezifische Rolle zugewiesen (30 Tage Test, 3 Monatsaccount, 6 Monatsaccount).
Mittels Rules gescheiht nun folgendes: Legt er jetzt einen Node eines Inhaltstyps x (u.a. Datumsfeld) an wird in Abhängigkeit der Rolle des Authors das Datumsfeld entsprechend berechnet (bspw. + 3 Monate) und ein Scheduler aufgerufen, der den Node in 3 Monaten auf unpublish setzt.
Jetzt möchte ich gerne dass der User seinen Account updaten kann. Dafür habe ich einen eigenen Inhaltstypen erstellt mit einer Auswahlliste (3 Monate, 6 Monate) und möchte bei der Erstellung dieses Contenttypes dem User verschiedene Rollen zuweisen (das funktioniert auch!) UND das Datumsfeld meines Inhaltstyps x manipulieren, indem ich bspw. noch einmal 3 Monate addiere. Wie kann ich diesen letzten Schritt machen?
- Anmelden oder Registrieren um Kommentare zu schreiben
Ich würde es "mit der Hand"
am 28.02.2012 - 17:10 Uhr
Ich würde es "mit der Hand" machen.
Du kannst doch mittels Rules auch ein PHP-Script auführen und genau dort würde ich einen MySQL Update Befehl für dieses Datumsfeld reinschreiben.
Das ist sicher die einfachste Lösung und so wie ich dein Posting einschätze, bekommst du so einen Update-Befehl mit PHP leicht hin :-)
liebe Grüsse
Berthold Lausch
Datenbank Update mitteld DATE_ADD
am 29.02.2012 - 10:56 Uhr
Vielen Dank Berthold Lausch für den Tip!
Ich habe nun ein Update Befehl in das PHP-Script eingefügt:
$getnid = db_query("SELECT field_ref_myfield_nid FROM {field_data_field_ref_mycontenttype} WHERE entity_id = :fetchentity", array(':fetchentity' => [node:nid]))->fetchField();
db_update('field_data_field_expiration_date')
->condition('entity_id', '1')
->fields(array('field_expiration_date_value' => DATE_ADD(field_expiration_date_value, INTERVAL 3 MONTH))
->execute();
Nur leider wird das Feld in der Datenbank nicht manipuliert. Meine Versuche in der Datenbank direkt über mysql das Feld zu manipulieren waren erfolgreich. Hat jemand einen Tip?
Dann stimmt wohl was an den
am 29.02.2012 - 12:30 Uhr
Dann stimmt wohl was an den beiden MySQL-Befehlen nicht.
Wenn du dir die Varialbe $getnid ausgeben läßt, steht da denn die richtige ID drin.
Das wäre doch ein erster Schritt, die beiden Befehle auf ihre Richtigkeit zu testen.
Die PHP-Funktion mysql_error liefert auch immer ganz brauchbarer Ergebnisse, wenn es darum geht, einen Fehler zu finden.
Grüsse
Berthold Lausch
Convert Date in String
am 29.02.2012 - 14:48 Uhr
Das war dann doch etwas komplexer. Aber jetzt funktioniert es :-)))
Es lag daran, dass das Datumsfeld nicht als STring ausgelesen wurde. Jetzt sehen die Abfragen folgendermaßen aus:
$nid = db_query("SELECT field_ref_myfield_nid FROM {field_data_field_ref_mycontenttype} WHERE entity_id = :fetchentity", array(':fetchentity' => [entity-referenceid:nid],))->fetchField();
$datum = db_query("SELECT DATE_ADD(DATE_FORMAT(field_expiration_date_value, '%Y-%m-%d %H:%i:%s'), INTERVAL 3 MONTH) FROM {field_data_field_expiration_date} WHERE entity_id = :fetchentity", array(':fetchentity' => $nid,))->fetchField();
db_update('field_data_field_expiration_date')
->fields(array('field_expiration_date_value' => $datum))
->condition('entity_id', $nid)
->execute();
Daten werden aus der field_revision Tabelle gelesen
am 01.03.2012 - 14:21 Uhr
Nachdem ich den PHP-Code wie oben beschrieben ausgeführt habe ist mir aufgefallen, dass das Feld im Node die Daten aus der entsprechenden field_revision_field_myfield ausliest und nicht aus der field_data_field_myfield. Damit die Daten richtig in die Datenbank reingeschrieben werden habe ich jetzt folges Skript programmiert:
$nodeid = db_query("SELECT field_ref_myfield_nid FROM {field_data_field_ref_mynode} WHERE entity_id = :fetchentity", array(':fetchentity' => [node:nid],))->fetchField();
//debug($nodeid, 'Node ID:', true);
$nodeidload = node_load($nodeid);
$lang = LANGUAGE_NONE;
$aktdate = $nodeidload->field_expiration_date['und']['0']['value'];
//debug($aktdate, 'Aktuelles Datum', true);
$dateThreeMonthAdded = strtotime(date("Y-m-d", strtotime($aktdate)) . "+3 month");
$updatedate = date("Y-m-d h:i:s", $dateThreeMonthAdded);
//debug($updatedate, 'Ablaufdatum nach Update', true);
$nodeidload->field_expiration_date['und'][0]['value'] = $updatedate;
node_save($nodeidload);
Nun funktioniert endlich alles :-) Juchhu!