Is there a multi-user webdav server available for linux?












9














I'm looking to completely decommission my SMBA service and replace it with a WebDav service.



All the google searches so far have pointed me to using Apache / Webdav. This is close to what I need but as far as I read it requires Apache to have access to my user's files and worse; if it creates a file the new file will be owned by Apache (not the user). Note that having files with the correct Unix ownership and permissions is a requirement as some users have direct SSH access.



So I'm quite simply looking for a way to either make Apache / Webdav work "correctly" with multi-users (that is change unix user to the logged in user before attempting to serve the file) or find a complete alternative to Apache / Webdav.



So far searches haven't turned anything up.










share|improve this question
























  • As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
    – Kiwy
    Apr 3 '14 at 18:50










  • It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
    – couling
    Apr 7 '14 at 11:09












  • There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
    – Jan
    Aug 21 '14 at 7:58










  • @jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
    – couling
    Aug 25 '14 at 22:37






  • 1




    Should be moved to Software Recommendations.SE.
    – William Edwards
    Oct 18 '14 at 19:55
















9














I'm looking to completely decommission my SMBA service and replace it with a WebDav service.



All the google searches so far have pointed me to using Apache / Webdav. This is close to what I need but as far as I read it requires Apache to have access to my user's files and worse; if it creates a file the new file will be owned by Apache (not the user). Note that having files with the correct Unix ownership and permissions is a requirement as some users have direct SSH access.



So I'm quite simply looking for a way to either make Apache / Webdav work "correctly" with multi-users (that is change unix user to the logged in user before attempting to serve the file) or find a complete alternative to Apache / Webdav.



So far searches haven't turned anything up.










share|improve this question
























  • As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
    – Kiwy
    Apr 3 '14 at 18:50










  • It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
    – couling
    Apr 7 '14 at 11:09












  • There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
    – Jan
    Aug 21 '14 at 7:58










  • @jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
    – couling
    Aug 25 '14 at 22:37






  • 1




    Should be moved to Software Recommendations.SE.
    – William Edwards
    Oct 18 '14 at 19:55














9












9








9


1





I'm looking to completely decommission my SMBA service and replace it with a WebDav service.



All the google searches so far have pointed me to using Apache / Webdav. This is close to what I need but as far as I read it requires Apache to have access to my user's files and worse; if it creates a file the new file will be owned by Apache (not the user). Note that having files with the correct Unix ownership and permissions is a requirement as some users have direct SSH access.



So I'm quite simply looking for a way to either make Apache / Webdav work "correctly" with multi-users (that is change unix user to the logged in user before attempting to serve the file) or find a complete alternative to Apache / Webdav.



So far searches haven't turned anything up.










share|improve this question















I'm looking to completely decommission my SMBA service and replace it with a WebDav service.



All the google searches so far have pointed me to using Apache / Webdav. This is close to what I need but as far as I read it requires Apache to have access to my user's files and worse; if it creates a file the new file will be owned by Apache (not the user). Note that having files with the correct Unix ownership and permissions is a requirement as some users have direct SSH access.



So I'm quite simply looking for a way to either make Apache / Webdav work "correctly" with multi-users (that is change unix user to the logged in user before attempting to serve the file) or find a complete alternative to Apache / Webdav.



So far searches haven't turned anything up.







multiuser webdav






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited May 31 '16 at 9:06

























asked Apr 3 '14 at 18:05









couling

263210




263210












  • As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
    – Kiwy
    Apr 3 '14 at 18:50










  • It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
    – couling
    Apr 7 '14 at 11:09












  • There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
    – Jan
    Aug 21 '14 at 7:58










  • @jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
    – couling
    Aug 25 '14 at 22:37






  • 1




    Should be moved to Software Recommendations.SE.
    – William Edwards
    Oct 18 '14 at 19:55


















  • As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
    – Kiwy
    Apr 3 '14 at 18:50










  • It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
    – couling
    Apr 7 '14 at 11:09












  • There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
    – Jan
    Aug 21 '14 at 7:58










  • @jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
    – couling
    Aug 25 '14 at 22:37






  • 1




    Should be moved to Software Recommendations.SE.
    – William Edwards
    Oct 18 '14 at 19:55
















As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
– Kiwy
Apr 3 '14 at 18:50




As webdav is based on the HTTP protocol, I would say it's not existing except under the form of an HTTP server. And if you find product that offer webdav trhey will usually offer more than that
– Kiwy
Apr 3 '14 at 18:50












It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
– couling
Apr 7 '14 at 11:09






It looks like there may be something promising in the latest version of MPM ITK. mpm-itk.sesse.net I'll have a try with this and see if AssignUserIDExpr will accept the logged in user. It may not since AssignUserID appears to kick in before the user authenticates.
– couling
Apr 7 '14 at 11:09














There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
– Jan
Aug 21 '14 at 7:58




There are standalone webdav servers like code.google.com/p/opendav or libraries like PyWebDAV that don't require apache.
– Jan
Aug 21 '14 at 7:58












@jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
– couling
Aug 25 '14 at 22:37




@jan That may turn out to to be the best answer. Apache is running on the server already and webdav should be a subdirectory on the site but I can set that up as a proxy pass through and use Apache's SSL to provide the encryption.
– couling
Aug 25 '14 at 22:37




1




1




Should be moved to Software Recommendations.SE.
– William Edwards
Oct 18 '14 at 19:55




Should be moved to Software Recommendations.SE.
– William Edwards
Oct 18 '14 at 19:55










7 Answers
7






active

oldest

votes


















1














This may be worth to read:
Another input: multiple user folders and one shared folder
http://hexeract.wordpress.com/2011/02/25/configure-a-webdav-enabled-webserver-for-multiple-user-folders-and-one-shared-folder/






share|improve this answer





















  • This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
    – couling
    Oct 20 '14 at 10:49



















1














If you have the username and/or the uid, you can do this with nginx + lua + luarocks ljsyscall



On a debian system, configured as:



apt-get -y install nginx libnginx-mod-http-dav-ext libnginx-mod-http-lua luarocks
luarocks install ljsyscall


And nginx configured the following way:



user  root;
worker_processes 1;

load_module modules/ngx_http_dav_ext_module.so;
load_module modules/ndk_http_module.so;
load_module modules/ngx_http_lua_module.so;

error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;


events {
worker_connections 1024;
}


http {
sendfile on;
keepalive_timeout 65;
gzip on;

server {
listen 80;
listen [::]:80;

location / {
rewrite ^ http://$host$request_uri?; # permanent;
}
}

server {
listen 443 ssl http2;
listen [::]:443 ssl http2;

ssl on;
# [ SSL Sections Omitted ]

# Set the maximum size of uploads
client_max_body_size 200m;

# Default is 60, May need to be increased for very large uploads
client_body_timeout 120s;

# other configs
location /webdav/ {
autoindex on;
alias /data/www/;
client_body_temp_path /data/client_temp;

dav_methods PUT DELETE MKCOL COPY MOVE;
dav_ext_methods PROPFIND OPTIONS;

create_full_put_path on;
# Not sure if you want to tweak this
# dav_access group:rw all:r;

# Let's assume you have an auth subrequest that can set X-UID
auth_request /auth
auth_request_set $auth_status $upstream_status;
auth_request_set $saved_remote_user $upstream_http_REMOTE_USER;
auth_request_set $saved_remote_uid $upstream_http_X_UID;

# Per-Request Impersonation
access_by_lua_block {
# Boilerplate because ljsyscall doesn't have setfsuid implemented directly
local syscall_api = require 'syscall'
local ffi = require "ffi"
local nr = require("syscall.linux.nr")
local sys = nr.SYS
local uint = ffi.typeof("unsigned int")
local syscall_long = ffi.C.syscall -- returns long
local function syscall(...) return tonumber(syscall_long(...)) end
local function setfsuid(id) return syscall(sys.setfsuid, uint(id)) end
-- If you only have ngx.var.saved_remote_user, install luaposix and do this ...
-- local pwd = require 'posix.pwd'
-- local new_uid = pwd.getpwnam(ngx.saved_remote_user).pw_uid
local new_uid = tonumber(ngx.var.saved_remote_uid)
ngx.log(ngx.NOTICE, "[Impersonating User #" .. new_uid .. "]")
local previous = setfsuid(new_uid)
local actual = setfsuid(new_uid)
if actual ~= new_uid then
ngx.log(ngx.CRIT, "Unable to impersonate users")
ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)
end
}
}

location = /auth {
internal;
proxy_pass http://localhost:8080/auth;
proxy_pass_request_body off;
proxy_set_header Content-Length "";
proxy_set_header X-Original-URI $request_uri;
proxy_set_header X-Original-Method $request_method;
}
}
}


