Implantando o WebDAV no Debian 10 usando o WsgiDAV

Introdução

O WebDAV (Web Distributed Authoring and Versioning) é uma extensão HTTP que fornece uma estrutura para criar e modificar remotamente arquivos em um servidor. WsgiDAV é um servidor WebDAV escrito em python. Este guia irá ajudá-lo na instalação do WsgiDAV versão 3.0 em um servidor Vultr executando o Debian 10. Também obteremos um certificado SSL para fornecer uma conexão segura e autenticação PAM.

Pré-requisitos

  • Um sistema Debian 10 ao qual você tem acesso privilegiado (através do usuário root ou de qualquer usuário sudo.)
  • A $EDITORvariável de ambiente deve ser configurada para um editor de texto de sua escolha.
  • É necessário um nome de domínio registrado. Seus servidores de nomes devem ser configurados com um Aregistro apontando para o endereço IPv4 do servidor e, opcionalmente, um AAAAregistro apontando para o endereço IPv6.
  • A familiaridade com a sintaxe YAML é recomendada.

O espaço reservado dav.example.comserá usado para o nome de domínio do seu servidor.

Instalação

Certificado SSL

Começaremos atualizando o sistema e obtendo um certificado SSL gratuito do Let's Encrypt . Para fazer isso, primeiro atualize seu sistema e instale o certbotutilitário:

 sudo apt update
 sudo apt upgrade -y
 sudo apt install -y certbot

No comando abaixo, substitua dav.example.come [email protected]pelo seu nome de domínio e endereço de email, respectivamente, antes de executá-lo:

sudo certbot certonly --standalone --agree-tos -m [email protected] -d dav.example.com

Seu servidor receberá um desafio para verificar se você controla o nome de domínio especificado. Se for bem-sucedido, o certificado será emitido e salvo, juntamente com outros arquivos, como a chave privada, em /etc/letsencrypt/live/dav.example.com/.

Instalando o WsgiDAV

Primeiro, instale o gerenciador de pacotes python pip:

sudo apt update
sudo apt install -y python3-pip

O WsgiDAV requer um servidor HTTP que suporte WSGI. Vamos instalar a opção padrão, que é Cheroot. Também instalaremos a biblioteca python lxml, que tende a ter um desempenho melhor que a biblioteca XML instalada por padrão. A biblioteca python3 do PAM (Pluggable Authentication Module) também é necessária. Instale os pacotes necessários usando a pipferramenta:

sudo pip3 install wsgidav cheroot lxml python-pam

Configurando o WsgiDAV

O executável WsgiDAV é armazenado em /usr/local/bin, portanto, colocaremos o arquivo de configuração no /usr/local/etcdiretório Faça o download do arquivo de configuração de amostra com os seguintes comandos:

sudo mkdir -p /usr/local/etc
sudo wget https://github.com/mar10/wsgidav/raw/master/sample_wsgidav.yaml -O /usr/local/etc/wsgidav.yaml

Abra-o com seu editor:

sudo $EDITOR /usr/local/etc/wsgidav.yaml

Encontre as seguintes linhas na seção "Suporte SSL":

# ssl_certificate: "wsgidav/server/sample_bogo_server.crt"
# ssl_private_key: "wsgidav/server/sample_bogo_server.key"
# ssl_certificate_chain: null

Substitua-os pelo seguinte:

ssl_certificate: "/etc/letsencrypt/live/dav.example.com/cert.pem"
ssl_private_key: "/etc/letsencrypt/live/dav.example.com/privkey.pem"
ssl_certificate_chain: "/etc/letsencrypt/live/dav.example.com/chain.pem"

Em seguida, configuraremos os caminhos de compartilhamento mapeando os caminhos HTTP (como /) para os locais correspondentes no sistema de arquivos (como /var/www/dir1). Para fins de demonstração, compartilharemos dois diretórios, um dos quais será somente leitura. Encontre o provider_mappingbloco na seção "AÇÕES":

