proftpd i uprawnienia raz jeszcze

Konfiguracja serwerów, usług, itp.
sekijr
Posty: 2
Rejestracja: 01 lutego 2012, 19:26

proftpd i uprawnienia raz jeszcze

Post autor: sekijr »

Witam,

siedzę nad jednym problem już ponad 12 godzin. Googluję i googluję i nic z tego. Przerobiłem miliard manuali i dochodzę do wniosku, że nie rozumiem nadawania praw do danych katalogów dla użytkowników proftpd.

Zacznę od początku.

Czego chcę?

Mam 4 użytkowników FTP (ftp-mini, ftp-midi, ftp-maxi i ftp-root) i 4 katalogi (sources, data, test, export). W każdym z katalogów będą jakieś uprawnienia dla danego użytkownika. Macierz tychże uprawnień wygląda tak:
[TABLE="class: grid, width: 50%, align: center"]
[TR]
[TD][/TD]
[TD="align: center"]ftp-mini
[/TD]
[TD="align: center"]ftp-midi
[/TD]
[TD="align: center"]ftp-maxi
[/TD]
[TD="align: center"]ftp-root
[/TD]
[/TR]
[TR]
[TD]sources[/TD]
[TD="align: center"]RWX
[/TD]
[TD="align: center"]R-X
[/TD]
[TD="align: center"]R-X
[/TD]
[TD="align: center"]RWX
[/TD]
[/TR]
[TR]
[TD]data[/TD]
[TD="align: center"]---
[/TD]
[TD="align: center"]RWX[/TD]
[TD="align: center"]RWX[/TD]
[TD="align: center"]RWX[/TD]
[/TR]
[TR]
[TD]test[/TD]
[TD="align: center"]---
[/TD]
[TD="align: center"]RWX[/TD]
[TD="align: center"]RWX[/TD]
[TD="align: center"]RWX[/TD]
[/TR]
[TR]
[TD]export[/TD]
[TD="align: center"]---
[/TD]
[TD="align: center"]---
[/TD]
[TD="align: center"]RWX[/TD]
[TD="align: center"]RWX[/TD]
[/TR]
[/TABLE]

Co zrobiłem?

Na czyściutkim Debian Squeeze zainstalowałem sobie apt-get'em proftpd i korzystałem z tego poradnika. Po miliardach testów, które powstrzymały mnie już na pierwszych uprawnieniach mam takie oto coś, które wiem, że już nie działa bo sprawdzałem KAŻDĄ kombinację.

/etc/proftpd/proftpd.conf:

Kod: Zaznacz cały

root@nsxxx:/etc/proftpd# cat proftpd.conf
#
# /etc/proftpd/proftpd.conf -- This is a basic ProFTPD configuration file.
# To really apply changes reload proftpd after modifications.
#

# Includes DSO modules
Include /etc/proftpd/modules.conf

# Set off to disable IPv6 support which is annoying on IPv4 only boxes.
UseIPv6                         off
# If set on you can experience a longer connection delay in many cases.
IdentLookups                    off

ServerName                      "Debian"
ServerType                      standalone
DeferWelcome                    off

MultilineRFC2228                on
DefaultServer                   on
ShowSymlinks                    on

TimeoutNoTransfer               600
TimeoutStalled                  600
TimeoutIdle                     1200

DisplayLogin                    welcome.msg
DisplayChdir                    .message true
ListOptions                     "-l"

DenyFilter                      \*.*/

# Use this to jail all users in their homes
# DefaultRoot                   /home/ftep

# Users require a valid shell listed in /etc/shells to login.
# Use this directive to release that constrain.
 RequireValidShell              off

# Port 21 is the standard FTP port.
Port                            21

# In some cases you have to specify passive ports range to by-pass
# firewall limitations. Ephemeral ports can be used for that, but
# feel free to use a more narrow range.
# PassivePorts                  49152 65534

# If your host was NATted, this option is useful in order to
# allow passive tranfers to work. You have to use your public
# address and opening the passive ports used on your firewall as well.
# MasqueradeAddress             1.2.3.4

# This is useful for masquerading address with dynamic IPs:
# refresh any configured MasqueradeAddress directives every 8 hours
<IfModule mod_dynmasq.c>
# DynMasqRefresh 28800
</IfModule>