This will execute setfsuid on every request serviced by the nginx worker. Unfortunately, it seems you must be running nginx as root in order for this to work right currently. I believe it's possible for this to work with a different user provided the process started as root, dropped to a different user, with CAP_SETUID preserved (see documentation for capsh), and the user directive is absent in the nginx config file.



You may also need to set the group IDs, potentially.



See "Effect of user ID changes on capabilities" in http://man7.org/linux/man-pages/man7/capabilities.7.html






share|improve this answer























  • That looks promising. I'll check it out.
    – couling
    Dec 19 '18 at 10:07



















0














I used this one as guide to set up webdav:
http://bernaerts.dyndns.org/linux/75-debian/62-debian-webdav-share



yes, Apache is the group (www-data under Debian) but you can add users to that group, so I added one user. Did not test why you may not add other users....
The webdav server using in principle this setup runs now for 3 yrs at my and my sons place (so 2 identical servers for the work of my son). Debian 6 is since some months the LTS version (till Feb-2016).



Compared to Bernaerts I adapted in the Apache file:
/etc/apache2/sites-available/default this part of configuration.



Alias /webdav1 /data/webdav1

<Location /webdav1>
DAV on
Authtype Basic
Authname "webdav1"
AuthUserFile /var/www/web1/passwd1.dav
Require valid-user
</location>


So my files are no longer under www but in /data/webdav1 (through alias webdav1 to keep it short)
For each hard disk I've created such a section and webdav1 becomes webdav2 for the 2nd hard disk in that section. We can build in max 10 hard disks in these servers, so 10 of these section in that config file. I added the user to www-data, davfs2 and davfs, so that the user can have access the webdav folder(s). So the user need to login and will be asked for the username and password.
In fstab all the webdav data disks are listed so that mounting proceeds automaticallly.
That part of fstab:




/dev/sda3 /data/webdav1 ext3, user,auto 0 0







share|improve this answer













We're looking for long answers that provide some explanation and context. Don't just give a one-line answer; explain why your answer is right, ideally with citations. Answers that don't include explanations may be removed.














  • Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
    – couling
    Oct 20 '14 at 10:45



















0














Have you tried OwnCloud? Still just testing it myself, but it sounds like it fills your requirements: webdav works out-of-the-box.






share|improve this answer





















  • Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
    – couling
    May 31 '16 at 9:04



















0














Having searched for a long time I just couldn't find one. There are many multi user servers but I couldn't find one which executed as the system user.



So I wrote one myself. This is only tested as far as I can test it myself. But for what its worth, the source code is here:



https://github.com/couling/WebDAV-Daemon






