Technologia blockchain, a konkretnie zdecentralizowane finanse (DeFi), otworzyły potężne możliwości dla systemów finansowych. Jednak wraz ze wzrostem ekosystemu rośnie również złożoność interakcji w wielu sieciach blockchain. Każdy blockchain działa niezależnie, tworząc silosy płynności i funkcjonalności, po których użytkownicy i deweloperzy muszą poruszać się ręcznie.
Systemy oparte na intencjach pojawiły się jako rozwiązanie tej fragmentacji, oferując sposób na abstrakcję złożoności interakcji z różnymi blockchainami. Zamiast wymagać od użytkowników bezpośredniej interakcji z podstawową infrastrukturą każdego łańcucha, systemy te pozwalają użytkownikom definiować pożądane rezultaty — takie jak transfer tokenów lub wykonywanie transakcji — jednocześnie przenosząc techniczne wykonanie na podmioty zewnętrzne, znane jako wypełniacze.
Intencje crosschain (jeden z wielu typów intencji) to wstępnie zdefiniowane działania, które użytkownicy chcą wykonać w różnych sieciach blockchain. Na przykład użytkownik może chcieć zamienić tokeny między Ethereum i Arbitrum. Zamiast ręcznie wykonywać transakcje w obu łańcuchach, intencja crosschain pozwala użytkownikowi zdefiniować działanie w jednym kroku. Wypełniacze wykonują intencję, wchodząc w interakcję z odpowiednimi łańcuchami, abstrahując proces dla użytkownika i zmniejszając tarcie — cenna funkcja dla operacji DeFi w wielu łańcuchach.
Pomimo swojego potencjału, systemy oparte na intencjach napotykają wyzwania, które ograniczają ich skalowalność i skuteczność, szczególnie w zakresie dostępu do płynności i rozwoju sieci wypełniaczy. Poniżej podkreślamy niektóre z tych problemów:
Pokonanie tych wyzwań wymaga zintegrowania współdzielonej infrastruktury i uniwersalnych ram w systemach crosschain. W szczególności ujednolicona struktura obsługi intencji crosschain może pomóc w koordynacji wypełniaczy, usprawnieniu przepływu płynności i ustanowieniu bardziej wydajnych sieci wypełniaczy. Wykorzystując współdzielone protokoły, systemy crosschain mogą skalować się i zapewniać bardziej płynne działanie, odblokowując większą wydajność i wykorzystanie płynności w całym ekosystemie blockchain.
Tu właśnie pojawia się ERC-7683.
ERC-7683: Cross Chain Intents proponuje ujednolicone ramy do definiowania i spełniania intencji crosschain i ułatwia użytkownikom angażowanie się w operacje multichain, takie jak transfery tokenów lub wykonywanie inteligentnych kontraktów. Propozycja stanowi pierwszą próbę stworzenia ustandaryzowanego interfejsu dla intencji używanych w operacjach crosschain i ma pozytywne implikacje dla ekosystemu Ethereum.
Standaryzując sposób tworzenia i przetwarzania intencji, ERC-7683 ma na celu usprawnienie interakcji między łańcuchami, poprawę dostępu do płynności i promowanie lepszej interoperacyjności między łańcuchami bloków. Upraszcza również interakcje, umożliwiając użytkownikom i zdecentralizowanym aplikacjom określanie swoich intencji bez bezpośredniego angażowania się w infrastrukturę każdego łańcucha.
Co ważne, ERC-7683 zmniejsza fragmentację i nieefektywność spowodowane przez izolowane protokoły i sieci wypełniaczy. Wypełniacze są obecnie odizolowane w określonych ekosystemach, co ogranicza przepływ płynności w łańcuchach bloków. ERC-7683 rozwiązuje ten problem, konsolidując wysiłki w spójną sieć wypełniaczy, która obejmuje wiele łańcuchów i protokołów, usprawniając tworzenie intencji, ich realizację i weryfikację, jednocześnie zachęcając do szerszego uczestnictwa w całym ekosystemie blockchain.
ERC-7683 umożliwia szeroki zakres intencji dla działań międzyłańcuchowych. Intencje te mogą obejmować proste transfery, wymiany tokenów międzyłańcuchowych, staking aktywów lub bardziej złożone operacje, takie jak dostarczanie płynności w wielu blockchainach. Użytkownicy mogą określić szczegóły, takie jak łańcuch docelowy, typy tokenów i ograniczenia, takie jak terminy wykonania lub limity cenowe. ERC-7683 zapewnia ustandaryzowany format przesyłania tych intencji, umożliwiając zdecentralizowanym aplikacjom i wypełniaczom bezproblemowe działanie w łańcuchach.
Podczas gdy ERC-7683 standaryzuje sposób przesyłania intencji międzyłańcuchowych i strukturę rozwiązań, nie określa, w jaki sposób odbywa się weryfikacja międzyłańcuchowa. Zamiast tego ERC-7683 pozostawia proces weryfikacji aplikacji zdecentralizowanej lub użytkownikowi za pośrednictwem pola „Settler Contracts”. To pole pozwala im wybrać umowę rozliczeniową z procesem weryfikacji, któremu ufają, dostosowaną do ich przypadku użycia.
To elastyczne podejście pozwala na różnorodność metod weryfikacji. Niektóre protokoły mogą komunikować się za pomocą weryfikacji wielopodpisowych, podczas gdy inne mogą używać optymistycznych konfiguracji z mechanizmami wyzwań lub dowodami zerowej wiedzy. ERC-7683 nie wymusza określonego modelu, wspierając różnorodność w projektach umów rozliczeniowych i pozwalając aplikacjom zdecentralizowanym wybrać najlepsze dopasowanie do ich potrzeb. Ostatecznie ERC-7683 koncentruje się na standaryzacji zleceń międzyłańcuchowych w celu ujednolicenia strumieni płynności i poprawy koordynacji, bez narzucania konkretnej metody weryfikacji.
ERC-7683 jest wynikiem współpracy między Across (wiodącym mostem) i Uniswap Labs (twórcą największej giełdy zdecentralizowanej Ethereum), które są znane w przestrzeni DeFi. Wykorzystując swoje połączone doświadczenie, zaproponowali standard, który odpowiada na rzeczywiste potrzeby użytkowników i deweloperów w ekosystemie Ethereum. ERC-7683 otrzymał również wsparcie od ponad 35 protokołów, w tym Arbitrum, Base, Optimism i Base.
Dodatkowo ERC-7683 został przedstawiony grupie roboczej CAKE ( Chain Abstraction Key Elements ), kolektywowi skupiającemu się na rozwoju międzyłańcuchowym i interoperacyjności. Ich zaangażowanie jest kluczowe, ponieważ reprezentują szeroki zakres projektów blockchain. Dzięki ich wkładowi standard może zostać udoskonalony, aby sprostać różnorodnym potrzebom ekosystemu. Ten proces zapewnia, że ERC-7683 jest zarówno solidny, jak i praktyczny do wdrożenia na dużą skalę.
ERC-7683 przedstawia przejrzysty proces wykonywania intencji crosschain, umożliwiając bezproblemowe transfery aktywów i interakcje w wielu blockchainach. Ten ustandaryzowany przepływ zapewnia, że użytkownicy mogą definiować swoje intencje, podczas gdy wypełniacze zajmują się wykonywaniem, co skutkuje bardziej wydajnym ekosystemem crosschain. Poniżej znajduje się szczegółowy podział każdego kroku w standardowym przepływie intencji crosschain.
Proces rozpoczyna się od użytkownika, który inicjuje intencję crosschain. Użytkownik podpisuje wiadomość offchain zawierającą kluczowe szczegóły dotyczące transakcji, takie jak tokeny do wymiany, łańcuch docelowy i inne istotne parametry zakodowane w strukturze CrossChainOrder. Ta wiadomość jest podpisana poza łańcuchem przy użyciu klucza prywatnego użytkownika, co zapewnia integralność i autentyczność zamówienia. Podpisując się poza łańcuchem, użytkownik unika bezpośredniej interakcji z łańcuchem bloków, co zmniejsza koszty gazu i poprawia wydajność.
Proces rozpoczyna się od rozpowszechnienia podpisanej wiadomości offchain. Ta wiadomość, utworzona przez użytkownika i podpisana jego kluczem prywatnym, jest udostępniana wypełniaczom — podmiotom zewnętrznym odpowiedzialnym za wykonywanie intencji crosschain. Rozpowszechnianie odbywa się za pośrednictwem kanałów offchain, takich jak zdecentralizowane sieci lub systemy przekazywania zamówień, umożliwiając wypełniaczom przeglądanie szczegółów zamówienia. Wypełniacze mogą następnie zdecydować, czy zaakceptować zamówienie, co sprzyja konkurencji, która promuje szybsze wykonanie i niższe opłaty.
Gdy wypełniający zaakceptuje zlecenie, inicjuje transakcję w łańcuchu źródłowym, wywołując funkcję open IOriginSettler. Ta funkcja weryfikuje podpis użytkownika, blokuje tokeny użytkownika w depozycie, aby zapobiec ich wykorzystaniu gdzie indziej, i sygnalizuje, że wymiana międzyłańcuchowa jest gotowa do wykonania. W tym momencie szczegóły zlecenia są przygotowywane do wykonania w łańcuchu docelowym i przesyłane za pośrednictwem systemu komunikatów międzyłańcuchowych.
Po zainicjowaniu transakcji w łańcuchu źródłowym wypełniacz realizuje zamówienie w łańcuchu docelowym, wywołując funkcję resolve, która dekoduje CrossChainOrder do ResolvedCrossChainOrder. Zapewnia to wypełniaczowi wszystkie niezbędne szczegóły — takie jak tokeny do przeniesienia i adresy odbiorców — w celu ukończenia wymiany. Następnie wypełniacz przekazuje tokeny użytkownikowi w łańcuchu docelowym, spełniając pierwotny zamiar.
Ostatnim krokiem jest rozliczenie międzyłańcuchowe, w którym kontrakty rozliczeniowe zarówno w łańcuchu źródłowym, jak i docelowym zapewniają, że intencja została wykonana poprawnie. Aktywa zablokowane w łańcuchu źródłowym zostają zwolnione, a użytkownik otrzymuje swoje tokeny w łańcuchu docelowym. W zależności od użytego kontraktu rozliczeniowego weryfikacja może nastąpić poprzez bezpośrednią komunikację między łańcuchami lub za pośrednictwem optymistycznych modeli weryfikacji. Ta elastyczność umożliwia różne metody potwierdzania spełnienia intencji, zapewniając, że zarówno użytkownik, jak i wypełniający mogą zaufać procesowi.
ERC-7683 wprowadza kilka niezbędnych komponentów zaprojektowanych w celu zapewnienia elastyczności i dostosowania do różnych implementacji crosschain. Komponenty te umożliwiają systemom opartym na intencjach dostosowywanie się do różnych protokołów, modeli cenowych i mechanizmów weryfikacji przy jednoczesnym zachowaniu ujednoliconej struktury dla zamówień crosschain.
Pole OrderData w strukturze CrossChainOrder odgrywa kluczową rolę w umożliwianiu personalizacji i elastyczności w różnych implementacjach.
Funkcja resolve i struktura ResolvedCrossChainOrder są niezbędne do zapewnienia, że wypełniacze mogą walidować i wykonywać zamówienia crosschain bez konieczności rozumienia szczegółowych informacji w oryginalnym polu OrderData. Funkcja resolve upraszcza proces walidacji i wykonywania, konwertując złożony, specyficzny dla protokołu CrossChainOrder na ResolvedCrossChainOrder.
To rozdzielenie abstrahuje od złożoności oryginalnego OrderData, zapewniając wypełniaczom standardowy format danych wejściowych i wyjściowych potrzebnych do ukończenia zamówienia. Ponadto pozwala wypełniaczom uczestniczyć w procesie crosschain bez potrzeby głębokiej wiedzy na temat szczegółów specyficznych dla protokołu zakodowanych w OrderData, co poprawia skalowalność i zmniejsza tarcie.
ERC-7683 opcjonalnie integruje Permit2 , mechanizm zatwierdzania, który umożliwia obsługę transferów tokenów i realizacji zleceń za pomocą jednego podpisu użytkownika. Zmniejsza to złożoność operacyjną dla użytkowników, którzy w przeciwnym razie musieliby zatwierdzać zarówno transfer tokenów, jak i wymianę osobno. Wykorzystując Permit2, aplikacje zdecentralizowane mogą zapewnić, że transfer tokenów jest bezpiecznie powiązany z pomyślnym zainicjowaniem wymiany, co poprawia zarówno bezpieczeństwo, jak i doświadczenie użytkownika. Wprowadza to jednak również kwestie związane z obsługą parametrów specyficznych dla Permit2, takich jak nonces i terminy, które muszą być zgodne ze strukturą zamówienia międzyłańcuchowego.
Uwaga dla czytelników : Poniższa sekcja zagłębia się w szczegółowe specyfikacje techniczne systemu. Chociaż zapewnia dogłębne informacje dla deweloperów i osób zainteresowanych aspektami technicznymi, nie jest to wymagana lektura, aby zrozumieć szersze koncepcje. Możesz pominąć część, jeśli bardziej interesują Cię ogólne przeglądy lub praktyczne zastosowania.
Zanim przejdziemy do szczegółów technicznych, przyjrzyjmy się słownikowi pojęć zawartemu w ofercie:
Ponieważ dysponujemy słownikiem, możemy skupić się na kluczowych komponentach wprowadzonych przez normę ERC-7683 w celu umożliwienia realizacji intencji międzyłańcuchowych:
ERC-7683 obsługuje dwa typy zleceń crosschain: GaslessCrossChainOrder i OnchainCrossChainOrder. Kluczowa różnica między nimi polega na tym, jak zlecenie jest inicjowane i kto ponosi koszty transakcji.
W przypadku GaslessCrossChainOrder użytkownik podpisuje zamówienie poza łańcuchem, delegując jego przesłanie do wypełniacza. Następnie wypełniacz przesyła zamówienie do umowy z pierwotnym osadnikiem w imieniu użytkownika i pokrywa powiązane opłaty za gaz. Takie podejście oferuje użytkownikowi płynne, bezgazowe doświadczenie, ponieważ wypełniacze są zachęcani do odzyskiwania kosztów poprzez nagrody za wykonanie. Aby umożliwić to delegowanie, struktura zawiera pola takie jak originSettler, user i nonce, zapewniając bezpieczeństwo, ochronę przed powtórzeniami i właściwe przetwarzanie intencji użytkownika.
Z drugiej strony, OnchainCrossChainOrder jest tworzony bezpośrednio przez użytkownika onchain. Tutaj użytkownik wchodzi w interakcję z kontraktem origin settlement jako msg.sender, biorąc odpowiedzialność za opłaty za gaz. Ta struktura jest prostsza, ponieważ wyklucza pola specyficzne dla delegacji, takie jak originSettler lub user, skupiając się zamiast tego na polach, takich jak fillDeadline i orderData, które są bezpośrednio istotne dla wykonania zamówienia. Ta metoda jest idealna dla użytkowników, którzy wolą bezpośrednią kontrolę nad swoimi transakcjami i wygodnie zarządzają interakcjami onchain.
originSettler : To pole zawiera adres kontraktu odpowiedzialny za zarządzanie rozliczeniem zamówienia w łańcuchu źródłowym. Umożliwia aplikacji dApp lub użytkownikowi zdefiniowanie metody weryfikacji, służy jako kluczowy kontrakt dla łańcucha źródłowego i zapewnia prawidłowe wykonanie swapu.
użytkownik : Użytkownik to adres osoby inicjującej intencję. Jego aktywa są blokowane lub powiernicze w łańcuchu źródłowym, gdy rozpoczyna się zamówienie. Ten adres jest kluczowy dla zapewnienia, że aktywa właściwej strony są zamieniane i dla weryfikacji podpisu użytkownika, potwierdzając autentyczność zamówienia.
nonce : Nonce działa jako unikalny identyfikator zamówienia, zapobiegając atakom typu replay. Każdy CrossChainOrder musi mieć unikalny nonce, co zapewnia, że żadne zamówienie nie może zostać wykonane więcej niż raz, unikając w ten sposób podwójnego wydatkowania lub powtarzających się transakcji.
originChainId i destinationChainId : Te pola odpowiednio identyfikują łańcuchy, w których zamówienie pochodzi i gdzie zostanie zrealizowane. Zapewniają one, że system kieruje zamówienie do właściwego miejsca docelowego, rozróżniając różne sieci blockchain.
openDeadline i fillDeadline : Te znaczniki czasu ustawiają limity czasowe na inicjowanie i realizację zamówienia. openDeadline definiuje, kiedy zamówienie musi zostać rozpoczęte w łańcuchu źródłowym, a fillDeadline oznacza, kiedy musi zostać ukończone w łańcuchu docelowym. Pomaga to zapewnić, że zamówienia są wykonywane terminowo i nie pozostają w zawieszeniu na czas nieokreślony.
orderData : Dowolne pole danych umożliwiające personalizację. Obejmuje szczegóły, takie jak wymieniane tokeny, kwoty, łańcuch docelowy, limity cenowe i dodatkowe ograniczenia. Ta elastyczność umożliwia szeroki zakres operacji międzyłańcuchowych przy jednoczesnym zachowaniu nienaruszonej struktury rdzenia.
/// @title GaslessCrossChainOrder CrossChainOrder type /// @notice Standard order struct to be signed by users, disseminated to fillers, and submitted to origin settler contracts struct GaslessCrossChainOrder { /// @dev The contract address that the order is meant to be settled by. /// Fillers send this order to this contract address on the origin chain address originSettler; /// @dev The address of the user who is initiating the swap, /// whose input tokens will be taken and escrowed address user; /// @dev Nonce to be used as replay protection for the order uint256 nonce; /// @dev The chainId of the origin chain uint256 originChainId; /// @dev The timestamp by which the order must be opened uint32 openDeadline; /// @dev The timestamp by which the order must be filled on the destination chain uint32 fillDeadline; /// @dev Type identifier for the order data. This is an EIP-712 typehash. bytes32 orderDataType; /// @dev Arbitrary implementation-specific data /// Can be used to define tokens, amounts, destination chains, fees, settlement parameters, /// or any other order-type specific information bytes orderData; } /// @title OnchainCrossChainOrder CrossChainOrder type /// @notice Standard order struct for user-opened orders, where the user is the msg.sender. struct OnchainCrossChainOrder { /// @dev The timestamp by which the order must be filled on the destination chain uint32 fillDeadline; /// @dev Type identifier for the order data. This is an EIP-712 typehash. bytes32 orderDataType; /// @dev Arbitrary implementation-specific data /// Can be used to define tokens, amounts, destination chains, fees, settlement parameters, /// or any other order-type specific information bytes orderData; }
Po przesłaniu CrossChainOrder do łańcucha docelowego jest on dekodowany do struktury ResolvedCrossChainOrder. Ten proces upraszcza dane, prezentując je w ujednoliconym formacie, którego wypełniacze mogą użyć do wykonania zamiany.
Cel i składniki: ResolvedCrossChainOrder zapewnia wypełniaczom przejrzystą, wykonalną strukturę do pracy. Poprzez rozdzielenie złożonego pola orderData ResolvedCrossChainOrder zapewnia płynne wykonanie w łańcuchu docelowym.
Struktura ResolvedCrossChainOrder zawiera pola tablicy kluczy, które definiują ograniczenia i parametry dla transakcji międzyłańcuchowych:
Pola te opierają się na strukturach Output i FillInstruction, które dostarczają szczegółowych danych umożliwiających bezproblemowe wykonanie instrukcji.
Struktura Output definiuje tokeny i miejsca docelowe zaangażowane w transakcję. Każdy wpis w tablicach maxSpent i minReceived jest instancją tej struktury i zawiera następujące atrybuty:
Pole fillInstructions zawiera tablicę instrukcji, przy czym każdy wpis parametryzuje pojedynczą nogę transakcji crosschain. Ta struktura zapewnia, że wypełniacze mają wszystkie dane generowane przez źródło, potrzebne do dokładnego wykonania transakcji. Kluczowe atrybuty obejmują:
Struktury te zapewniają, że wszystkie zaangażowane strony — użytkownicy i osoby wypełniające — otrzymają odpowiednie wynagrodzenie w postaci właściwych tokenów, co gwarantuje bezpieczne i wydajne przeprowadzenie wymiany w ramach łańcuchów.
/// @title ResolvedCrossChainOrder type /// @notice An implementation-generic representation of an order intended for filler consumption /// @dev Defines all requirements for filling an order by unbundling the implementation-specific orderData. /// @dev Intended to improve integration generalization by allowing fillers to compute the exact input and output information of any order struct ResolvedCrossChainOrder { /// @dev The address of the user who is initiating the transfer address user; /// @dev The chainId of the origin chain uint256 originChainId; /// @dev The timestamp by which the order must be opened uint32 openDeadline; /// @dev The timestamp by which the order must be filled on the destination chain(s) uint32 fillDeadline; /// @dev The unique identifier for this order within this settlement system bytes32 orderId; /// @dev The max outputs that the filler will send. It's possible the actual amount depends on the state of the destination /// chain (destination dutch auction, for instance), so these outputs should be considered a cap on filler liabilities. Output[] maxSpent; /// @dev The minimum outputs that must be given to the filler as part of order settlement. Similar to maxSpent, it's possible /// that special order types may not be able to guarantee the exact amount at open time, so this should be considered /// a floor on filler receipts. Output[] minReceived; /// @dev Each instruction in this array is parameterizes a single leg of the fill. This provides the filler with the information /// necessary to perform the fill on the destination(s). FillInstruction[] fillInstructions; } /// @notice Tokens that must be received for a valid order fulfillment struct Output { /// @dev The address of the ERC20 token on the destination chain /// @dev address(0) used as a sentinel for the native token bytes32 token; /// @dev The amount of the token to be sent uint256 amount; /// @dev The address to receive the output tokens bytes32 recipient; /// @dev The destination chain for this output uint256 chainId; } /// @title FillInstruction type /// @notice Instructions to parameterize each leg of the fill /// @dev Provides all the origin-generated information required to produce a valid fill leg struct FillInstruction { /// @dev The contract address that the order is meant to be settled by uint64 destinationChainId; /// @dev The contract address that the order is meant to be filled on bytes32 destinationSettler; /// @dev The data generated on the origin chain needed by the destinationSettler to process the fill bytes originData; }
Interfejsy IOriginSettler i IDestinationSettler definiują podstawowe metody dla kontraktów rozliczeniowych w łańcuchach pochodzenia i przeznaczenia. Kontrakty te zapewniają standaryzowaną, wydajną obsługę intencji międzyłańcuchowych, obsługując zarówno zamówienia bez gazu, jak i zamówienia onchain, umożliwiając jednocześnie bezproblemową realizację w łańcuchach przeznaczenia.
Interfejs IOriginSettler zarządza cyklem życia zleceń crosschain w łańcuchu źródłowym, od utworzenia zlecenia do jego rozwiązania. Obsługuje zarówno GaslessCrossChainOrder, jak i OnchainCrossChainOrder, oferując elastyczność dla transakcji inicjowanych przez użytkownika i ułatwianych przez wypełniacza.
Funkcje openFor i open inicjują zlecenia crosschain w łańcuchu źródłowym. Funkcja openFor jest używana przez wypełniaczy do przesyłania zleceń gasless w imieniu użytkowników, podczas gdy funkcja open umożliwia użytkownikom bezpośrednie tworzenie zleceń onchain bez angażowania wypełniacza.
Kluczową różnicą jest to, że openFor obejmuje podpis i opcjonalne dane dostarczone przez wypełniacza (originFillerData) w celu uwierzytelnienia i parametryzacji transakcji, podczas gdy open nie wymaga tych danych, ponieważ użytkownik bezpośrednio wchodzi w interakcję z kontraktem nadawcy nadawcy jako msg.sender.
Parametry :
Funkcje resolveFor i resolve konwertują zamówienia crosschain do standardowego formatu ResolvedCrossChainOrder. Funkcja resolveFor obsługuje zamówienia gasless, podczas gdy funkcja resolve przetwarza zamówienia onchain. Obie funkcje zapewniają ujednoliconą strukturę dla integracji downstream, upraszczając wykonywanie dla wypełniaczy.
Parametry :
Interfejs IDestinationSettler zarządza procesem rozliczeniowym w łańcuchu docelowym, umożliwiając realizatorom realizację określonych odcinków zleceń międzyłańcuchowych.
Funkcja fill pozwala wypełniaczom przetwarzać określoną nogę zamówienia crosschain w łańcuchu docelowym. Polega ona na danych wygenerowanych w łańcuchu źródłowym, w połączeniu z dodatkowymi preferencjami dostarczonymi przez wypełniacza, aby sparametryzować i wykonać transakcję.
Parametry:
orderId : Unikalny identyfikator konkretnego zamówienia międzyłańcuchowego.
originData : Dane z łańcucha pochodzenia wymagane do rozliczenia.
fillerData : Dodatkowe dane zdefiniowane przez wypełniacz, umożliwiające dostosowanie procesu wypełniania.
/// @title IOriginSettler /// @notice Standard interface for settlement contracts on the origin chain interface IOriginSettler { /// @notice Opens a gasless cross-chain order on behalf of a user. /// @dev To be called by the filler. /// @dev This method must emit the Open event /// @param order The GaslessCrossChainOrder definition /// @param signature The user's signature over the order /// @param originFillerData Any filler-defined data required by the settler function openFor(GaslessCrossChainOrder calldata order, bytes calldata signature, bytes calldata originFillerData) external; /// @notice Opens a cross-chain order /// @dev To be called by the user /// @dev This method must emit the Open event /// @param order The OnchainCrossChainOrder definition function open(OnchainCrossChainOrder calldata order) external; /// @notice Resolves a specific GaslessCrossChainOrder into a generic ResolvedCrossChainOrder /// @dev Intended to improve standardized integration of various order types and settlement contracts /// @param order The GaslessCrossChainOrder definition /// @param originFillerData Any filler-defined data required by the settler /// @return ResolvedCrossChainOrder hydrated order data including the inputs and outputs of the order function resolveFor(GaslessCrossChainOrder calldata order, bytes calldata originFillerData) external view returns (ResolvedCrossChainOrder memory); /// @notice Resolves a specific OnchainCrossChainOrder into a generic ResolvedCrossChainOrder /// @dev Intended to improve standardized integration of various order types and settlement contracts /// @param order The OnchainCrossChainOrder definition /// @return ResolvedCrossChainOrder hydrated order data including the inputs and outputs of the order function resolve(OnchainCrossChainOrder calldata order) external view returns (ResolvedCrossChainOrder memory); }
ERC-7683 nie wymusza konkretnej metody weryfikacji do ustalania intencji crosschain, dając deweloperom elastyczność w implementacji najlepszego podejścia do ich przypadku użycia. Typowe metody obejmują:
Optimistic Setups : Zakładają, że transakcje są domyślnie ważne, a spory są zgłaszane tylko w przypadku podejrzenia oszukańczej aktywności. Ta metoda przyspiesza wykonanie, pomijając natychmiastową weryfikację.
Bezpośrednia komunikacja łańcuchowa : Niektóre systemy, takie jak niektóre mosty stron trzecich, wykorzystują metody komunikacji międzyłańcuchowej za pośrednictwem protokołów przesyłania wiadomości. Inteligentne kontrakty w łańcuchu źródłowym pośrednio wchodzą w interakcję z tymi w łańcuchu docelowym, a transakcje są weryfikowane i rozliczane bez długich okresów wyzwań. Ta metoda jest szybsza, ale wymaga niezawodnych przekaźników i silnych dowodów kryptograficznych dla bezpiecznej implementacji.
Podejścia hybrydowe : ERC-7683 obsługuje modele hybrydowe, w których różne elementy procesu rozliczeniowego są łączone w celu zapewnienia większej elastyczności. Na przykład aplikacja zdecentralizowana może używać bezpośredniej komunikacji do weryfikacji i blokowania zasobów użytkownika za pośrednictwem IOriginSettler w łańcuchu źródłowym, jednocześnie stosując optymistyczną konfigurację do walidacji działań wypełniacza za pośrednictwem IDestinationSettler w łańcuchu docelowym. To podejście hybrydowe zapewnia równowagę między szybkością a bezpieczeństwem, wykorzystując mocne strony obu metod.
Oferując elastyczność w metodach rozliczeń i weryfikacji, ERC-7683 pozwala deweloperom dostosowywać systemy do konkretnych zastosowań DeFi, zwiększając zarówno komfort użytkowania, jak i wydajność.
ERC-7683 znacząco poprawia krajobraz intencji międzyłańcuchowych, usprawniając procesy i umożliwiając bardziej wydajne interakcje w wielu blockchainach. Wprowadzając ujednolicone ramy, ERC-7683 przynosi kilka kluczowych korzyści, które ulepszają doświadczenie użytkowników, deweloperów i wypełniaczy.
Jedną z głównych zalet ERC-7683 jest ulepszona interoperacyjność, jaką wnosi do ekosystemu Ethereum. Wcześniej protokoły i platformy musiały tworzyć własne zastrzeżone rozwiązania do obsługi transakcji międzyłańcuchowych, co prowadziło do fragmentacji i nieefektywności. Standaryzacja intencji międzyłańcuchowych umożliwia zdecentralizowanym aplikacjom integrację funkcjonalności międzyłańcuchowych bez konieczności projektowania unikalnych rozwiązań. W rezultacie płynność może płynąć swobodniej między sieciami, tworząc bardziej spójny ekosystem międzyłańcuchowy, który zmniejsza tarcie zarówno dla programistów, jak i użytkowników.
ERC-7683 zachęca również do rozwoju wspólnej infrastruktury do dystrybucji zamówień i sieci wypełniaczy, co jest kluczowe dla skalowalności i sukcesu systemów crosschain. Poprzez standaryzację struktury i przetwarzania zamówień protokół sprzyja tworzeniu wspólnych systemów, które skutecznie dystrybuują zamówienia crosschain. Ta wspólna infrastruktura umożliwia wielu aplikacjom zdecentralizowanym i protokołom korzystanie z tych samych sieci wypełniaczy, tworząc bardziej solidne i konkurencyjne środowisko wypełniaczy.
Wypełniacze mogą teraz uczestniczyć w różnych protokołach bez konieczności dostosowywania się do różnych zastrzeżonych formatów, co prowadzi do lepszej koordynacji i wykorzystania płynności. Ta infrastruktura współpracy zwiększa niezawodność transakcji międzyłańcuchowych, zapewniając większą pulę wypełniaczy do realizacji zamówień, redukując wąskie gardła i poprawiając wskaźniki realizacji.
ERC-7683 wzmacnia płynność, umożliwiając bezproblemowy przepływ aktywów w łańcuchach bloków. Standaryzacja intencji międzyłańcuchowych eliminuje silosy, umożliwiając swobodniejszy przepływ aktywów między łańcuchami i zmniejszając nieefektywność spowodowaną rozdrobnionymi pulami płynności. Ta pogłębiona płynność przynosi korzyści zdecentralizowanym giełdom (DEX), platformom pożyczkowym i innym protokołom DeFi, usprawniając realizację transakcji, zmniejszając poślizg i zapewniając płynniejsze transfery aktywów w ekosystemie blockchain. Dzięki ERC-7683 płynność staje się zasobem współdzielonym, a nie rozdrobnionym, zwiększając ogólną wydajność operacji wielołańcuchowych.
ERC-7683 znacząco poprawia doświadczenie użytkownika, rozwiązując wiele problemów z transakcjami międzyłańcuchowymi. Wprowadzenie standardowego formatu zamówień i współdzielonych sieci wypełniaczy pozwala wypełniaczom konkurować skuteczniej, obniżając opłaty i czyniąc wymiany i transfery międzyłańcuchowe bardziej opłacalnymi.
Ponadto ERC-7683 zmniejsza wskaźniki awaryjności w swapach międzyłańcuchowych, rozwiązując problem rozdrobnionych sieci wypełniaczy i niewystarczającej płynności. Jego ustandaryzowane procesy zamówień i realizacji umożliwiają wypełniaczom bardziej wydajny dostęp do niezbędnych szczegółów, redukując błędy, opóźnienia i nieudane transakcje. W rezultacie użytkownicy doświadczają płynniejszych i bardziej przewidywalnych interakcji międzyłańcuchowych.
Ponadto ERC-7683 ułatwia szybsze wykonywanie intencji międzyłańcuchowych. Konsolidując płynność i przepływ zleceń, protokół zapewnia, że wypełniacze mogą szybko uzyskać dostęp i ukończyć niezbędne transakcje, zmniejszając opóźnienia, z którymi użytkownicy mogą się spotkać podczas interakcji z wieloma łańcuchami.
Zapewniając standaryzowaną strukturę intencji, ERC-7683 otwiera nowe możliwości kompozycyjności w zdecentralizowanych finansach (DeFi). Protokoły mogą teraz bezproblemowo integrować funkcjonalność crosschain z istniejącymi strukturami, umożliwiając użytkownikom łączenie wielu operacji DeFi, takich jak pożyczanie, staking i swapowanie, w jednym przepływie transakcji.
Ta zwiększona możliwość kompozycji pozwala deweloperom budować bardziej zaawansowane aplikacje zdecentralizowane, które wykorzystują funkcjonalność crosschain bez dodatkowej złożoności, co ostatecznie sprzyja innowacjom w DeFi. Dla użytkowników oznacza to bardziej płynne doświadczenie podczas interakcji z połączonymi protokołami, odblokowując pełny potencjał DeFi w wielu łańcuchach.
Podsumowując, ERC-7683 zwiększa wydajność międzyłańcuchowych systemów intencyjnych poprzez zapewnienie lepszej interoperacyjności, wspieranie współdzielonej infrastruktury i dostarczanie bardziej przyjaznego dla użytkownika środowiska przy niższych kosztach, szybszym wykonywaniu i mniejszej liczbie niepowodzeń transakcji.
Podczas gdy ERC-7683 oferuje znaczące korzyści dla systemów intencji międzyłańcuchowych, przedstawia również wyzwania i kwestie, które należy uwzględnić w celu pomyślnej implementacji. Obejmują one przeszkody we wdrażaniu, obawy dotyczące bezpieczeństwa i złożoność integracji, które mogą mieć wpływ na sposób, w jaki programiści, aplikacje zdecentralizowane i użytkownicy korzystają ze standardu.
Jednym z głównych wyzwań dla ERC-7683 jest osiągnięcie powszechnej adopcji w różnych ekosystemach blockchain. Wiele projektów zainwestowało już znaczne zasoby w rozwój własnych zastrzeżonych rozwiązań crosschain, co może powodować opór przed przyjęciem nowego standardu. Przekonanie deweloperów i dApps do przejścia na ERC-7683 będzie wymagało znacznego wysiłku, szczególnie w przypadku ustalonych protokołów, które już zbudowały własną infrastrukturę.
Bezpieczeństwo jest krytycznym czynnikiem w interakcjach międzyłańcuchowych, a ERC-7683 wprowadza nowe rozważania ze względu na elastyczną konstrukcję. Standard pozwala na różne umowy rozliczeniowe, ale ta elastyczność może prowadzić do różnych poziomów bezpieczeństwa w zależności od implementacji. Źle zaprojektowane lub niewystarczająco przetestowane umowy rozliczeniowe mogą wprowadzać luki, szczególnie dla wypełniaczy i deweloperów, podkreślając potrzebę solidnej konstrukcji i dokładnego testowania.
Jednak dla użytkowników ryzyko jest stosunkowo niskie. Zamówienia są nieodwracalnie realizowane przy użyciu środków wypełniającego przed ostatecznym rozliczeniem w łańcuchu. Jeśli zamówienie nie zostanie zrealizowane, użytkownicy otrzymują z powrotem swoje początkowe środki powiernicze, minimalizując narażenie na ryzyko wykraczające poza nieodłączne ryzyko inteligentnych kontraktów, które mają zastosowanie w całym Web3.
Techniczna implementacja ERC-7683 przedstawia kilka wyzwań integracyjnych dla dApps i platform blockchain. Deweloperzy muszą zintegrować interfejs Settler Contracts i dostosować swoje systemy do obsługi ERC-7683, co może wymagać przepisania kluczowych komponentów związanych z tworzeniem, rozpowszechnianiem i rozliczaniem zamówień. Może to być zasobochłonne.
Ponadto elastyczność ERC-7683 umożliwia różne procedury rozliczeniowe, co może komplikować sprawy dla wypełniaczy i dApps, gdy poruszają się po różnych implementacjach. Warstwa komunikatów międzyłańcuchowych dodaje kolejną warstwę złożoności, ponieważ programiści muszą zapewnić bezpieczną i terminową transmisję wiadomości i zasobów przez blockchainy z różnymi mechanizmami konsensusu i prędkościami.
Ustandaryzowane ramy ERC-7683 dla intencji międzyłańcuchowych otwierają liczne możliwości, szczególnie w ekosystemach, w których interakcje wielołańcuchowe są niezbędne. Usprawniając sposób inicjowania, wykonywania i rozliczania transakcji międzyłańcuchowych, ERC-7683 umożliwia nowe przypadki użycia w zdecentralizowanych aplikacjach i platformach. Poniżej przedstawiono niektóre z najbardziej obiecujących obszarów, w których ten standard może mieć znaczący wpływ.
DeFi to jeden z kluczowych obszarów, w których ERC-7683 może mieć duży wpływ. Wiele protokołów DeFi działa w wielu sieciach blockchain, a ERC-7683 może znacznie poprawić ich wydajność poprzez standaryzację transakcji międzyłańcuchowych. Użytkownicy platform DeFi multichain mogą przenosić aktywa między łańcuchami bez konieczności ręcznej interakcji z infrastrukturą każdego pojedynczego łańcucha.
Ten standard zapewnia użytkownikom lepszy dostęp do płynności w łańcuchach, poprawiając wydajność operacji, takich jak udzielanie pożyczek, staking i yield farming. Zapewniając płynniejsze i szybsze interakcje, ERC-7683 obniża koszty i zwiększa niezawodność dla użytkowników DeFi.
Innym ekscytującym zastosowaniem ERC-7683 są rynki NFT międzyłańcuchowe. Niewymienne tokeny (NFT) odgrywają znaczącą rolę w ekosystemach blockchain, a umożliwienie interakcji międzyłańcuchowych z NFT mogłoby rozszerzyć rynki dla kupujących i sprzedających.
Chociaż ERC-7683 nie obsługuje bezpośrednio transferu NFT z jednego łańcucha do drugiego, jeśli sam NFT nie istnieje w obu łańcuchach, pozwala użytkownikom na zakup NFT w łańcuchu A przy użyciu środków w łańcuchu B bez konieczności dodatkowych transferów pomostowych. Ułatwiając takie intencje, jak zamiana lub nabywanie NFT w łańcuchu docelowym, ERC-7683 zwiększa płynność i elastyczność na rynku NFT, zapewniając użytkownikom bardziej płynne doświadczenie. Podsumowując, ERC-7683 ma potencjał, aby napędzać innowacje na rynkach wielołańcuchowych DeFi i międzyłańcuchowych NFT, zapewniając ujednolicone i wydajne podejście do interakcji międzyłańcuchowych.
ERC-7683 jest pozycjonowany tak, aby wywrzeć znaczący wpływ na Ethereum i szerszy ekosystem blockchain. Wprowadzając ujednolicone ramy dla intencji crosschain, rozwiązuje wiele wyzwań związanych z interakcjami multichain. W miarę rozwoju przestrzeni blockchain, przyjęcie i dalszy rozwój ERC-7683 może zmienić sposób działania zdecentralizowanych aplikacji i protokołów w różnych łańcuchach, promując bardziej wydajne, skalowalne i przyjazne dla użytkownika rozwiązania.
W przypadku Ethereum ERC-7683 może wzmocnić swoją rolę jako centrum działań multichain. Zapewniając bezproblemowy sposób przemieszczania aktywów i transakcji między Ethereum a innymi blockchainami, ERC-7683 wzmacnia pozycję Ethereum jako fundamentu dla DeFi i innych aplikacji crosschain. Jest to szczególnie ważne w kontekście rollupów, gdzie płynność często ulega fragmentacji w różnych rozwiązaniach warstwy 2 (L2).
Obecnie użytkownicy muszą osobno wchodzić w interakcję z każdym rollupem, co fragmentuje płynność i zwiększa nieefektywność. ERC-7683 pomaga ujednolicić płynność w tych rollupach, standaryzując sposób, w jaki aktywa przemieszczają się między nimi, zmniejszając tarcie i poprawiając przepływ płynności.
ERC-7683 ma potencjał, aby znacząco wpłynąć na szerszy ekosystem blockchain poprzez wspieranie większej współpracy międzyłańcuchowej. W miarę jak standard zyskuje na popularności, projekty, które były tradycyjnie izolowane w obrębie własnych ekosystemów, mogą zacząć płynniej integrować się z zewnętrznymi blockchainami, torując drogę do zwiększonej interoperacyjności w przyszłości. Ta zwiększona łączność międzyłańcuchowa może prowadzić do lepszej płynności, bardziej solidnych DEX-ów i silniejszych ekosystemów DeFi w ogóle. Standaryzacja wprowadzona przez ERC-7683 może również napędzać innowacje, zachęcając projekty do budowania na podstawie tych ram i wykorzystywania interoperacyjności międzyłańcuchowej w celu oferowania nowych usług i funkcji.
Podobnie jak w przypadku każdej rozwijającej się technologii, ERC-7683 prawdopodobnie będzie podlegać dalszym udoskonaleniom w miarę upływu czasu. Jednym z obszarów potencjalnego rozwoju jest udoskonalenie mechanizmów weryfikacji rozliczeń. Podczas gdy obecna wersja umożliwia elastyczność w procesach rozliczeniowych, przyszłe iteracje mogą wprowadzić bardziej solidne lub ujednolicone metody weryfikacji w celu poprawy bezpieczeństwa i uproszczenia integracji dla programistów i użytkowników.
Innym obszarem do poprawy może być optymalizacja sieci wypełniaczy. Wraz ze wzrostem transakcji międzyłańcuchowych posiadanie bardziej wydajnych sieci wypełniaczy będzie krytyczne dla zapewnienia szybkiego i taniego wykonania. Przyszłe wersje ERC-7683 mogą wprowadzić zaawansowane mechanizmy doboru wypełniaczy, zachęcania do uczestnictwa i minimalizowania opóźnień w transakcjach międzyłańcuchowych.
Podsumowując, ERC-7683 daje duże nadzieje na udoskonalenie ekosystemu Ethereum, szczególnie w zakresie konsolidacji płynności w ramach rozproszonych konsolidacji, a także rozszerzenia interoperacyjności międzyłańcuchowej w szerszej przestrzeni blockchain.
ERC-7683 zapewnia kluczowe ramy do ulepszania interakcji międzyłańcuchowych poprzez standaryzację sposobu tworzenia, rozpowszechniania i spełniania intencji w wielu blockchainach. Ten standard rozwiązuje kluczowe problemy, takie jak rozdrobniona płynność i nieefektywne sieci wypełniaczy, oferując ujednoliconą strukturę, która upraszcza transfery aktywów i poprawia wrażenia użytkownika. Jego elastyczna konstrukcja umożliwia również stosowanie różnych metod weryfikacji, dając deweloperom swobodę wdrażania rozwiązań dostosowanych do ich potrzeb, przy jednoczesnym zachowaniu zgodności w całym szerszym ekosystemie.
Patrząc w przyszłość, ERC-7683 prawdopodobnie odegra kluczową rolę w kształtowaniu przyszłości interoperacyjności międzyłańcuchowej. Wraz ze wzrostem adopcji możemy spodziewać się dalszych postępów w standardzie, szczególnie w takich obszarach jak weryfikacja rozliczeń i optymalizacja sieci wypełniaczy. Poprzez ujednolicenie płynności w rozdrobnionych ekosystemach, w szczególności w ramach konsolidacji Ethereum, ERC-7683 przygotowuje grunt pod bardziej spójne, wydajne i skalowalne środowisko międzyłańcuchowe, napędzając innowacje i współpracę w całym krajobrazie blockchain.
Wersja tego artykułu została pierwotnie opublikowana tutaj .