Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Allgemeines zu Drupal ›

[Gelöst] User Relationship: Tabelleninhalt unklar, UR access rights von CCK Feldern bzw. Node auslesen

Eingetragen von CodeFlatter (37)
am 23.09.2010 - 22:12 Uhr in
  • Allgemeines zu Drupal
  • Drupal 6.x

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:
User Relations für Hobbys
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:
User Relations für Hobbys

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

‹ [Erledigt] Problem mit Hochkommata (') monthly archiv listet auch neue Blogartikel ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Hast du schon gecheckt ob im

Eingetragen von netzkoop (1820)
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...

  • Anmelden oder Registrieren um Kommentare zu schreiben

luzer schrieb Hast du schon

Eingetragen von CodeFlatter (37)
am 24.09.2010 - 08:30 Uhr
luzer schrieb

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

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich versuch es nochmal anders

Eingetragen von netzkoop (1820)
am 24.09.2010 - 09:06 Uhr

Ich versuch es nochmal anders :)

Zitat:

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.

  • Anmelden oder Registrieren um Kommentare zu schreiben

jetzt versteh ich was du meinst :-)

Eingetragen von CodeFlatter (37)
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

  • Anmelden oder Registrieren um Kommentare zu schreiben

Soweit schon sehr hilfreich, aber etwas fehlt noch.

Eingetragen von CodeFlatter (37)
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 :-).

  • Anmelden oder Registrieren um Kommentare zu schreiben

Versuch mal folgendes: <?php

Eingetragen von Sammelzwerg (377)
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);
?>

  • Anmelden oder Registrieren um Kommentare zu schreiben

Sammelzwerg schrieb Versuch

Eingetragen von CodeFlatter (37)
am 25.09.2010 - 09:53 Uhr
Sammelzwerg schrieb

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... :-)

  • Anmelden oder Registrieren um Kommentare zu schreiben

Habs! Vielen Dank an luzer und Sammelzwerg!

Eingetragen von CodeFlatter (37)
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. :-)

  • Anmelden oder Registrieren um Kommentare zu schreiben

Nur noch als Ergänzung: Du

Eingetragen von netzkoop (1820)
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...

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • wmtbpo361x
  • Rolle erstellen nicht zu finden
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
Weiter

Neue Kommentare

  • Rollen
    vor 5 Tagen 17 Stunden
  • Inzwischen sind wir bei
    vor 2 Wochen 2 Tagen
  • Migrieren von D7 auf D8/ D10/ D11
    vor 2 Wochen 3 Tagen
  • melde mich mal wieder, da ich
    vor 10 Wochen 6 Stunden
  • Hey danke
    vor 10 Wochen 1 Tag
  • Update: jetzt gibt's ein
    vor 10 Wochen 1 Tag
  • Hallo, im Prinzip habe ich
    vor 10 Wochen 6 Tagen
  • Da scheint die Terminologie
    vor 10 Wochen 6 Tagen
  • Kannst doch auch alles direkt
    vor 11 Wochen 3 Tagen
  • In der entsprechenden View
    vor 11 Wochen 3 Tagen

Statistik

Beiträge im Forum: 250239
Registrierte User: 20467

Neue User:

  • LorisBen
  • StevenEness
  • ocvk2810

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 28 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association