PDA

Archiv verlassen und diese Seite im Standarddesign anzeigen : Proftpd-mysql + apache2 Rechte Problem in /var/www



DirtyRodriguez
22.09.11, 21:20
hallo ich bin zur zeit echt am verzweifeln.
Ich möchte gerne das Proftpd die Uploads in /var/www speichert und nicht in /home jedes mal verliert apache dabei aber seine rechte auf den Ordner www.

Ich füge jetzt mal hier einfach alles ein was ich denke das von Bedeutung ist

id ftpuser


uid=1005(ftpuser) gid=33(www-data) Gruppen=33(www-data)

/etc/proftpd/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 on
# 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 /var/www/ www-data
# DefaultRoot ~

# 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
# 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 ftpuser
Group www-data


# 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>



Ok ich hoffe das reicht also wen mir jemand dabei helfen könnte den ftpuser dazu zu kriegen in /var/www zu speichern ohne dabei die rechte vom apache User www-data zu löschen wehre das wirklich Wahnsinn :)

muell200
23.09.11, 06:14
hallo

erstmal willkommen auf dem board



# Umask 022 022


versuche mal die rechte mit der option "umask" anzupassen bzw. mit dem sticky-bit

DrunkenFreak
23.09.11, 07:20
War eigentlich auch mein Gedanke, laut der Hilfe aber:


# Umask 022 is a good standard umask to prevent new files and dirs
# (second parm) from being group and world writable.
Umask 022 022

/var/www dürfte aber schon existieren und daher nicht mehr verändert werden.

Ein Workaround könnten ACLs sein.

DirtyRodriguez
29.09.11, 16:55
Ok Leute hab das mit Apache und Proftpd jetzt fast hin bekommen.
Aber auch nur fast :D

Also ich kann jetzt problemlos meine user anlegen und in /var/www
uploaden. Ich kann auch die Dateien in Apache anzeigen lassen
wen ich chmod -R 777 www oder chmod -R 777 * im Verzeichnis ausführe.
Proftpd startet mit dem User ftpuser und der Gruppe ftpgroup.
Apache läuft mit www-data:www-data.
Proftpd ist in der Gruppe www-data und der User www-data ist auch
in der Gruppe ftpgroup (hab ich zum testen jetzt mal gemacht).



id ftpuser
uid=2001(ftpuser) gid=2001(ftpgroup) Gruppen=2001(ftpgroup),33(www-data)



id www-data
uid=33(www-data) gid=33(www-data) Gruppen=33(www-data),2001(ftpgroup)


dann noch das /www ich hab eine User angelegt und mit chmod -R 777 *
seine Dateien schon für Apache lesbar gemacht der User Test kann jetzt in Apache noch nicht angezeigt werden



ls -la
insgesamt 20
drwxrwsrwx 5 www-data www-data 4096 29. Sep 17:36 .
drwxr-xr-x 14 root root 4096 23. Sep 17:45 ..
drwxrwsrwx 2 ftpuser ftpgroup 4096 29. Sep 17:18 dirtyrodriguez
drwx--S--- 2 ftpuser ftpgroup 4096 29. Sep 17:36 test



Wehre echt wahnsinnig geil wen mir jemand sag wie ich den Ordner /www
zwingen kann alle rechte in 777 zu ändern :)
Mit freundlichen Grüßen Rodriguez