[Gelöst] User Relationship: Tabelleninhalt unklar, UR access rights von CCK Feldern bzw. Node auslesen
am 23.09.2010 - 22:12 Uhr in
Hallo liebe Drupal-Gemeinde,
ich mal wieder und es geht weiter mit meinen Problemen.
Ich habe eine UR Tabelle in der Datenbank, in der die node access abgelegt sind:
Das sind alles CCK Felder in der Tabelle...
Der Inhaltstyp Hobbys (nid:40 in der Tabelle) hat genau ein CCK Feld field_hobbys, für das folgende UR vergeben sind:
Dabei sind folgende Beziehungen definiert:
Freund:1, Spezial:3, Besucher:5, Niemand:6
Mein Problem:
Ich verstehe nur soviel, was den Inhalt von nid:40 angeht (kann auch falsch liegen):
- es sind 4 Arrays
- a: könnte immer eine Array-Angabe sein
Dann hört es für mich auf, ich konnte leider keinerlei Dokumentation bei UR finden.
Was bedeutet das?
Oder besser: wie kann man die Tabelle auslesen um nur an die node access Werte zu kommen?
Wie kann man überhaupt die UR von Nodes auslesen? (ich meine nicht den Inhalt, sondern den/die UR access für den Node)
Vielen Dank schon mal fürs lesen. :-)
Viele Grüße
CF
- Anmelden oder Registrieren um Kommentare zu schreiben
Hast du schon gecheckt ob im
am 24.09.2010 - 01:55 Uhr
Hast du schon gecheckt ob im NodeObject die UR ausgegeben werden?
Wenn du das Devel Modul installierst kannst du dir die Node laden mit allem drum und dran.
Eigentlich auch die Zugriffsrechte anzeigen lassen...
luzer schrieb Hast du schon
am 24.09.2010 - 08:30 Uhr
Hast du schon gecheckt ob im NodeObject die UR ausgegeben werden?
Wenn du das Devel Modul installierst kannst du dir die Node laden mit allem drum und dran.
Eigentlich auch die Zugriffsrechte anzeigen lassen...
Hallo und guten Morgen luzer,
auch wenn ich mich nun als "Nerd" oute - ich verstehe nicht was du meinst.
Das Devel-Modul ist installiert und aktiviert, nur weis ich nicht wie ich da einen Node laden soll "mit allem drum und dran" und vor allem, was mir das beim Versuch des auslesens und verstehen des inhaltes helfen soll? Ich versteh echt nicht was du mir damit sagen willst. :-(
Selbst wenn ich den Node im Devel geladen bekommen sollte, weis ich noch immer nicht was dieser Inhalt in der Tabelle zu bedeuten hat und auch nicht, wie ich den auszulesen habe, oder zeigt mir das Devel-Modul einen Query für den Zugriff an?
Möglicherweise seh ich auch den Wald vor lauter Bäumen nicht mehr... :-(
Trotzdem vielen Dank für den Versuch zu helfen luzer :-).
Grüßle CF
Ich versuch es nochmal anders
am 24.09.2010 - 09:06 Uhr
Ich versuch es nochmal anders :)
Oder besser: wie kann man die Tabelle auslesen um nur an die node access Werte zu kommen?
Wie kann man überhaupt die UR von Nodes auslesen? (ich meine nicht den Inhalt, sondern den/die UR access für den Node)
Daraus hab ich geschlossen du möchtest die durch UserRelations definierten Zugriffsrechte von Nodes wissen.
Direkt aus der Tabelle sind sie nicht ersichtlich. Deshalb war meine Idee vielleicht speichert UR sie auch im NodeObject. Wenn Devel aktiv ist findest du bei der Node einen Tab "Devel" darunter dann "Dev Laden"
Die Ausgabe zeigt die einzelnen Felder und Zusatzinformationen einer Node.
Zusätzlich gibt es noch das Modul "Devel node access" dieses stellt Blöcke bereit die du aktivieren kannst um nähere Infos über Zugriffsrechte einer Node zu sehen. Ob UR Zugriffsrechte angezeigt werden weiss ich aber nicht.
jetzt versteh ich was du meinst :-)
am 24.09.2010 - 09:29 Uhr
Danke luzer,
das werde ich mal heute Abend ausprobieren.
Wobei es mir ja nicht darum geht, herauszufinden OB ein Node UR hat - die Tabelle mit den Berechtigungen ist ja eindeutig identifiziert.
Ändere ich die Auswahl aus dem ersten Bild, ändert sich der Wert für nid:40 - ich kann also mit absoluter Sicherheit sagen, das es diese Tabelle ist, in der alle Access Rights der User für meine Node abgelegt sind.
Mein Problem ist ja, ich weis das es UR Zugriffsbeschränkungen gibt, DAS muss ich nicht ermitteln - ich muss ermitteln WELCHE UR es für den Node gibt und muss dazu die Werte für den Node laden - eben aus dieser Tabelle oder sonst irgendwie.
Noch mal anders formuliert:
Es muss doch möglich sein für jeden Node X seine UR Werte zu laden, wegen mir direkt aus der angegebenen Tabelle.
Jetzt weis ich nicht wie es noch anders formuliert werden kann.
luzer, ich melde mich auf jeden Fall dann noch mal - mal sehen ob mir der Blick ins Devel noch was an Erkenntnissen bringt.
Hab nochmals vielen Dank!
Grüßle CF
Soweit schon sehr hilfreich, aber etwas fehlt noch.
am 24.09.2010 - 18:46 Uhr
Hallo luzer und die liebe Drupal-Gemeinde,
also ich bin schon etwas weiter, habe dabei was neues gelernt und dafür schon mal meinen Dank! ;-)
Der Devel-Link ist echt hilfreich!
Ich habe mal eben einen Teil kopiert, von dem was mir zu Hobbys (erstes Bild, nid:40, alle Haken gesetzt) ausgegeben wird:
nid (String, 2 characters ) 40
type (String, 6 characters ) hobbys
language (String, 2 characters ) de
uid (String, 1 characters ) 5
...
user_relationship_node_access (Array, 4 elements)
5 (Array, 1 element)
view (Boolean) TRUE
1 (Array, 1 element)
view (Boolean) TRUE
6 (Array, 1 element)
view (Boolean) TRUE
3 (Array, 1 element)
view (Boolean) TRUE
...
Und siehe da, die UR zu dem Node sind dort gespeichert, du hattest also schon mal Recht.
Und weiterhin, man versteht was die Daten aussagen sollen - nochmals hattest du Recht.
Die große Frage ist nun noch immer, wie ich die Daten mit PHP von dem Node auslesen, jetzt wo wir ja wissen das sie da sind :-).
Versuch mal folgendes: <?php
am 25.09.2010 - 06:29 Uhr
Versuch mal folgendes:
<?php
$test = unserialize(db_result(db_query('SELECT permissions FROM dp_user_relationship_node_access WHERE nid = 40')));
print_r ($test);
?>
Sammelzwerg schrieb Versuch
am 25.09.2010 - 09:53 Uhr
Versuch mal folgendes:
<?php
$test = unserialize(db_result(db_query('SELECT permissions FROM dp_user_relationship_node_access WHERE nid = 40')));
print_r ($test);
?>
Hey vielen Dank (!)Sammelzwerg,
des funktioniert schon mal, da bekomme ich
Array()
ausgegeben.
Hast du vielleicht auch noch einen Tipp, wie an den nid dynamisch rankomme?
In meinem Panel bekomme ich mit deiner gezeigten Abfrage den nid von jeden Benutzer - bis auf einen, den mit ID 1.
Es geht voran... :-)
Habs! Vielen Dank an luzer und Sammelzwerg!
am 25.09.2010 - 12:55 Uhr
Habs endlich hinbekommen, vielen Dank noch mal an euch beide - war eine schwere Geburt mit mir ;-).
Es tut in meinem Panel genau so wie ich es brauche:
- einzelne Elemente im Profil wie z.B. Hobbys oder die Interessen können dyn. von den Benutzern für Freunde oder andere in der Sichtbarkeit geregelt werden
- meine Panels prüfen die Beziehungen zwischen dem User und dem betrachteten User und ziehen die UR für den jeweiligen Node heran
- Panel zeigt nur an was zu den Beziehungen passt
Muss jetzt nur noch herausfinden, ob man eine PHP Funktion schreiben kann, welche in einem Panel als Sichtbarkeitsregel aufgerufen werden kann.
Falls nicht, muss ich eben das Stück Code in jedes Panel kopieren.
Nachtrag:
Habs mit dem PHP-Code und der Erweiterung des Funktionsumfanges von Drupal hinbekommen. :-)
Nur noch als Ergänzung: Du
am 27.09.2010 - 15:29 Uhr
Nur noch als Ergänzung:
Du kannst die Werte einer node mittels node_load() auslesen und dann entsprechend der Struktur z.B. mit
$val = $node->field_xyz[0][value]
darauf zugreifen...