share|improve this answer































    0














    Hy,



    I was looking for same thing and I finally gathered a solution using apache2.
    I tried node solution using npm webdav-server and found out not all worked as nicely then using the apache module.
    Then I tried a npm dav-server based on jsDAV that could do better and could be a solution, but as I had to deal with lousy 3g connection I preferred apache and found out about multiple instance scripts.



    So here I share my experience.



    http://helpcenter.epages.com/Doc/doc/apache2/README.multiple-instances



    I run an instance per webdav user... not very scalable, but to work in a small team it's good enough.



    Replace myUser with your user.



    On Ubuntu 14.04



    sh /usr/share/doc/apache2/examples/setup-instance myUser


    So I run a apache process as user myUser defined in /etc/apache2-myUser/envars



    export APACHE_RUN_USER=myUser
    export APACHE_RUN_GROUP=myUser


    Edit ports.conf



    # If you proxy with nginx as I did better to limit to local interface
    listen localhost:8080
    # listen 8080


    I could not get PAM auth on ubuntu 14.04 to work so need to trick with basic auth as I then wrap it in https with nginx



    htpasswd -c /etc/apache2/htpasswd myUser


    Then /etc/apache2-myUser/sites-available/000-default.conf



    <VirtualHost *:8080>

    DocumentRoot /var/www/html

    Alias /${APACHE_RUN_USER} /home/${APACHE_RUN_USER}
    <Directory /home/${APACHE_RUN_USER}>
    Require all granted
    Options +Indexes
    </Directory>

    <Location /${APACHE_RUN_USER}>
    DAV On
    AuthType Basic
    AuthName "Restricted Area"
    AuthUserFile /etc/apache2/htpasswd
    Require valid-user
    </Location>

    DavLockDB /home/${APACHE_RUN_USER}/.DavLock
    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined
    </VirtualHost>


    then nginx proxy has a trick with header Destination
    passing icons folder lets webdav downgrade nicely on browsers



    server {
    listen 443 ssl http2;
    server_name exemple.com;

    location ~ ^/(myUser|icons)/ {

    proxy_pass http://dav-myUser;

    # auth_basic "Restricted Content";
    # auth_basic_user_file /etc/nginx/htpasswd;

    # proxy_set_header Authorization $http_authorization;

    proxy_pass_header Authorization;
    proxy_pass_request_headers on;

    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-Host $http_host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-Proto $scheme;

    port_in_redirect off;

    # to avoid 502 Bad Gateway:
    # http://vanderwijk.info/Members/ivo/articles/ComplexSVNSetupFix
    set $destination $http_destination;

    if ($destination ~* ^https(.+)$) {
    set $destination http$1;
    }

    proxy_set_header Destination $destination;

    proxy_read_timeout 300;
    proxy_connect_timeout 5;

    # Default is HTTP/1, keepalive is only enabled in HTTP/1.1
    proxy_http_version 1.1;

    # Remove the Connection header if the client sends it,
    # it could be "close" to close a keepalive connection
    proxy_set_header Connection "";
    }

    ssl on;
    ssl_certificate /etc/letsencrypt/live/exemple.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/exemple.com/privkey.pem;

    include /etc/letsencrypt/options-ssl-nginx.conf;

    }


    There is no obligation to use nginx as proxy, apache could very well do the https, but as I bumped into the proxy Destination issue I felt it was worth mentioning it.






    share|improve this answer































      -1














      I'm also looking for a similar solution.



      Solution 1:
      Your desktop environment (Gnome, KDE) might have widgets to expose a certain folder by WebDAV. This will run as long as your desktop environment is running and is not a daemon solution.



      Solution 2:
      Nothing stops you from running Apache under your own user binding on unprivileged ports above 1024. Just write a configuration file or copy the ones bundled in your distribution to your $HOME/etc/httpd (just an example), add DAV-related config and run it as your own non-root user like:



      $ httpd -f $HOME/etc/httpd



      Running as your users ensures Apache will create files as you.






      share|improve this answer





















        Your Answer








        StackExchange.ready(function() {
        var channelOptions = {
        tags: "".split(" "),
        id: "106"
        };
        initTagRenderer("".split(" "), "".split(" "), channelOptions);

        StackExchange.using("externalEditor", function() {
        // Have to fire editor after snippets, if snippets enabled
        if (StackExchange.settings.snippets.snippetsEnabled) {
        StackExchange.using("snippets", function() {
        createEditor();
        });
        }
        else {
        createEditor();
        }
        });

        function createEditor() {
        StackExchange.prepareEditor({
        heartbeatType: 'answer',
        autoActivateHeartbeat: false,
        convertImagesToLinks: false,
        noModals: true,
        showLowRepImageUploadWarning: true,
        reputationToPostImages: null,
        bindNavPrevention: true,
        postfix: "",
        imageUploader: {
        brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
        contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
        allowUrls: true
        },
        onDemand: true,
        discardSelector: ".discard-answer"
        ,immediatelyShowMarkdownHelp:true
        });


        }
        });














        draft saved

        draft discarded


















        StackExchange.ready(
        function () {
        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f123001%2fis-there-a-multi-user-webdav-server-available-for-linux%23new-answer', 'question_page');
        }
        );

        Post as a guest















        Required, but never shown

























        7 Answers
        7






        active

        oldest

        votes








        7 Answers
        7






        active

        oldest

        votes









        active

        oldest

        votes






        active

        oldest

        votes









        1














        This may be worth to read:
        Another input: multiple user folders and one shared folder
        http://hexeract.wordpress.com/2011/02/25/configure-a-webdav-enabled-webserver-for-multiple-user-folders-and-one-shared-folder/






        share|improve this answer





















        • This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
          – couling
          Oct 20 '14 at 10:49
















        1














        This may be worth to read:
        Another input: multiple user folders and one shared folder
        http://hexeract.wordpress.com/2011/02/25/configure-a-webdav-enabled-webserver-for-multiple-user-folders-and-one-shared-folder/






        share|improve this answer





















        • This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
          – couling
          Oct 20 '14 at 10:49














        1












        1








        1






        This may be worth to read:
        Another input: multiple user folders and one shared folder
        http://hexeract.wordpress.com/2011/02/25/configure-a-webdav-enabled-webserver-for-multiple-user-folders-and-one-shared-folder/






        share|improve this answer












        This may be worth to read:
        Another input: multiple user folders and one shared folder
        http://hexeract.wordpress.com/2011/02/25/configure-a-webdav-enabled-webserver-for-multiple-user-folders-and-one-shared-folder/







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Oct 19 '14 at 15:15









        Andre

        393




        393












        • This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
          – couling
          Oct 20 '14 at 10:49


















        • This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
          – couling
          Oct 20 '14 at 10:49
















        This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
        – couling
        Oct 20 '14 at 10:49




        This has the same problem as your other answer. Some users have ssh access. The files MUST be given correct (their own, not the web server's) unix file permissions and ownership (both user and group).
        – couling
        Oct 20 '14 at 10:49













        1














        If you have the username and/or the uid, you can do this with nginx + lua + luarocks ljsyscall



        On a debian system, configured as:



        apt-get -y install nginx libnginx-mod-http-dav-ext libnginx-mod-http-lua luarocks
        luarocks install ljsyscall


        And nginx configured the following way:



        user  root;
        worker_processes 1;

        load_module modules/ngx_http_dav_ext_module.so;
        load_module modules/ndk_http_module.so;
        load_module modules/ngx_http_lua_module.so;

        error_log /var/log/nginx/error.log warn;
        pid /var/run/nginx.pid;


        events {
        worker_connections 1024;
        }


        http {
        sendfile on;
        keepalive_timeout 65;
        gzip on;

        server {
        listen 80;
        listen [::]:80;

        location / {
        rewrite ^ http://$host$request_uri?; # permanent;
        }
        }

        server {
        listen 443 ssl http2;
        listen [::]:443 ssl http2;

        ssl on;
        # [ SSL Sections Omitted ]

        # Set the maximum size of uploads
        client_max_body_size 200m;

        # Default is 60, May need to be increased for very large uploads
        client_body_timeout 120s;

        # other configs
        location /webdav/ {
        autoindex on;
        alias /data/www/;
        client_body_temp_path /data/client_temp;

        dav_methods PUT DELETE MKCOL COPY MOVE;
        dav_ext_methods PROPFIND OPTIONS;

        create_full_put_path on;
        # Not sure if you want to tweak this
        # dav_access group:rw all:r;

        # Let's assume you have an auth subrequest that can set X-UID
        auth_request /auth
        auth_request_set $auth_status $upstream_status;
        auth_request_set $saved_remote_user $upstream_http_REMOTE_USER;
        auth_request_set $saved_remote_uid $upstream_http_X_UID;

        # Per-Request Impersonation
        access_by_lua_block {
        # Boilerplate because ljsyscall doesn't have setfsuid implemented directly
        local syscall_api = require 'syscall'
        local ffi = require "ffi"
        local nr = require("syscall.linux.nr")
        local sys = nr.SYS
        local uint = ffi.typeof("unsigned int")
        local syscall_long = ffi.C.syscall -- returns long
        local function syscall(...) return tonumber(syscall_long(...)) end
        local function setfsuid(id) return syscall(sys.setfsuid, uint(id)) end
        -- If you only have ngx.var.saved_remote_user, install luaposix and do this ...
        -- local pwd = require 'posix.pwd'
        -- local new_uid = pwd.getpwnam(ngx.saved_remote_user).pw_uid
        local new_uid = tonumber(ngx.var.saved_remote_uid)
        ngx.log(ngx.NOTICE, "[Impersonating User #" .. new_uid .. "]")
        local previous = setfsuid(new_uid)
        local actual = setfsuid(new_uid)
        if actual ~= new_uid then
        ngx.log(ngx.CRIT, "Unable to impersonate users")
        ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)
        end
        }
        }

        location = /auth {
        internal;
        proxy_pass http://localhost:8080/auth;
        proxy_pass_request_body off;
        proxy_set_header Content-Length "";
        proxy_set_header X-Original-URI $request_uri;
        proxy_set_header X-Original-Method $request_method;
        }
        }
        }


        This will execute setfsuid on every request serviced by the nginx worker. Unfortunately, it seems you must be running nginx as root in order for this to work right currently. I believe it's possible for this to work with a different user provided the process started as root, dropped to a different user, with CAP_SETUID preserved (see documentation for capsh), and the user directive is absent in the nginx config file.



        You may also need to set the group IDs, potentially.



        See "Effect of user ID changes on capabilities" in http://man7.org/linux/man-pages/man7/capabilities.7.html






        share|improve this answer























        • That looks promising. I'll check it out.
          – couling
          Dec 19 '18 at 10:07
















        1














        If you have the username and/or the uid, you can do this with nginx + lua + luarocks ljsyscall



        On a debian system, configured as:



        apt-get -y install nginx libnginx-mod-http-dav-ext libnginx-mod-http-lua luarocks
        luarocks install ljsyscall


        And nginx configured the following way:



        user  root;
        worker_processes 1;

        load_module modules/ngx_http_dav_ext_module.so;
        load_module modules/ndk_http_module.so;
        load_module modules/ngx_http_lua_module.so;

        error_log /var/log/nginx/error.log warn;
        pid /var/run/nginx.pid;


        events {
        worker_connections 1024;
        }


        http {
        sendfile on;
        keepalive_timeout 65;
        gzip on;

        server {
        listen 80;
        listen [::]:80;

        location / {
        rewrite ^ http://$host$request_uri?; # permanent;
        }
        }

        server {
        listen 443 ssl http2;
        listen [::]:443 ssl http2;

        ssl on;
        # [ SSL Sections Omitted ]

        # Set the maximum size of uploads
        client_max_body_size 200m;

        # Default is 60, May need to be increased for very large uploads
        client_body_timeout 120s;

        # other configs
        location /webdav/ {
        autoindex on;
        alias /data/www/;
        client_body_temp_path /data/client_temp;

        dav_methods PUT DELETE MKCOL COPY MOVE;
        dav_ext_methods PROPFIND OPTIONS;

        create_full_put_path on;
        # Not sure if you want to tweak this
        # dav_access group:rw all:r;

        # Let's assume you have an auth subrequest that can set X-UID
        auth_request /auth
        auth_request_set $auth_status $upstream_status;
        auth_request_set $saved_remote_user $upstream_http_REMOTE_USER;
        auth_request_set $saved_remote_uid $upstream_http_X_UID;

        # Per-Request Impersonation
        access_by_lua_block {
        # Boilerplate because ljsyscall doesn't have setfsuid implemented directly
        local syscall_api = require 'syscall'
        local ffi = require "ffi"
        local nr = require("syscall.linux.nr")
        local sys = nr.SYS
        local uint = ffi.typeof("unsigned int")
        local syscall_long = ffi.C.syscall -- returns long
        local function syscall(...) return tonumber(syscall_long(...)) end
        local function setfsuid(id) return syscall(sys.setfsuid, uint(id)) end
        -- If you only have ngx.var.saved_remote_user, install luaposix and do this ...
        -- local pwd = require 'posix.pwd'
        -- local new_uid = pwd.getpwnam(ngx.saved_remote_user).pw_uid
        local new_uid = tonumber(ngx.var.saved_remote_uid)
        ngx.log(ngx.NOTICE, "[Impersonating User #" .. new_uid .. "]")
        local previous = setfsuid(new_uid)
        local actual = setfsuid(new_uid)
        if actual ~= new_uid then
        ngx.log(ngx.CRIT, "Unable to impersonate users")
        ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)
        end
        }
        }

        location = /auth {
        internal;
        proxy_pass http://localhost:8080/auth;
        proxy_pass_request_body off;
        proxy_set_header Content-Length "";
        proxy_set_header X-Original-URI $request_uri;
        proxy_set_header X-Original-Method $request_method;
        }
        }
        }


        This will execute setfsuid on every request serviced by the nginx worker. Unfortunately, it seems you must be running nginx as root in order for this to work right currently. I believe it's possible for this to work with a different user provided the process started as root, dropped to a different user, with CAP_SETUID preserved (see documentation for capsh), and the user directive is absent in the nginx config file.



        You may also need to set the group IDs, potentially.



        See "Effect of user ID changes on capabilities" in http://man7.org/linux/man-pages/man7/capabilities.7.html






        share|improve this answer























        • That looks promising. I'll check it out.
          – couling
          Dec 19 '18 at 10:07














        1












        1








        1






        If you have the username and/or the uid, you can do this with nginx + lua + luarocks ljsyscall



        On a debian system, configured as:



        apt-get -y install nginx libnginx-mod-http-dav-ext libnginx-mod-http-lua luarocks
        luarocks install ljsyscall


        And nginx configured the following way:



        user  root;
        worker_processes 1;

        load_module modules/ngx_http_dav_ext_module.so;
        load_module modules/ndk_http_module.so;
        load_module modules/ngx_http_lua_module.so;

        error_log /var/log/nginx/error.log warn;
        pid /var/run/nginx.pid;


        events {
        worker_connections 1024;
        }


        http {
        sendfile on;
        keepalive_timeout 65;
        gzip on;

        server {
        listen 80;
        listen [::]:80;

        location / {
        rewrite ^ http://$host$request_uri?; # permanent;
        }
        }

        server {
        listen 443 ssl http2;
        listen [::]:443 ssl http2;

        ssl on;
        # [ SSL Sections Omitted ]

        # Set the maximum size of uploads
        client_max_body_size 200m;

        # Default is 60, May need to be increased for very large uploads
        client_body_timeout 120s;

        # other configs
        location /webdav/ {
        autoindex on;
        alias /data/www/;
        client_body_temp_path /data/client_temp;

        dav_methods PUT DELETE MKCOL COPY MOVE;
        dav_ext_methods PROPFIND OPTIONS;

        create_full_put_path on;
        # Not sure if you want to tweak this
        # dav_access group:rw all:r;

        # Let's assume you have an auth subrequest that can set X-UID
        auth_request /auth
        auth_request_set $auth_status $upstream_status;
        auth_request_set $saved_remote_user $upstream_http_REMOTE_USER;
        auth_request_set $saved_remote_uid $upstream_http_X_UID;

        # Per-Request Impersonation
        access_by_lua_block {
        # Boilerplate because ljsyscall doesn't have setfsuid implemented directly
        local syscall_api = require 'syscall'
        local ffi = require "ffi"
        local nr = require("syscall.linux.nr")
        local sys = nr.SYS
        local uint = ffi.typeof("unsigned int")
        local syscall_long = ffi.C.syscall -- returns long
        local function syscall(...) return tonumber(syscall_long(...)) end
        local function setfsuid(id) return syscall(sys.setfsuid, uint(id)) end
        -- If you only have ngx.var.saved_remote_user, install luaposix and do this ...
        -- local pwd = require 'posix.pwd'
        -- local new_uid = pwd.getpwnam(ngx.saved_remote_user).pw_uid
        local new_uid = tonumber(ngx.var.saved_remote_uid)
        ngx.log(ngx.NOTICE, "[Impersonating User #" .. new_uid .. "]")
        local previous = setfsuid(new_uid)
        local actual = setfsuid(new_uid)
        if actual ~= new_uid then
        ngx.log(ngx.CRIT, "Unable to impersonate users")
        ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)
        end
        }
        }

        location = /auth {
        internal;
        proxy_pass http://localhost:8080/auth;
        proxy_pass_request_body off;
        proxy_set_header Content-Length "";
        proxy_set_header X-Original-URI $request_uri;
        proxy_set_header X-Original-Method $request_method;
        }
        }
        }


        This will execute setfsuid on every request serviced by the nginx worker. Unfortunately, it seems you must be running nginx as root in order for this to work right currently. I believe it's possible for this to work with a different user provided the process started as root, dropped to a different user, with CAP_SETUID preserved (see documentation for capsh), and the user directive is absent in the nginx config file.



        You may also need to set the group IDs, potentially.



        See "Effect of user ID changes on capabilities" in http://man7.org/linux/man-pages/man7/capabilities.7.html






        share|improve this answer














        If you have the username and/or the uid, you can do this with nginx + lua + luarocks ljsyscall



        On a debian system, configured as:



        apt-get -y install nginx libnginx-mod-http-dav-ext libnginx-mod-http-lua luarocks
        luarocks install ljsyscall


        And nginx configured the following way:



        user  root;
        worker_processes 1;

        load_module modules/ngx_http_dav_ext_module.so;
        load_module modules/ndk_http_module.so;
        load_module modules/ngx_http_lua_module.so;

        error_log /var/log/nginx/error.log warn;
        pid /var/run/nginx.pid;


        events {
        worker_connections 1024;
        }


        http {
        sendfile on;
        keepalive_timeout 65;
        gzip on;

        server {
        listen 80;
        listen [::]:80;

        location / {
        rewrite ^ http://$host$request_uri?; # permanent;
        }
        }

        server {
        listen 443 ssl http2;
        listen [::]:443 ssl http2;

        ssl on;
        # [ SSL Sections Omitted ]

        # Set the maximum size of uploads
        client_max_body_size 200m;

        # Default is 60, May need to be increased for very large uploads
        client_body_timeout 120s;

        # other configs
        location /webdav/ {
        autoindex on;
        alias /data/www/;
        client_body_temp_path /data/client_temp;

        dav_methods PUT DELETE MKCOL COPY MOVE;
        dav_ext_methods PROPFIND OPTIONS;

        create_full_put_path on;
        # Not sure if you want to tweak this
        # dav_access group:rw all:r;

        # Let's assume you have an auth subrequest that can set X-UID
        auth_request /auth
        auth_request_set $auth_status $upstream_status;
        auth_request_set $saved_remote_user $upstream_http_REMOTE_USER;
        auth_request_set $saved_remote_uid $upstream_http_X_UID;

        # Per-Request Impersonation
        access_by_lua_block {
        # Boilerplate because ljsyscall doesn't have setfsuid implemented directly
        local syscall_api = require 'syscall'
        local ffi = require "ffi"
        local nr = require("syscall.linux.nr")
        local sys = nr.SYS
        local uint = ffi.typeof("unsigned int")
        local syscall_long = ffi.C.syscall -- returns long
        local function syscall(...) return tonumber(syscall_long(...)) end
        local function setfsuid(id) return syscall(sys.setfsuid, uint(id)) end
        -- If you only have ngx.var.saved_remote_user, install luaposix and do this ...
        -- local pwd = require 'posix.pwd'
        -- local new_uid = pwd.getpwnam(ngx.saved_remote_user).pw_uid
        local new_uid = tonumber(ngx.var.saved_remote_uid)
        ngx.log(ngx.NOTICE, "[Impersonating User #" .. new_uid .. "]")
        local previous = setfsuid(new_uid)
        local actual = setfsuid(new_uid)
        if actual ~= new_uid then
        ngx.log(ngx.CRIT, "Unable to impersonate users")
        ngx.exit(ngx.HTTP_INTERNAL_SERVER_ERROR)
        end
        }
        }

        location = /auth {
        internal;
        proxy_pass http://localhost:8080/auth;
        proxy_pass_request_body off;
        proxy_set_header Content-Length "";
        proxy_set_header X-Original-URI $request_uri;
        proxy_set_header X-Original-Method $request_method;
        }
        }
        }


        This will execute setfsuid on every request serviced by the nginx worker. Unfortunately, it seems you must be running nginx as root in order for this to work right currently. I believe it's possible for this to work with a different user provided the process started as root, dropped to a different user, with CAP_SETUID preserved (see documentation for capsh), and the user directive is absent in the nginx config file.



        You may also need to set the group IDs, potentially.



        See "Effect of user ID changes on capabilities" in http://man7.org/linux/man-pages/man7/capabilities.7.html







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Dec 18 '18 at 21:27

























        answered Dec 18 '18 at 18:51









        Brian

        1112




        1112












        • That looks promising. I'll check it out.
          – couling
          Dec 19 '18 at 10:07


















        • That looks promising. I'll check it out.
          – couling
          Dec 19 '18 at 10:07
















        That looks promising. I'll check it out.
        – couling
        Dec 19 '18 at 10:07




        That looks promising. I'll check it out.
        – couling
        Dec 19 '18 at 10:07











        0














        I used this one as guide to set up webdav:
        http://bernaerts.dyndns.org/linux/75-debian/62-debian-webdav-share



        yes, Apache is the group (www-data under Debian) but you can add users to that group, so I added one user. Did not test why you may not add other users....
        The webdav server using in principle this setup runs now for 3 yrs at my and my sons place (so 2 identical servers for the work of my son). Debian 6 is since some months the LTS version (till Feb-2016).



        Compared to Bernaerts I adapted in the Apache file:
        /etc/apache2/sites-available/default this part of configuration.



        Alias /webdav1 /data/webdav1

        <Location /webdav1>
        DAV on
        Authtype Basic
        Authname "webdav1"
        AuthUserFile /var/www/web1/passwd1.dav
        Require valid-user
        </location>


        So my files are no longer under www but in /data/webdav1 (through alias webdav1 to keep it short)
        For each hard disk I've created such a section and webdav1 becomes webdav2 for the 2nd hard disk in that section. We can build in max 10 hard disks in these servers, so 10 of these section in that config file. I added the user to www-data, davfs2 and davfs, so that the user can have access the webdav folder(s). So the user need to login and will be asked for the username and password.
        In fstab all the webdav data disks are listed so that mounting proceeds automaticallly.
        That part of fstab:




        /dev/sda3 /data/webdav1 ext3, user,auto 0 0







        share|improve this answer













        We're looking for long answers that provide some explanation and context. Don't just give a one-line answer; explain why your answer is right, ideally with citations. Answers that don't include explanations may be removed.














        • Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
          – couling
          Oct 20 '14 at 10:45
















        0














        I used this one as guide to set up webdav:
        http://bernaerts.dyndns.org/linux/75-debian/62-debian-webdav-share



        yes, Apache is the group (www-data under Debian) but you can add users to that group, so I added one user. Did not test why you may not add other users....
        The webdav server using in principle this setup runs now for 3 yrs at my and my sons place (so 2 identical servers for the work of my son). Debian 6 is since some months the LTS version (till Feb-2016).



        Compared to Bernaerts I adapted in the Apache file:
        /etc/apache2/sites-available/default this part of configuration.



        Alias /webdav1 /data/webdav1

        <Location /webdav1>
        DAV on
        Authtype Basic
        Authname "webdav1"
        AuthUserFile /var/www/web1/passwd1.dav
        Require valid-user
        </location>


        So my files are no longer under www but in /data/webdav1 (through alias webdav1 to keep it short)
        For each hard disk I've created such a section and webdav1 becomes webdav2 for the 2nd hard disk in that section. We can build in max 10 hard disks in these servers, so 10 of these section in that config file. I added the user to www-data, davfs2 and davfs, so that the user can have access the webdav folder(s). So the user need to login and will be asked for the username and password.
        In fstab all the webdav data disks are listed so that mounting proceeds automaticallly.
        That part of fstab:




        /dev/sda3 /data/webdav1 ext3, user,auto 0 0







        share|improve this answer













        We're looking for long answers that provide some explanation and context. Don't just give a one-line answer; explain why your answer is right, ideally with citations. Answers that don't include explanations may be removed.














        • Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
          – couling
          Oct 20 '14 at 10:45














        0












        0








        0






        I used this one as guide to set up webdav:
        http://bernaerts.dyndns.org/linux/75-debian/62-debian-webdav-share



        yes, Apache is the group (www-data under Debian) but you can add users to that group, so I added one user. Did not test why you may not add other users....
        The webdav server using in principle this setup runs now for 3 yrs at my and my sons place (so 2 identical servers for the work of my son). Debian 6 is since some months the LTS version (till Feb-2016).



        Compared to Bernaerts I adapted in the Apache file:
        /etc/apache2/sites-available/default this part of configuration.



        Alias /webdav1 /data/webdav1

        <Location /webdav1>
        DAV on
        Authtype Basic
        Authname "webdav1"
        AuthUserFile /var/www/web1/passwd1.dav
        Require valid-user
        </location>


        So my files are no longer under www but in /data/webdav1 (through alias webdav1 to keep it short)
        For each hard disk I've created such a section and webdav1 becomes webdav2 for the 2nd hard disk in that section. We can build in max 10 hard disks in these servers, so 10 of these section in that config file. I added the user to www-data, davfs2 and davfs, so that the user can have access the webdav folder(s). So the user need to login and will be asked for the username and password.
        In fstab all the webdav data disks are listed so that mounting proceeds automaticallly.
        That part of fstab:




        /dev/sda3 /data/webdav1 ext3, user,auto 0 0







        share|improve this answer














        I used this one as guide to set up webdav:
        http://bernaerts.dyndns.org/linux/75-debian/62-debian-webdav-share



        yes, Apache is the group (www-data under Debian) but you can add users to that group, so I added one user. Did not test why you may not add other users....
        The webdav server using in principle this setup runs now for 3 yrs at my and my sons place (so 2 identical servers for the work of my son). Debian 6 is since some months the LTS version (till Feb-2016).



        Compared to Bernaerts I adapted in the Apache file:
        /etc/apache2/sites-available/default this part of configuration.



        Alias /webdav1 /data/webdav1

        <Location /webdav1>
        DAV on
        Authtype Basic
        Authname "webdav1"
        AuthUserFile /var/www/web1/passwd1.dav
        Require valid-user
        </location>


        So my files are no longer under www but in /data/webdav1 (through alias webdav1 to keep it short)
        For each hard disk I've created such a section and webdav1 becomes webdav2 for the 2nd hard disk in that section. We can build in max 10 hard disks in these servers, so 10 of these section in that config file. I added the user to www-data, davfs2 and davfs, so that the user can have access the webdav folder(s). So the user need to login and will be asked for the username and password.
        In fstab all the webdav data disks are listed so that mounting proceeds automaticallly.
        That part of fstab:




        /dev/sda3 /data/webdav1 ext3, user,auto 0 0








        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Oct 19 '14 at 17:16

























        answered Oct 18 '14 at 19:51









        Andre

        393




        393



        We're looking for long answers that provide some explanation and context. Don't just give a one-line answer; explain why your answer is right, ideally with citations. Answers that don't include explanations may be removed.




        We're looking for long answers that provide some explanation and context. Don't just give a one-line answer; explain why your answer is right, ideally with citations. Answers that don't include explanations may be removed.













        • Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
          – couling
          Oct 20 '14 at 10:45


















        • Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
          – couling
          Oct 20 '14 at 10:45
















        Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
        – couling
        Oct 20 '14 at 10:45




        Sadly this doesn't solve the problem at all. The focus of this question was multi user. With this solution new files will be created as the apache user not the logged in user. In order to function apache all files must be www-data group with read / write permissions to that group. Since every user will have to be in that group every user will have to have access to read / write every other user's files. This solution simply doesn't wok for multiple users.
        – couling
        Oct 20 '14 at 10:45











        0














        Have you tried OwnCloud? Still just testing it myself, but it sounds like it fills your requirements: webdav works out-of-the-box.






        share|improve this answer





















        • Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
          – couling
          May 31 '16 at 9:04
















        0














        Have you tried OwnCloud? Still just testing it myself, but it sounds like it fills your requirements: webdav works out-of-the-box.






        share|improve this answer





















        • Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
          – couling
          May 31 '16 at 9:04














        0












        0








        0






        Have you tried OwnCloud? Still just testing it myself, but it sounds like it fills your requirements: webdav works out-of-the-box.






        share|improve this answer












        Have you tried OwnCloud? Still just testing it myself, but it sounds like it fills your requirements: webdav works out-of-the-box.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered May 30 '16 at 14:31









        Ryder

        27618




        27618












        • Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
          – couling
          May 31 '16 at 9:04


















        • Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
          – couling
          May 31 '16 at 9:04
















        Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
        – couling
        May 31 '16 at 9:04




        Yes I have an instance of Owncloud but thats not what I'm looking for because the owncloud user (apache) owns all the files.
        – couling
        May 31 '16 at 9:04











        0














        Having searched for a long time I just couldn't find one. There are many multi user servers but I couldn't find one which executed as the system user.



        So I wrote one myself. This is only tested as far as I can test it myself. But for what its worth, the source code is here:



        https://github.com/couling/WebDAV-Daemon






        share|improve this answer




























          0














          Having searched for a long time I just couldn't find one. There are many multi user servers but I couldn't find one which executed as the system user.



          So I wrote one myself. This is only tested as far as I can test it myself. But for what its worth, the source code is here:



          https://github.com/couling/WebDAV-Daemon






          share|improve this answer


























            0












            0








            0






            Having searched for a long time I just couldn't find one. There are many multi user servers but I couldn't find one which executed as the system user.



            So I wrote one myself. This is only tested as far as I can test it myself. But for what its worth, the source code is here:



            https://github.com/couling/WebDAV-Daemon






            share|improve this answer














            Having searched for a long time I just couldn't find one. There are many multi user servers but I couldn't find one which executed as the system user.



            So I wrote one myself. This is only tested as far as I can test it myself. But for what its worth, the source code is here:



            https://github.com/couling/WebDAV-Daemon







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Sep 13 '17 at 15:52

























            answered Sep 13 '17 at 15:41









            couling

            263210




            263210























                0














                Hy,



                I was looking for same thing and I finally gathered a solution using apache2.
                I tried node solution using npm webdav-server and found out not all worked as nicely then using the apache module.
                Then I tried a npm dav-server based on jsDAV that could do better and could be a solution, but as I had to deal with lousy 3g connection I preferred apache and found out about multiple instance scripts.



                So here I share my experience.



                http://helpcenter.epages.com/Doc/doc/apache2/README.multiple-instances



                I run an instance per webdav user... not very scalable, but to work in a small team it's good enough.



                Replace myUser with your user.



                On Ubuntu 14.04



                sh /usr/share/doc/apache2/examples/setup-instance myUser


                So I run a apache process as user myUser defined in /etc/apache2-myUser/envars



                export APACHE_RUN_USER=myUser
                export APACHE_RUN_GROUP=myUser


                Edit ports.conf



                # If you proxy with nginx as I did better to limit to local interface
                listen localhost:8080
                # listen 8080


                I could not get PAM auth on ubuntu 14.04 to work so need to trick with basic auth as I then wrap it in https with nginx



                htpasswd -c /etc/apache2/htpasswd myUser


                Then /etc/apache2-myUser/sites-available/000-default.conf



                <VirtualHost *:8080>

                DocumentRoot /var/www/html

                Alias /${APACHE_RUN_USER} /home/${APACHE_RUN_USER}
                <Directory /home/${APACHE_RUN_USER}>
                Require all granted
                Options +Indexes
                </Directory>

                <Location /${APACHE_RUN_USER}>
                DAV On
                AuthType Basic
                AuthName "Restricted Area"
                AuthUserFile /etc/apache2/htpasswd
                Require valid-user
                </Location>

                DavLockDB /home/${APACHE_RUN_USER}/.DavLock
                ErrorLog ${APACHE_LOG_DIR}/error.log
                CustomLog ${APACHE_LOG_DIR}/access.log combined
                </VirtualHost>


                then nginx proxy has a trick with header Destination
                passing icons folder lets webdav downgrade nicely on browsers



                server {
                listen 443 ssl http2;
                server_name exemple.com;

                location ~ ^/(myUser|icons)/ {

                proxy_pass http://dav-myUser;

                # auth_basic "Restricted Content";
                # auth_basic_user_file /etc/nginx/htpasswd;

                # proxy_set_header Authorization $http_authorization;

                proxy_pass_header Authorization;
                proxy_pass_request_headers on;

                proxy_set_header Host $host;
                proxy_set_header X-Forwarded-Host $http_host;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-Proto $scheme;

                port_in_redirect off;

                # to avoid 502 Bad Gateway:
                # http://vanderwijk.info/Members/ivo/articles/ComplexSVNSetupFix
                set $destination $http_destination;

                if ($destination ~* ^https(.+)$) {
                set $destination http$1;
                }

                proxy_set_header Destination $destination;

                proxy_read_timeout 300;
                proxy_connect_timeout 5;

                # Default is HTTP/1, keepalive is only enabled in HTTP/1.1
                proxy_http_version 1.1;

                # Remove the Connection header if the client sends it,
                # it could be "close" to close a keepalive connection
                proxy_set_header Connection "";
                }

                ssl on;
                ssl_certificate /etc/letsencrypt/live/exemple.com/fullchain.pem;
                ssl_certificate_key /etc/letsencrypt/live/exemple.com/privkey.pem;

                include /etc/letsencrypt/options-ssl-nginx.conf;

                }


                There is no obligation to use nginx as proxy, apache could very well do the https, but as I bumped into the proxy Destination issue I felt it was worth mentioning it.






                share|improve this answer




























                  0














                  Hy,



                  I was looking for same thing and I finally gathered a solution using apache2.
                  I tried node solution using npm webdav-server and found out not all worked as nicely then using the apache module.
                  Then I tried a npm dav-server based on jsDAV that could do better and could be a solution, but as I had to deal with lousy 3g connection I preferred apache and found out about multiple instance scripts.



                  So here I share my experience.



                  http://helpcenter.epages.com/Doc/doc/apache2/README.multiple-instances



                  I run an instance per webdav user... not very scalable, but to work in a small team it's good enough.



                  Replace myUser with your user.



                  On Ubuntu 14.04



                  sh /usr/share/doc/apache2/examples/setup-instance myUser


                  So I run a apache process as user myUser defined in /etc/apache2-myUser/envars



                  export APACHE_RUN_USER=myUser
                  export APACHE_RUN_GROUP=myUser


                  Edit ports.conf



                  # If you proxy with nginx as I did better to limit to local interface
                  listen localhost:8080
                  # listen 8080


                  I could not get PAM auth on ubuntu 14.04 to work so need to trick with basic auth as I then wrap it in https with nginx



                  htpasswd -c /etc/apache2/htpasswd myUser


                  Then /etc/apache2-myUser/sites-available/000-default.conf



                  <VirtualHost *:8080>

                  DocumentRoot /var/www/html

                  Alias /${APACHE_RUN_USER} /home/${APACHE_RUN_USER}
                  <Directory /home/${APACHE_RUN_USER}>
                  Require all granted
                  Options +Indexes
                  </Directory>

                  <Location /${APACHE_RUN_USER}>
                  DAV On
                  AuthType Basic
                  AuthName "Restricted Area"
                  AuthUserFile /etc/apache2/htpasswd
                  Require valid-user
                  </Location>

                  DavLockDB /home/${APACHE_RUN_USER}/.DavLock
                  ErrorLog ${APACHE_LOG_DIR}/error.log
                  CustomLog ${APACHE_LOG_DIR}/access.log combined
                  </VirtualHost>


                  then nginx proxy has a trick with header Destination
                  passing icons folder lets webdav downgrade nicely on browsers



                  server {
                  listen 443 ssl http2;
                  server_name exemple.com;

                  location ~ ^/(myUser|icons)/ {

                  proxy_pass http://dav-myUser;

                  # auth_basic "Restricted Content";
                  # auth_basic_user_file /etc/nginx/htpasswd;

                  # proxy_set_header Authorization $http_authorization;

                  proxy_pass_header Authorization;
                  proxy_pass_request_headers on;

                  proxy_set_header Host $host;
                  proxy_set_header X-Forwarded-Host $http_host;
                  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                  proxy_set_header X-Real-IP $remote_addr;
                  proxy_set_header X-Forwarded-Proto $scheme;

                  port_in_redirect off;

                  # to avoid 502 Bad Gateway:
                  # http://vanderwijk.info/Members/ivo/articles/ComplexSVNSetupFix
                  set $destination $http_destination;

                  if ($destination ~* ^https(.+)$) {
                  set $destination http$1;
                  }

                  proxy_set_header Destination $destination;

                  proxy_read_timeout 300;
                  proxy_connect_timeout 5;

                  # Default is HTTP/1, keepalive is only enabled in HTTP/1.1
                  proxy_http_version 1.1;

                  # Remove the Connection header if the client sends it,
                  # it could be "close" to close a keepalive connection
                  proxy_set_header Connection "";
                  }

                  ssl on;
                  ssl_certificate /etc/letsencrypt/live/exemple.com/fullchain.pem;
                  ssl_certificate_key /etc/letsencrypt/live/exemple.com/privkey.pem;

                  include /etc/letsencrypt/options-ssl-nginx.conf;

                  }


                  There is no obligation to use nginx as proxy, apache could very well do the https, but as I bumped into the proxy Destination issue I felt it was worth mentioning it.






                  share|improve this answer


























                    0












                    0








                    0






                    Hy,



                    I was looking for same thing and I finally gathered a solution using apache2.
                    I tried node solution using npm webdav-server and found out not all worked as nicely then using the apache module.
                    Then I tried a npm dav-server based on jsDAV that could do better and could be a solution, but as I had to deal with lousy 3g connection I preferred apache and found out about multiple instance scripts.



                    So here I share my experience.



                    http://helpcenter.epages.com/Doc/doc/apache2/README.multiple-instances



                    I run an instance per webdav user... not very scalable, but to work in a small team it's good enough.



                    Replace myUser with your user.



                    On Ubuntu 14.04



                    sh /usr/share/doc/apache2/examples/setup-instance myUser


                    So I run a apache process as user myUser defined in /etc/apache2-myUser/envars



                    export APACHE_RUN_USER=myUser
                    export APACHE_RUN_GROUP=myUser


                    Edit ports.conf



                    # If you proxy with nginx as I did better to limit to local interface
                    listen localhost:8080
                    # listen 8080


                    I could not get PAM auth on ubuntu 14.04 to work so need to trick with basic auth as I then wrap it in https with nginx



                    htpasswd -c /etc/apache2/htpasswd myUser


                    Then /etc/apache2-myUser/sites-available/000-default.conf



                    <VirtualHost *:8080>

                    DocumentRoot /var/www/html

                    Alias /${APACHE_RUN_USER} /home/${APACHE_RUN_USER}
                    <Directory /home/${APACHE_RUN_USER}>
                    Require all granted
                    Options +Indexes
                    </Directory>

                    <Location /${APACHE_RUN_USER}>
                    DAV On
                    AuthType Basic
                    AuthName "Restricted Area"
                    AuthUserFile /etc/apache2/htpasswd
                    Require valid-user
                    </Location>

                    DavLockDB /home/${APACHE_RUN_USER}/.DavLock
                    ErrorLog ${APACHE_LOG_DIR}/error.log
                    CustomLog ${APACHE_LOG_DIR}/access.log combined
                    </VirtualHost>


                    then nginx proxy has a trick with header Destination
                    passing icons folder lets webdav downgrade nicely on browsers



                    server {
                    listen 443 ssl http2;
                    server_name exemple.com;

                    location ~ ^/(myUser|icons)/ {

                    proxy_pass http://dav-myUser;

                    # auth_basic "Restricted Content";
                    # auth_basic_user_file /etc/nginx/htpasswd;

                    # proxy_set_header Authorization $http_authorization;

                    proxy_pass_header Authorization;
                    proxy_pass_request_headers on;

                    proxy_set_header Host $host;
                    proxy_set_header X-Forwarded-Host $http_host;
                    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                    proxy_set_header X-Real-IP $remote_addr;
                    proxy_set_header X-Forwarded-Proto $scheme;

                    port_in_redirect off;

                    # to avoid 502 Bad Gateway:
                    # http://vanderwijk.info/Members/ivo/articles/ComplexSVNSetupFix
                    set $destination $http_destination;

                    if ($destination ~* ^https(.+)$) {
                    set $destination http$1;
                    }

                    proxy_set_header Destination $destination;

                    proxy_read_timeout 300;
                    proxy_connect_timeout 5;

                    # Default is HTTP/1, keepalive is only enabled in HTTP/1.1
                    proxy_http_version 1.1;

                    # Remove the Connection header if the client sends it,
                    # it could be "close" to close a keepalive connection
                    proxy_set_header Connection "";
                    }

                    ssl on;
                    ssl_certificate /etc/letsencrypt/live/exemple.com/fullchain.pem;
                    ssl_certificate_key /etc/letsencrypt/live/exemple.com/privkey.pem;

                    include /etc/letsencrypt/options-ssl-nginx.conf;

                    }


                    There is no obligation to use nginx as proxy, apache could very well do the https, but as I bumped into the proxy Destination issue I felt it was worth mentioning it.






                    share|improve this answer














                    Hy,



                    I was looking for same thing and I finally gathered a solution using apache2.
                    I tried node solution using npm webdav-server and found out not all worked as nicely then using the apache module.
                    Then I tried a npm dav-server based on jsDAV that could do better and could be a solution, but as I had to deal with lousy 3g connection I preferred apache and found out about multiple instance scripts.



                    So here I share my experience.



                    http://helpcenter.epages.com/Doc/doc/apache2/README.multiple-instances



                    I run an instance per webdav user... not very scalable, but to work in a small team it's good enough.



                    Replace myUser with your user.



                    On Ubuntu 14.04



                    sh /usr/share/doc/apache2/examples/setup-instance myUser


                    So I run a apache process as user myUser defined in /etc/apache2-myUser/envars



                    export APACHE_RUN_USER=myUser
                    export APACHE_RUN_GROUP=myUser


                    Edit ports.conf



                    # If you proxy with nginx as I did better to limit to local interface
                    listen localhost:8080
                    # listen 8080


                    I could not get PAM auth on ubuntu 14.04 to work so need to trick with basic auth as I then wrap it in https with nginx



                    htpasswd -c /etc/apache2/htpasswd myUser


                    Then /etc/apache2-myUser/sites-available/000-default.conf



                    <VirtualHost *:8080>

                    DocumentRoot /var/www/html

                    Alias /${APACHE_RUN_USER} /home/${APACHE_RUN_USER}
                    <Directory /home/${APACHE_RUN_USER}>
                    Require all granted
                    Options +Indexes
                    </Directory>

                    <Location /${APACHE_RUN_USER}>
                    DAV On
                    AuthType Basic
                    AuthName "Restricted Area"
                    AuthUserFile /etc/apache2/htpasswd
                    Require valid-user
                    </Location>

                    DavLockDB /home/${APACHE_RUN_USER}/.DavLock
                    ErrorLog ${APACHE_LOG_DIR}/error.log
                    CustomLog ${APACHE_LOG_DIR}/access.log combined
                    </VirtualHost>


                    then nginx proxy has a trick with header Destination
                    passing icons folder lets webdav downgrade nicely on browsers



                    server {
                    listen 443 ssl http2;
                    server_name exemple.com;

                    location ~ ^/(myUser|icons)/ {

                    proxy_pass http://dav-myUser;

                    # auth_basic "Restricted Content";
                    # auth_basic_user_file /etc/nginx/htpasswd;

                    # proxy_set_header Authorization $http_authorization;

                    proxy_pass_header Authorization;
                    proxy_pass_request_headers on;

                    proxy_set_header Host $host;
                    proxy_set_header X-Forwarded-Host $http_host;
                    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                    proxy_set_header X-Real-IP $remote_addr;
                    proxy_set_header X-Forwarded-Proto $scheme;

                    port_in_redirect off;

                    # to avoid 502 Bad Gateway:
                    # http://vanderwijk.info/Members/ivo/articles/ComplexSVNSetupFix
                    set $destination $http_destination;

                    if ($destination ~* ^https(.+)$) {
                    set $destination http$1;
                    }

                    proxy_set_header Destination $destination;

                    proxy_read_timeout 300;
                    proxy_connect_timeout 5;

                    # Default is HTTP/1, keepalive is only enabled in HTTP/1.1
                    proxy_http_version 1.1;

                    # Remove the Connection header if the client sends it,
                    # it could be "close" to close a keepalive connection
                    proxy_set_header Connection "";
                    }

                    ssl on;
                    ssl_certificate /etc/letsencrypt/live/exemple.com/fullchain.pem;
                    ssl_certificate_key /etc/letsencrypt/live/exemple.com/privkey.pem;

                    include /etc/letsencrypt/options-ssl-nginx.conf;

                    }


                    There is no obligation to use nginx as proxy, apache could very well do the https, but as I bumped into the proxy Destination issue I felt it was worth mentioning it.







                    share|improve this answer














                    share|improve this answer



                    share|improve this answer








                    edited Sep 7 '18 at 23:23









                    Rui F Ribeiro

                    39k1479129




                    39k1479129










                    answered Apr 10 '18 at 6:38









                    Antony Gibbs

                    1014




                    1014























                        -1














                        I'm also looking for a similar solution.



                        Solution 1:
                        Your desktop environment (Gnome, KDE) might have widgets to expose a certain folder by WebDAV. This will run as long as your desktop environment is running and is not a daemon solution.



                        Solution 2:
                        Nothing stops you from running Apache under your own user binding on unprivileged ports above 1024. Just write a configuration file or copy the ones bundled in your distribution to your $HOME/etc/httpd (just an example), add DAV-related config and run it as your own non-root user like:



                        $ httpd -f $HOME/etc/httpd



                        Running as your users ensures Apache will create files as you.






                        share|improve this answer


























                          -1














                          I'm also looking for a similar solution.



                          Solution 1:
                          Your desktop environment (Gnome, KDE) might have widgets to expose a certain folder by WebDAV. This will run as long as your desktop environment is running and is not a daemon solution.



                          Solution 2:
                          Nothing stops you from running Apache under your own user binding on unprivileged ports above 1024. Just write a configuration file or copy the ones bundled in your distribution to your $HOME/etc/httpd (just an example), add DAV-related config and run it as your own non-root user like:



                          $ httpd -f $HOME/etc/httpd



                          Running as your users ensures Apache will create files as you.






                          share|improve this answer
























                            -1












                            -1








                            -1






                            I'm also looking for a similar solution.



                            Solution 1:
                            Your desktop environment (Gnome, KDE) might have widgets to expose a certain folder by WebDAV. This will run as long as your desktop environment is running and is not a daemon solution.



                            Solution 2:
                            Nothing stops you from running Apache under your own user binding on unprivileged ports above 1024. Just write a configuration file or copy the ones bundled in your distribution to your $HOME/etc/httpd (just an example), add DAV-related config and run it as your own non-root user like:



                            $ httpd -f $HOME/etc/httpd



                            Running as your users ensures Apache will create files as you.






                            share|improve this answer












                            I'm also looking for a similar solution.



                            Solution 1:
                            Your desktop environment (Gnome, KDE) might have widgets to expose a certain folder by WebDAV. This will run as long as your desktop environment is running and is not a daemon solution.



                            Solution 2:
                            Nothing stops you from running Apache under your own user binding on unprivileged ports above 1024. Just write a configuration file or copy the ones bundled in your distribution to your $HOME/etc/httpd (just an example), add DAV-related config and run it as your own non-root user like:



                            $ httpd -f $HOME/etc/httpd



                            Running as your users ensures Apache will create files as you.







                            share|improve this answer












                            share|improve this answer



                            share|improve this answer










                            answered Sep 12 '17 at 21:40









                            avibrazil

                            1




                            1






























                                draft saved

                                draft discarded




















































                                Thanks for contributing an answer to Unix & Linux Stack Exchange!


                                • Please be sure to answer the question. Provide details and share your research!

                                But avoid



                                • Asking for help, clarification, or responding to other answers.

                                • Making statements based on opinion; back them up with references or personal experience.


                                To learn more, see our tips on writing great answers.





                                Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                                Please pay close attention to the following guidance:


                                • Please be sure to answer the question. Provide details and share your research!

                                But avoid



                                • Asking for help, clarification, or responding to other answers.

                                • Making statements based on opinion; back them up with references or personal experience.


                                To learn more, see our tips on writing great answers.




                                draft saved


                                draft discarded














                                StackExchange.ready(
                                function () {
                                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f123001%2fis-there-a-multi-user-webdav-server-available-for-linux%23new-answer', 'question_page');
                                }
                                );

                                Post as a guest















                                Required, but never shown





















































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown

































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown







                                Popular posts from this blog

                                Morgemoulin

                                Scott Moir

                                Souastre