Dotazy > Programování

Problém s pravý

(1/1)

Le_Ze:
Zdravím Vás.
Proč toto jede jen přes sudo?

--- Kód: ---<?php
exec("stty -F /dev/ttyAMA0 9600 -parenb cs8 -cstopb ");
$fp = fopen('/dev/ttyAMA0','r+');
fwrite($fp, "hups");
fclose($fp);
?>
--- Konec kódu ---

JInak.

--- Citace ---stty: /dev/ttyAMA0: Operace zamítnuta
PHP Warning:  fopen(/dev/ttyAMA0): failed to open stream: Permission denied in /var/www/ser1.php on line 3
PHP Warning:  fwrite() expects parameter 1 to be resource, boolean given in /var/www/ser1.php on line 4
PHP Warning:  fclose() expects parameter 1 to be resource, boolean given in /var/www/ser1.php on line 5
--- Konce citace ---

Je to na raspi.
pi i  www-data jsou ve skupině tty
A  toto přes web i terminal jede bez sudo.
system ('echo hups> /dev/ttyAMA0');




Petr Gajdůšek:
https://raspberrypi.stackexchange.com/questions/48211/set-permission-for-dev-ttyama0-on-boot#48258

Le_Ze:
To asi ne, když to přes terminal funguje
echo hups> /dev/ttyAMA0

I přes PHP


--- Kód: ---<?php
system ('echo hups> /dev/ttyAMA0');
?>
--- Konec kódu ---

Tak jinak.
sudo stty -F /dev/ttyAMA0 9600
Bez sudo to vyhodí Permission denied.
Přes sudo ok.
Jak zjistím, ve ktere skupině musí být pi, aby mohl přistupovat k stty bez sudo?

Petr Gajdůšek:
Ahoj,

Ty se v tom PHP pokoušíš otevřít /dev/ttyAMA0 pro zápis a čtení
--- Kód: (php) ---fopen('/dev/ttyAMA0','r+');
--- Konec kódu ---
Ale protože je používáno jako sériová console (terminál), je na něm spuštěno getty, a tedy k němu má přístup jen skupina tty, a to jen pro zápis.


--- Kód: (bash) ---$ ls -l /dev/ttyAMA0
crw--w---- 1 root tty 204, 64 Jun  1 21:10 /dev/ttyAMA0

--- Konec kódu ---

Proto ti pod Apachem funguje např.
--- Kód: (php) ---system ('echo hups> /dev/ttyAMA0');
--- Konec kódu ---
když je Apache (uživatel www-data) ve skupině tty.

Podívej se do /proc/cmdline a uvidíš tam něco jako console=ttyAMA0,115200. Systemd potom na tomhle portu pustí getty a to nastaví zařízení  /dev/ttyAMA0  práva jako consoli (terminálu). Do terminálu smí zapisovat jen skupina tty, ale nesmí z něho číst. Zápis je nutný např. pokud chceš poslat zprávu na všechny terminály, můžeš použít /usr/bin/wall, který je vlastněn skupinou tty a má nastaven SETGID bit.

Ten odkaz ti měl napovědět. Jen tam místo řešení příčiny - /dev/ttyAMA0 se používá jako sériová console - ji obchází tím, že zakážou systemd unitu serial-getty@.service, která na zařízení /dev/ttyAMA0  spustí getty.

man 8 systemd-getty-generator

Odstraň z /boot/cmdline.txt text console=ttyAMA0,115200 a rebootuj.

Nyní už nebude /dev/ttyAMA0 používán jako console (nepoběží na něm getty), ale bude dostupný jako seriový port, ke kterému budou mít přístup uživatelé ve skupině dialout, pro čtení i zápis.


--- Kód: (bash) ---$ ls -l /dev/ttyAMA0
crw-rw---- 1 root dialout 204, 64 Jun  2 11:29 /dev/ttyAMA0

--- Konec kódu ---

Dej apache (uživatele www-data) do skupiny dialout; odstraň ho ze skupiny tty a restartuj.

Viz. https://wiki.debian.org/SystemGroups

Le_Ze:

Navigace

[0] Seznam témat

Přejít na plnou verzi