provider_mapping:
    "/": "/path/to/share1"
    "/pub":
        root: "/path/to/share2"
        readonly: true
    "/share3":
        provider: path.to.CustomDAVProviderClass
        args: ["/path/to/share3", "second_arg"]
        kwargs: {"another_arg": 42}

Substitua-o:

provider_mapping:
    "/":
    root: "/var/www/html/documents"
    readonly: false
"/reports":
    root: "/var/www/html/reports"
    readonly: true

Com esses mapeamentos, https://dav.example.com:8080/corresponderá ao /var/www/html/documentsdiretório no servidor, enquanto https://dav.example.com:8080/reportsmapeará para /var/www/html/reportssem acesso de gravação.

Para autenticação, usaremos o driver PAM. Isso elimina a necessidade de contas de usuário separadas do WebDAV e permite que os usuários do sistema efetuem login usando suas credenciais habituais.

Na seção "AUTENTICAÇÃO", encontre estas linhas:

accept_basic: true
accept_digest: true
default_to_digest: true
domain_controller: null

Substitua-os pelo seguinte:

accept_basic: true
accept_digest: false
default_to_digest: false
domain_controller: wsgidav.dc.pam_dc.PAMDomainController

Agora você pode testar seu servidor:

sudo wsgidav -c /usr/local/etc/wsgidav.yaml

Abra https://dav.example.com:8080/no seu navegador. Como configuramos a autenticação PAM, você precisará fazer login com sua conta de usuário Linux. Use CTRL+ Cpara parar o servidor antes de continuar.

Instalando como um Serviço

Para executar o servidor WebDAV como um serviço do sistema gerenciado pelo systemd, crie um arquivo de unidade:

sudo $EDITOR /etc/systemd/system/wsgidav.service

Digite o seguinte:

[Unit]
Description=WsgiDAV WebDAV server
After=network.target

[Service]
Type=simple
ExecStart=/usr/local/bin/wsgidav -c /usr/local/etc/wsgidav.yaml
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=wsgidav_service

[Install]
WantedBy=multi-user.target

Em seguida, crie um arquivo de configuração para o serviço de log do sistema:

sudo $EDITOR /etc/rsyslog.d/wsgidav_service.conf

Preencha o arquivo com o seguinte:

 if $programname == 'wsgidav_service' then /var/log/wsgidav.log
 & stop

Salve e saia e use os comandos abaixo para criar o arquivo de log:

sudo touch /var/log/wsgidav.log
sudo chown root:adm /var/log/wsgidav.log

Por fim, carregue o novo arquivo da unidade systemd e reinicie o serviço de log antes de iniciar o WsgiDAV:

sudo systemctl daemon-reload
sudo systemctl restart rsyslog.service
sudo systemctl start wsgidav.service

Agora você pode usar systemctlpara iniciar, parar e reiniciar o servidor WebDAV. A saída e o erro padrão do WsgiDAV serão registrados /var/log/wsgidav.loge também podem ser acessados ​​usando sudo journalctl -u wsgidav.service.

Se você deseja que o servidor WebDAV inicie automaticamente no momento da inicialização do sistema, execute:

 sudo systemctl enable wsgidav.service

Leitura adicional



Leave a Comment

Configure sua própria rede privada com o OpenVPN

Configure sua própria rede privada com o OpenVPN

O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Usando um sistema diferente? O Couch CMS é um sistema de gerenciamento de conteúdo (CMS) simples e flexível, gratuito e de código aberto que permite que os web designers

Como usar o Sudo no Debian, CentOS e FreeBSD

Como usar o Sudo no Debian, CentOS e FreeBSD

Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud

Configurando um Chroot no Debian

Configurando um Chroot no Debian

Este artigo ensinará como configurar uma prisão chroot no Debian. Presumo que você esteja usando o Debian 7.x. Se você estiver executando o Debian 6 ou 8, isso pode funcionar, mas

Como instalar o PiVPN no Debian

Como instalar o PiVPN no Debian

Introdução Uma maneira fácil de configurar um servidor VPN no Debian é com o PiVPN. PiVPN é um instalador e wrapper para o OpenVPN. Ele cria comandos simples para você t

