Errors

Tratamento de erros estruturados com categorização e metadados de retry. Tabela global errors disponível sem require.

Criando Erros

-- Mensagem simples (tipo padrão UNKNOWN)
local err = errors.new("something went wrong")

-- Com tipo
local err = errors.new(errors.NOT_FOUND, "user not found")

-- Construtor completo
local err = errors.new({
    message = "user not found",
    kind = errors.NOT_FOUND,
    retryable = false,
    details = {user_id = 123}
})

Encapsulando Erros

Adicionar contexto preservando tipo, retryable e detalhes:

local data, err = db.query("SELECT * FROM users")
if err then
    return nil, errors.wrap(err, "failed to load users")
end

Métodos de Erro

Método Retorna Descrição
err:kind() string Categoria do erro
err:message() string Mensagem de erro
err:retryable() boolean/nil Se operação pode ser retentada
err:details() table/nil Metadados estruturados
err:stack() string Stack trace Lua
tostring(err) string Representação completa

Verificando Tipo

if errors.is(err, errors.INVALID) then
    -- tratar entrada inválida
end

-- Ou comparar diretamente
if err:kind() == errors.NOT_FOUND then
    -- tratar recurso ausente
end

Tipos de Erro

Constante Caso de Uso
errors.NOT_FOUND Recurso não existe
errors.ALREADY_EXISTS Recurso já existe
errors.INVALID Entrada ou argumentos inválidos
errors.PERMISSION_DENIED Acesso negado
errors.UNAVAILABLE Serviço temporariamente fora
errors.INTERNAL Erro interno
errors.CANCELED Operação foi cancelada
errors.CONFLICT Conflito de estado de recurso
errors.TIMEOUT Operação expirou
errors.RATE_LIMITED Muitas requisições
errors.UNKNOWN Erro não específicado

Call Stack

Obter call stack estruturado:

local stack = errors.call_stack(err)
if stack then
    print("Thread:", stack.thread)
    for _, frame in ipairs(stack.frames) do
        print(frame.source .. ":" .. frame.line, frame.name)
    end
end

Erros Retentáveis

Tipicamente Retentável Não Retentável
TIMEOUT INVALID
UNAVAILABLE NOT_FOUND
RATE_LIMITED PERMISSION_DENIED
ALREADY_EXISTS
if err:retryable() then
    -- seguro para retentar
end

Detalhes de Erro

local err = errors.new({
    message = "validation failed",
    kind = errors.INVALID,
    details = {
        errors = {
            {field = "email", message = "invalid format"},
            {field = "age", message = "must be positive"}
        }
    }
})

local details = err:details()
for _, e in ipairs(details.errors) do
    print(e.field, e.message)
end