# To prevent DoS attacks, set the maximum number of child processes
# to 30.  If you need to allow more than 30 concurrent connections
# at once, simply increase this value.  Note that this ONLY works
# in standalone mode, in inetd mode you should use an inetd server
# that allows you to limit maximum number of processes per service
# (such as xinetd)
MaxInstances                    30

# Set the user and group that the server normally runs at.
User                            proftpd
Group                           nogroup

# Umask 022 is a good standard umask to prevent new files and dirs
# (second parm) from being group and world writable.
Umask                           022  022
# Normally, we want files to be overwriteable.
AllowOverwrite                  on

# Uncomment this if you are using NIS or LDAP via NSS to retrieve passwords:
# PersistentPasswd              off

# This is required to use both PAM-based authentication and local passwords
# AuthOrder                     mod_auth_pam.c* mod_auth_unix.c

# Be warned: use of this directive impacts CPU average load!
# Uncomment this if you like to see progress and transfer rate with ftpwho
# in downloads. That is not needed for uploads rates.
#
# UseSendFile                   off

TransferLog /var/log/proftpd/xferlog
SystemLog   /var/log/proftpd/proftpd.log

<IfModule mod_quotatab.c>
QuotaEngine off
</IfModule>

<IfModule mod_ratio.c>
Ratios off
</IfModule>


# Delay engine reduces impact of the so-called Timing Attack described in
# http://security.lss.hr/index.php?page=details&ID=LSS-2004-10-02
# It is on by default.
<IfModule mod_delay.c>
DelayEngine on
</IfModule>

<IfModule mod_ctrls.c>
ControlsEngine        off
ControlsMaxClients    2
ControlsLog           /var/log/proftpd/controls.log
ControlsInterval      5
ControlsSocket        /var/run/proftpd/proftpd.sock
</IfModule>

<IfModule mod_ctrls_admin.c>
AdminControlsEngine off
</IfModule>

#
# Alternative authentication frameworks
#
#Include /etc/proftpd/ldap.conf
#Include /etc/proftpd/sql.conf

#
# This is used for FTPS connections
#
#Include /etc/proftpd/tls.conf

#
# Useful to keep VirtualHost/VirtualRoot directives separated
#
#Include /etc/proftpd/virtuals.con

# A basic anonymous configuration, no upload directories.

# <Anonymous ~ftp>
#   User                                ftp
#   Group                               nogroup
#   # We want clients to be able to login with "anonymous" as well as "ftp"
#   UserAlias                   anonymous ftp
#   # Cosmetic changes, all files belongs to ftp user
#   DirFakeUser on ftp
#   DirFakeGroup on ftp
#
#   RequireValidShell           off
#
#   # Limit the maximum number of anonymous logins
#   MaxClients                  10
#
#   # We want 'welcome.msg' displayed at login, and '.message' displayed
#   # in each newly chdired directory.
#   DisplayLogin                        welcome.msg
#   DisplayChdir                .message
#
#   # Limit WRITE everywhere in the anonymous chroot
#   <Directory *>
#     <Limit WRITE>
#       DenyAll
#     </Limit>
#   </Directory>
#
#   # Uncomment this if you're brave.
#   # <Directory incoming>
#   #   # Umask 022 is a good standard umask to prevent new files and dirs
#   #   # (second parm) from being group and world writable.
#   #   Umask                           022  022
#   #            <Limit READ WRITE>
#   #            DenyAll
#   #            </Limit>
#   #            <Limit STOR>
#   #            AllowAll
#   #            </Limit>
#   # </Directory>
#
# </Anonymous>
AuthUserFile /etc/proftpd/ftpd.passwd


<Anonymous /home/ftep>
User ftp-mini ftp-midi ftp-maxi ftp-root
Group nogroup
AnonRequirePassword on
HideNoAccess on

<Limit LOGIN>
Order Allow,Deny
AllowUser ftp-mini
AllowUser ftp-midi
AllowUser ftp-maxi
AllowUser ftp-root
DenyAll
</Limit>

