--- name: verify_file_hash kind: function lang: bash domain: cybersecurity version: "1.0.0" purity: impure signature: "verify_file_hash(file: string, algorithm: string, expected_hash: string) -> void" description: "Calcula el hash criptográfico de un archivo con el algoritmo especificado (md5, sha1, sha256, sha512) y opcionalmente lo compara con un hash esperado para verificar integridad. Retorna exit code 1 si los hashes no coinciden." tags: [bash, cybersecurity, hash, integrity, checksum, md5, sha256, sha512, pendiente-usar] uses_functions: [] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] params: - name: file desc: "ruta al archivo del que calcular el hash" - name: algorithm desc: "algoritmo de hash a usar: md5, sha1, sha256 (recomendado) o sha512" - name: expected_hash desc: "hash esperado en hexadecimal para verificar integridad (opcional; si se omite, solo calcula e imprime)" output: "imprime el hash calculado; si se proporcionó expected_hash, imprime COINCIDE o NO COINCIDE y retorna exit code 1 si no coinciden" tested: false tests: [] test_file_path: "" file_path: "bash/functions/cybersecurity/verify_file_hash.sh" source_repo: "https://gitea-dgg044oo04woo4ggcsws4gk0.organic-machine.com/egutierrez/DevLauncher.git" source_license: "MIT" source_file: "scripts/linux/ciberseguridad/utilidades/verificar_hash.sh" --- ## Ejemplo ```bash source bash/functions/cybersecurity/verify_file_hash.sh # Solo calcular el hash verify_file_hash archivo.iso sha256 # Verificar contra un hash conocido verify_file_hash archivo.iso sha256 "a1b2c3d4e5f6..." # MD5 (solo para compatibilidad, no recomendado para seguridad) verify_file_hash documento.pdf md5 ``` ## Notas La comparación de hashes es case-insensitive (normaliza a minúsculas). SHA256 es el algoritmo recomendado para verificación de integridad. MD5 y SHA1 están deprecados para uso en seguridad pero se incluyen para compatibilidad con sumas publicadas en sistemas legacy. Retorna exit code 1 cuando los hashes no coinciden, lo que permite usar la función en scripts con `set -e`.