# Integraciones de Marketplace de Estates

## Integrar el Estate de Decentraland en tu Marketplace

El Estate de Decentraland es un NFT compatible con ERC721 y funciona en Ethereum Mainnet. Por lo tanto, muchos marketplaces de terceros pueden comerciar con ellos. Para hacerlo, este marketplace debe seguir ciertas reglas para mantener las operaciones seguras para los usuarios.

Como quizás sepas, cada [Estate](https://docs.decentraland.org/decentraland/faq/#what-is-an-estate) es un grupo de [LANDs](https://docs.decentraland.org/decentraland/faq/#what-is-land) y tiene un *bytes* hash asociado al grupo que se llama *`fingerprint`*. Cada vez que el Estate cambia al añadir o eliminar un LAND, su *`fingerprint`* también cambia.

Para los marketplaces, especialmente los que no tienen un sistema de escrow, se recomienda al 100% tener un registro del *`fingerprint`* fingerprint del Estate cuando alguien lo publica a la venta o hace una oferta. De esa manera, cuando la orden/oferta se ejecuta correctamente, el propietario actual no puede cambiar el estate intentando adelantarse a la ejecución de la orden.

No se recomienda listar Estates vacíos. El smart contract del Estate tiene un método `getEstateSize` que devuelve el número de LANDs en el Estate. Si el resultado es `0`, recomendamos no listar ese Estate. Si quieres listarlo de todos modos, verás una imagen como esta:

![](/files/bfb7604fd1177182ccca0b6bdb36617791af8c66)

## Ejemplo

### No usar el fingerprint del Estate

* Bob tiene el Estate1 con los LAND (1,1) y (1,2). Fingerprint de Estate1: hash1
* Bob añade el LAND (1,3) al Estate1. El Estate1 tiene los LANDs: (1,1), (1,2) y (1,3). Fingerprint de Estate1: hash2 (Fingerprint cambiado)
* Bob elimina el LAND (1,1) del Estate1. El Estate1 tiene los LANDs: (1,2) y (1,3). Fingerprint de Estate1: hash3 (Fingerprint cambiado)
* Bob pone a la venta el Estate1. La lista se crea onchain en Ethereum Mainnet con la dirección del smart contract del Estate, el id del Estate, el precio y la fecha de expiración.
* Alice envía una transacción para comprar el Estate especificando el id del estate y el precio esperado a pagar.
* Bob detecta que alguien está intentando comprar su Estate1 y envía una transacción con tarifas de gas más altas que las de Alice para eliminar los LANDs (1,2) y (1,3) del Estate1.
* La transacción de Bob se mina primero. Estate1 tiene 0 LANDs. Fingerprint de Estate1: hash4 (Fingerprint cambiado)
* La transacción de Alice se mina después. Alice compró el Estate1 con 0 LANDs sobre él. Eso significa que Bob hizo front-run a Alice (y la robó/estafó).

### Usar el fingerprint del Estate

* Bob tiene el Estate1 con los LAND (1,1) y (1,2). Fingerprint de Estate1: hash1
* Bob añade el LAND (1,3) al Estate1. El Estate1 tiene los LANDs: (1,1), (1,2) y (1,3). Fingerprint de Estate1: hash2 (Fingerprint cambiado)
* Bob elimina el LAND (1,1) del Estate1. El Estate1 tiene los LANDs: (1,2) y (1,3). Fingerprint de Estate1: hash3 (Fingerprint cambiado)
* Bob pone a la venta el Estate1. La lista se crea onchain en Ethereum Mainnet con la dirección del smart contract del Estate, el id del Estate, el precio y la fecha de expiración.
* Alice envía una transacción para comprar el Estate especificando el id del estate, el precio esperado a pagar y **el fingerprint que vio (hash3)**.
* Bob detecta que alguien está intentando comprar su Estate1 y envía una transacción con tarifas de gas más altas que las de Alice para eliminar los LANDs (1,2) y (1,3) del Estate1.
* La transacción de Bob se mina primero. Estate1 tiene 0 LANDs. Fingerprint de Estate1: hash4 (Fingerprint cambiado)
* La transacción de Alice se revierte porque el smart contract comprobó que el fingerprint en el parámetro que envió Alice no coincidía con el fingerprint actual de Estate1 (hash3 != hash4). Esta comprobación evitó que Alice comprara un Estate no deseado.

## Interfaz de Fingerprint del Smart Contract del Estate

El smart contract del Estate es compatible con una [interfaz de fingerprint](https://github.com/decentraland/land/blob/master/contracts/estate/EstateStorage.sol#L19). Para comprobar si una orden/oferta para un estate sigue siendo válida o no, puedes llamar a la *`verifyFingerprint(uint256 estateId, bytes fingerprint)`* función implementada en el smart contract del Estate. Puedes consultar un ejemplo funcional en producción [aquí](https://github.com/decentraland/marketplace-contracts/blob/master/contracts/marketplace/MarketplaceV2.sol#L382)


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.decentraland.org/creator/content-creator-es/marketplace/estates-marketplace-integrations.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
