Scripts e Comandos do Admin do Workspace
Limpar Banco de Dados
./scripts/clean-db.sh
Limpa o banco de dados removendo todos os dados enquanto preserva o esquema e a estrutura do banco de dados.
Caution
Use com cuidado, pois isto excluirá todos os dados existentes.
Limpar artefatos de compilação e dependências
scripts/clean-workspace.sh
Remove todos os artefatos de build, diretório node_modules e outros arquivos gerados para garantir um estado limpo. Isso é útil quando você precisa realizar uma instalação nova ou resolver problemas de dependências. O comando excluirá:
- Diretório
node_modules/ - Diretório de build
.next/ - Diretório
dist/ - Diretório
out/ - Diretório
.turbo/ pnpm-lock.yamldata/*.json(arquivos de backup JSON de desenvolvimento)public/documentationdocumentation/.docusaurus,.cache,.cache-*,build,node_modules,pnpm-lock.yaml- Diretório
.genkit/ - Arquivos
*.tsbuildinfo - Cache de store do pnpm (via
pnpm store prune) - Cache de build do Docker e limpeza do sistema (imagens, redes, volumes)
Limpar Docker Compose e ambiente Docker
scripts/clean-docker.sh
Realizar uma limpeza completa do Docker, que é útil para:
- Liberar espaço em disco
- Remover artefatos antigos/não utilizados do Docker
- Limpar após sessões de desenvolvimento ou testes
- Manter um ambiente Docker limpo
Atualizar os pacotes para a versão mais recente
Você pode atualizar pacotes manualmente usando:
ncu --upgrade
pnpm update
Ou use o script automatizado:
./scripts/upgrade-dependencies.sh
O script upgrade-dependencies.sh automatiza todo o processo de atualização de dependências:
- Atualiza
package.jsoncom as versões mais recentes usandonpm-check-updates - Atualiza o arquivo de bloqueio do pnpm e instala as dependências atualizadas
- Atualiza o banco de dados do browserslist
- Verifica vulnerabilidades usando
pnpm audit - Corrige automaticamente vulnerabilidades usando
pnpm audit fix - Verifica novamente vulnerabilidades após a correção para confirmar os ajustes
Este script fornece um fluxo de trabalho completo para manter as dependências atualizadas e seguras.
Verificar pacotes não utilizados
pnpm depcheck
Atualizar informações de versão
./scripts/update-version.sh
Este script atualiza automaticamente informações de versão em múltiplos arquivos para mantê-los sincronizados. Ele:
- Extrai a versão de
package.json - Atualiza o arquivo
.envcom a variávelVERSION(cria-a se não existir) - Atualiza o
Dockerfilecom a variávelVERSION(se existir) - Atualiza o campo de versão em
documentation/package.json(se existir) - Atualiza apenas se a versão foi alterada
- Fornece feedback sobre cada operação
Script de pré-verificações
./scripts/pre-checks.sh
Este script executa verificações prévias antes de iniciar o servidor de desenvolvimento, compilar ou iniciar o servidor de produção. Ele:
- Garante que o arquivo
.duplistatus.keyexista (viaensure-key-file.sh) - Atualiza as informações de versão (via
update-version.sh)
Este script é chamado automaticamente por pnpm dev, pnpm build e pnpm start-local.
Garantir que o arquivo de chave existe
./scripts/ensure-key-file.sh
Este script garante que o arquivo .duplistatus.key exista no diretório data. Ele:
- Cria o diretório
datase não existir - Gera um novo arquivo de chave aleatória de 32 bytes se estiver faltando
- Define as permissões do arquivo como 0400 (somente leitura para o proprietário)
- Corrige as permissões se estiverem incorretas
O arquivo de chave é usado para operações criptográficas na aplicação.
Recuperação de conta Admin
./admin-recovery <username> <new-password>
Este script permite a recuperação de contas admin se bloqueadas ou com senha esquecida. Ele:
- Redefine a senha para o usuário especificado
- Desbloqueia a conta se ela estava bloqueada
- Redefine o contador de tentativas de login falhadas
- Limpa a flag "Deve alterar a senha"
- Valida se a senha atende aos requisitos de segurança
- Registra a ação no Log de Auditoria
Exemplo:
./admin-recovery admin NewPassword123
Caution
Este script modifica diretamente o banco de dados. Use apenas quando necessário para recuperação de conta.
Copiar imagens
./scripts/copy-images.sh
Copia arquivos de imagem de documentation/static/img para seus locais apropriados no aplicativo:
- Copia
favicon.icoparasrc/app/ - Copia
duplistatus_logo.pngparapublic/images/ - Copia
duplistatus_banner.pngparapublic/images/
Útil para manter as imagens da aplicação sincronizadas com as imagens da documentação.
Comparar versões entre desenvolvimento e Docker
./scripts/compare-versions.sh
Este script compara versões entre seu ambiente de desenvolvimento e um contêiner Docker em execução. Ele:
- Compara versões do SQLite apenas pela versão principal (por exemplo, 3.45.1 vs 3.51.1 são consideradas compatíveis, mostradas como "✅ (major)")
- Compara versões do Node, npm e duplistatus exatamente (devem corresponder exatamente)
- Exibe uma tabela formatada mostrando todas as comparações de versão
- Fornece um resumo com resultados codificados por cores (✅ para correspondências, ❌ para incompatibilidades)
- Sai com código 0 se todas as versões corresponderem, 1 se houver incompatibilidades
Requisitos:
- O container Docker nomeado
duplistatusdeve estar em execução - O script lê informações de versão dos logs do container Docker
Saída de exemplo:
┌─────────────────────────┬──────────────────────────────┬──────────────────────────────┬──────────────┐
│ Component │ Development │ Docker │ Match │
├─────────────────────────┼──────────────────────────────┼──────────────────────────────┼──────────────┤
│ SQLite │ 3.45.1 │ 3.51.1 │ ✅ (major) │
│ Node │ 24.12.0 │ 24.12.0 │ ✅ │
│ npm │ 10.9.2 │ 10.9.2 │ ✅ │
│ Duplistatus │ 1.2.1 │ 1.2.1 │ ✅ │
└─────────────────────────┴──────────────────────────────┴──────────────────────────────┴──────────────┘
Nota: As versões do SQLite são comparadas apenas pela versão principal, pois diferentes versões de patch dentro da mesma versão principal são geralmente compatíveis. O script indicará se as versões do SQLite correspondem no nível principal, mas diferem nas versões de patch.
Visualizando as configurações no banco de dados
sqlite3 data/backups.db "SELECT key, value FROM configurations;" | awk -F'|' '
{print "\n" $1 ": ";
if(index($2,"{")>0) {print $2 |"jq -C ."; close("jq -C .")}
else {print $2;}}' | less -R
sqlite3 /var/lib/docker/volumes/duplistatus_data/_data/backups.db "SELECT key, value FROM configurations;" | awk -F'|' '
{print "\n" $1 ": ";
if(index($2,"{")>0) {print $2 |"jq -C ."; close("jq -C .")}
else {print $2;}}' | less -R
Mostrar configurações de backup
./scripts/show-backup-settings.sh [database_path]
Exibe o conteúdo do valor backup_settings na tabela de configurações em uma tabela formatada. Útil para depurar configurações de notificação. Caminho padrão do banco de dados: data/backups.db.