User Authentication with IMAP, SMB, and FTP

You may configure additional user backends in ownCloud’s configuration file (config/config.php) using the following syntax:

<?php

"user_backends" => [
    0 => [
        "class"     => ...,
        "arguments" => [
            0 => ...
        ],
    ],
],

Note

A non-blocking or correctly configured SELinux setup is needed for these backends to work, if SELinux is enabled on your server.. Please refer to the SELinux documentation for further details.

Currently the External user support app (user_external), which is not enabled by default, provides three backends. These are:

See Installing and Managing Apps for more information.

IMAP

Provides authentication against IMAP servers.

Option Value/Description
Class OC_User_IMAP.
Arguments A mailbox string as defined in the PHP documentation.
Dependency PHP’s IMAP extension. See Manual Installation on Linux for instructions on how to install it.

Example

<?php

"user_backends" => [
    0 => [
        "class"     => "OC_User_IMAP",
        "arguments" => [
            // The IMAP server to authenticate against
            '{imap.gmail.com:993/imap/ssl}',
            // The domain to send email from
            'example.com'
        ],
    ],
],

Warning

The second arguments parameter ensures that only users from that domain are allowed to login. When set, after a successful login, the domain will be stripped from the email address and the rest used as an ownCloud username. For example, if the email address is guest.user@example.com, then guest.user will be the username used by ownCloud.

SMB

Provides authentication against Samba servers.

Option Value/Description
Class OC_User_SMB.
Arguments The samba server to authenticate against.
Dependency PECL’s smbclient extension or smbclient.

Example

<?php

"user_backends" => [
    0 => [
        "class"     => "OC_User_SMB",
        "arguments" => [
            0 => 'localhost'
        ],
    ],
],

FTP

Provides authentication against FTP servers.

Option Value/Description
Class OC_User_FTP.
Arguments The FTP server to authenticate against.
Dependency PHP’s FTP extension. See Manual Installation on Linux for instructions on how to install it.

Example

<?php

"user_backends" => [
    0 => [
        "class"     => "OC_User_FTP",
        "arguments" => [
            0 => 'localhost'
        ],
    ],
],