Contenido del curso
Contratos actualizables
Firmas off-chain
Meta-transacciones
Detalles EIP-20
Contenido del curso
Detalles EIP-20
Rafael Mosquera
EstudianteRoger Castellví Garcia
EstudianteAfu Tse
EstudianteCarlos Jose Ramirez Divo
EstudianteJesús Antonio López Lugo
EstudianteRodrigo Ramos Xochiteotzin
EstudianteJesús Antonio López Lugo
EstudianteEs recomendable revisar el curso de OpenZeppelin: **https://platzi.com/cursos/openzeppelin/ **
Te tomo la palabra, voy a ello
Creo q tomaré tu consejo, ya que en la clase anterior tmb recomendaron ver primero lo de openzepellin. Slds
Hay dos flujos de transferencia a los contratos, una directa y una indirecta.
.
Entonces, ¿por qué no usar siempre el flujo de transferencia directa?
Porque en ocasiones es necesario utilizar un contrato inteligente como intermediario.
.
Función transferFrom
.
● Es útil en casos donde se interactúa con contratos que actúan como vendedores.
Estos contratos no tienen forma de escuchar eventos que generan las transacciones. La manera de hacerlo es mediante el transferFrom
.
● Ataque front-running: Este tipo de ataque se da por la misma especificación, no por una implementación en particular.
.
Un ejemplo de ataque front-running:
.
T1: Alice -> approve(Bob, N) -> Token ERC20 -> DONE
.
T.. | Alice decide cambiar la cantidad aprobada a Bob de N a M tokens (M > 0), pero Bob se da cuenta de esta transaccion y decide transferir los N tokens que ya tiene aprobados antes que la nueva transaccion de Alice sea probada.
.
Tn: Alice -> approve(Bob, M) -> Token ERC20 -> DELAYED
.
Tn: Bob -> transferFrom(Alice, otra_direccion, N) -> Token ERC20 -> OK
(esta transaccion se realiza mas rapido porque Bob pago un fee extra al minero para agilizarla)
.
Tn+1: Alice -> approve(Bob, M) -> Token ERC20 -> DONE
.
Tn+2: Bob -> transferFrom(Alice, otra_direccion, M) -> Token ERC20 -> OK
¿Los Hooks son funciones que se crean manualmente o son parte del estandar ERC20?
¿Se podría decir que los hooks son como parte del ciclo de vida de una función?
Una transferencia indirecta seria por ejemplo, permitir que un exchange pueda vender y transferir cierta cantidad de mis tokens ERC20 a traves de su contrato inteligente