<Directory /sources/*>
<Limit MKD DELE RMD>
Order Allow,Deny
AllowUser ftp-mini
AllowUser ftp-root
DenyAll
</Limit>
<Limit LIST>
DenyAll
</Limit>
</Directory>



</Anonymous>
Co otrzymałem?
Pomijając to, że powyższy kod jest na bank zły i jest to już ostatnia forma grzebaniny z moich ostatnich 12 godzin. W ostatnim okresie to już robiłem metodą prób i błędów bo już nie miałem pomysłu.

Generalnie loguję się na przez Total Commandera jako ftp-midi i NIE CHCĘ mieć prawa zapisu do katalogu sources, a mam! Reszty już nie dotykałem bo nie ma sensu skoro zatrzymałem się na starcie.

Czy ktoś mi może pomóc i wlać trochę olej do tej mojej zakutej pały? Powiedzcie mi gdzie robię błąd - ja po prostu już się poddaję i nie rozumiem tej składni mimo iż jest bardzo podobna do virtualhostów Apache'a
Awatar użytkownika
Bastian
Member
Posty: 1424
Rejestracja: 30 marca 2008, 16:09
Lokalizacja: Poznañ

Post autor: Bastian »

Za dokumentacją:
All FTP commands which deal with file or directory write/creation/deletion: APPE, DELE, MKD, RMD, RNTO, STOR, XMKD, XRMD DIRS
Na moje oko brakuje Ci przynajmniej STOR, ale najlepiej dać wszystkie.
sekijr
Posty: 2
Rejestracja: 01 lutego 2012, 19:26

Post autor: sekijr »

Bastian pisze:Za dokumentacją:
...
Na moje oko brakuje Ci przynajmniej STOR, ale najlepiej dać wszystkie.
Dziękuję za odpowiedź - o ile pamiętam to też z tym próbowałem. Czy mógłbym Ciebie prosić jakbyś rozpisał uprawnienia dla katalogu sources dla użytkowników ftp-mini i ftp-midi? Pytam się bo nie wiem jak to rozumieć. Jedne poradniki mówią, żeby tworzyć uprawnienia na zasadzie:

Kod: Zaznacz cały

<directory /sciezka>
limit ALL
allowuser root
/limit

limit READ
allowuser R-X_user
/limit
</directory>
A z kolei inne poradniki wskazują dla każdego użytkownika wypisać po kolei uprawnienia:

Kod: Zaznacz cały

limit STOR MKD DELE RMD itp..
allowuser RWX_user
/limit

limit READ
allowuser R-X_user
/limit
O ile pamiętam z ostatnich moich 12 godzin to próbowałem obie formy i nic z tego nie wyszło - midi dalej może "pisać" w sources. Może to jest problem w konfiguracji gdzieś poza proftpd.conf? Wolałbym właśnie dlatego dostać rozpisane chociaż jeden katalog z dwoma użytkownikami aby załapać jak to działa. Resztę zrobię sam (albo się odezwę)

Dodane:
Mając coś takiego:

Kod: Zaznacz cały

<Anonymous /home/ftep>
User ftp-mini ftp-midi ftp-maxi ftp-root
Group nogroup
AnonRequirePassword on
HideNoAccess on

<Limit LOGIN>
Order Allow,Deny
AllowUser ftp-mini
AllowUser ftp-midi
AllowUser ftp-maxi
AllowUser ftp-root
DenyAll
</Limit>

<Directory /sources>
<Limit STOR WRITE>
Order Deny,Allow
DenyAll
</Limit>
</Directory>
</Anonymous>
Nie powinien mieć prawa zapisu do katalogu /home/ftep/sources nikt - czy źle rozumiem? Tymczasem zapisać może zarówno ftp-mini jak i ftp-midi.
Awatar użytkownika
Bastian
Member
Posty: 1424
Rejestracja: 30 marca 2008, 16:09
Lokalizacja: Poznañ

Post autor: Bastian »

Generalnie Twój konfig, we fragmencie, który prezentujesz wygląda poprawnie. Spróbuj usunąć Order Deny, Allow zamaist <Directory /sources> dać <Directory /home/ftep/sources>, oraz dodać resztę uprawnień, czyli:

Kod: Zaznacz cały

<Anonymous /home/ftep>
User ftp-mini ftp-midi ftp-maxi ftp-root
Group nogroup
AnonRequirePassword on
HideNoAccess on

<Limit LOGIN>
Order Allow,Deny
AllowUser ftp-mini
AllowUser ftp-midi
AllowUser ftp-maxi
AllowUser ftp-root
DenyAll
</Limit>

<Directory home/ftep/sources>
<Limit APPE, DELE, MKD, RMD, RNTO, STOR, XMKD, XRMD DIRS>
DenyAll
</Limit>
</Directory>
</Anonymous>

Najlepiej jakbyś podał cały konfig, bo trochę dziwne, że 2 z 4 użytkowników nadal może zapisywać.
ODPOWIEDZ