Como instalar o Kanboard no Debian 9

Como instalar o Kanboard no Debian 9

Usando um sistema diferente? Introdução O Kanboard é um programa de software de gerenciamento de projetos gratuito e de código aberto, projetado para facilitar e visualizar

Como instalar o Neos CMS no Debian 9

Como instalar o Neos CMS no Debian 9

Usando um sistema diferente? Neos é uma plataforma de aplicativos de conteúdo com um CMS e uma estrutura de aplicativos em seu núcleo. Este guia mostra como instalar

Configurar cactos no Debian Jessie

Configurar cactos no Debian Jessie

Introdução O Cacti é uma ferramenta de monitoramento e gráfico de código aberto totalmente baseada em dados RRD. Através do Cacti, você pode monitorar quase qualquer tipo de dispositivo

Como instalar o Java 8 e o DCEVM no Debian 8 (Jessie)

Como instalar o Java 8 e o DCEVM no Debian 8 (Jessie)

Java é uma linguagem de programação independente de plataforma / máquina virtual. Neste tutorial, instalaremos a implementação OpenJDK do Java 8 em um Debian

Servidor HTTP Git com Nginx no Debian 8

Servidor HTTP Git com Nginx no Debian 8

O Git é um sistema de controle de versão (VCS) que permite o rastreamento de alterações no código. Neste tutorial, mostraremos a instalação de um servidor HTTP (S) Git, um

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL

Usando vistas MySQL no Debian 7

Usando vistas MySQL no Debian 7

Introdução O MySQL possui um ótimo recurso conhecido como views. As visualizações são consultas armazenadas. Pense neles como um alias para uma consulta longa. Neste guia,

Como instalar o Matomo Analytics no Debian 9

Como instalar o Matomo Analytics no Debian 9

Usando um sistema diferente? O Matomo (anteriormente Piwik) é uma plataforma de análise de código aberto, uma alternativa aberta ao Google Analytics. Fonte Matomo está hospedado o

Monitorar o status do servidor Debian com o Munin

Monitorar o status do servidor Debian com o Munin

Munin é uma ferramenta de monitoramento para pesquisar processos e recursos em sua máquina e apresenta as informações em gráficos através de uma interface da web. Use o seguinte

Como instalar o fórum NodeBB no Debian 9

Como instalar o fórum NodeBB no Debian 9

Usando um sistema diferente? O NodeBB é um fórum baseado no Node.js. Ele utiliza soquetes da web para interações instantâneas e notificações em tempo real. Código fonte do NodeBB i

Como configurar o Samba com armazenamento em bloco no Debian 9

Como configurar o Samba com armazenamento em bloco no Debian 9

O Samba é uma solução de código aberto que permite aos usuários configurar compartilhamentos de arquivos e impressão rápidos e seguros. Neste artigo, abordarei como configurar a sagacidade do Samba

Adicionar intervalo de endereços IP ao seu servidor (CentOS / Ubuntu / Debian)

Adicionar intervalo de endereços IP ao seu servidor (CentOS / Ubuntu / Debian)

Introdução Neste tutorial, abordaremos o processo de adicionar um intervalo / sub-rede IP inteiro a um servidor Linux executando o CentOS, Debian ou Ubuntu. O processo

Instale o Plesk no Debian 8 (Jessie)

Instale o Plesk no Debian 8 (Jessie)

Usando um sistema diferente? O Plesk é um painel de controle proprietário de host da web que permite que os usuários administrem seus sites pessoais e / ou clientes, bancos de dados

Como instalar o Koel no Debian 9

Como instalar o Koel no Debian 9

Usando um sistema diferente? O Koel é um aplicativo simples de transmissão de áudio pessoal baseado na Web, escrito em Vue no lado do cliente e Laravel no lado do servidor. Koe

Como implantar o Ghost v0.11 LTS no Debian 8

Como implantar o Ghost v0.11 LTS no Debian 8

Usando um sistema diferente? O Ghost é uma plataforma de blog de código aberto que vem ganhando popularidade entre desenvolvedores e usuários comuns desde a sua 201

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.