Componentes internos do Weblate

Nota

Este capítulo lhe dará uma visão geral básica dos componentes internos do Weblate.

Weblate deriva a maior parte de sua estrutura de código e é baseado no Django.

Estrutura de diretórios

Visão geral rápida da estrutura de diretórios do repositório principal Weblate:

docs

Código-fonte desta documentação, que pode ser construída usando Sphinx.

dev-docker

Código do Docker para executar o servidor de desenvolvimento, consulte Executando Weblate localmente no Docker.

weblate

Código-fonte do Weblate como um aplicativo Django, consulte Componentes internos do Weblate.

weblate/static

Arquivos de cliente (CSS, Javascript e imagens), veja Frontend do Weblate.

Módulos

O Weblate consiste em vários aplicativos Django (alguns opcionais, consulte Módulos opcionais do Weblate):

accounts

Conta de usuário, perfis e notificações.

addons

Complementos para ajustar o comportamento do Weblate, consulte Complementos.

api

API baseada no framework Django REST.

auth

Autenticação e permissões.

billing

O módulo opcional de Cobrança.

checks

Módulo de Verificações de qualidade de texto de tradução.

fonts

Módulo de verificações de renderização de fonte.

formats

Camada de abstração de formato de arquivo baseada no translate-toolkit.

gitexport

O módulo opcional Exportador git.

lang

Módulo que define idioma e modelos plurais.

legal

O módulo opcional Legal module.

machinery

Integração de serviços de tradução automática.

memory

Memória de tradução embutida, consulte Memória de tradução.

screenshots

Gerenciamento de capturas de tela e módulo OCR.

trans

Módulo principal que trata das traduções.

utils

Vários utilitários auxiliares.

vcs

Abstração do sistema de controle de versão.

wladmin

Personalização da interface administrativa do Django.

Background tasks internals

Dica

This section describes Celery task internals. Tarefas de fundo usando Celery describes how to configure Celery to run the tasks.

Weblate uses Celery to execute tasks in the background. Some tasks are event-triggered, and some tasks are schedule-triggered.

The Celery Beat is used for scheduling tasks, and django-celery-beat is used to store the periodic task schedule in the database. The tasks schedule is configured in tasks.py in each of the Django apps.

The tasks are consumed using several queues; the routing is configured in settings.py. The queues were designed to separate different types of workload:

celery

The default queue where background tasks are processed.

notify

Delivers notification e-mails, both for events within Weblate and for authentication or registration. This is a separate queue to make e-mail delivery smooth even if there is a backlog of other tasks.

memory

Updates translation memory entries. The updating queue can be long when importing new strings, and long processing does not matter much here, so having a separate queue avoids blocking other tasks.

backup

The backup tasks cannot be executed in parallel, and a single dedicated worker makes this easier.

translate

Automatic translation tasks are known to take long because they hit external services.