Solidity. Смарт контракты и аудит – Telegram
Solidity. Смарт контракты и аудит
2.62K subscribers
246 photos
7 videos
18 files
547 links
Обучение Solidity. Уроки, аудит, разбор кода и популярных сервисов
Download Telegram
ERC-865

Новые пользователи криптовалюты могут быть удивлены, узнав, что плата перевод токенов может взыматься плата в Эфире.

Среди стандартов ERC, предложенных разработчиками сообщества Ethereum, ERC-865 призван облегчить привыкание к этому людям, плохо знакомым с криптографией. Также предполагается, что плата за майнинг может быть оплачена с помощью токена.

#erc #erc865
👍1
ERC-875

ERC-875 предложил возможность отправки нескольких NFT (non-fungible tokens) в одной транзакции, при помощи присвоения каждому из них персонального индекса. Стандарт также предполагает безопасные отправку и обмен токенов, как и в случае с ERC-721.

#erc #erc875
👍1
ERC-884

Маркер ERC-884 является токеном, совместимым с ERC-20, который был разработан Дэвидом Сагом в соответствии с общим корпоративным законом штата Делавэр.

Корпорации штата Делавэр могут использовать технологии блокчейна для создания торгуемого токена ERC-20 и поддержки акций, выпущенных корпорацией штата Делавэр.

#erc #erc884
👍1
ERC-998

ERC-998 можно комбинировать с неоднородными токенами (составные NFT, сокращенно CNFT). Его структурный дизайн является стандартизированным расширением, которое позволяет любому NFT иметь другие NFT или FT. При передаче CNFT необходимо передать всю иерархическую структуру и принадлежность CNFT. Проще говоря, ERC-998 может содержать несколько токенов в форме ERC-721 и ERC-20.

#erc #erc998
👍1
ERC-1155

ERC-1155 использует новый способ определения токенов, центральный интеллектуальный контракт, в котором элементы будут храниться, и занимает очень мало места, чтобы отличать их друг от друга. Любой элемент Token можно объединить и упаковать в «пакет Token», пакет Token также имеет собственный независимый идентификатор (уменьшите большое количество избыточных байт-кодов в блокчейне)

Давайте сравним механизм установки алмазов в темноте, оружие с двумя отверстиями и двумя совершенными драгоценными камнями. Это три жетона. Когда мы вкладываем эти два драгоценных камня в оружие, он становится жетоном Сумка - это новое оружие. В то же время этот механизм также может упростить сложные транзакции. Например, A и B. хотят обменять 20 позиций. Если это транзакция, требуется 20 транзакций. Если можно собрать 20 токенов, требуется только одна транзакция. Во время распаковки эффективность и опыт значительно улучшились.

#erc #erc1155
👍1
ERC-1337

Это стандарт для создания повторяемых подписных платежей в блокчейне. Протокол токена создает задачу для повторяемых платежей в криптовалюте. Также он позволяет владельцу настраивать вариатны приема платежей даже из разных токенов.

#erc #erc1337
👍1
ERC-1400

Он представляет собой библиотеку стандартов для токенов безопасности в Ethereum. Эти стандарты являются зонтиком нескольких других стандартов, которые все обратно совместимы с интерфейсами ERC-20 и ERC-777.

#erc #erc1400
👍1
ERC-1404

Это дополнение к ERC-20-совместимым токенам, которое включает дополнительную функцию, позволяющую ограничивать передачу токенов. Этот стандарт был создан TokenSoft , поставщиком технологий для компаний, которые стремятся выпускать и управлять цифровыми ценными бумагами на блокчейне, соблюдая при этом нормативные требования.

#erc #erc1404
👍1
ERC-1410

Он относится как к дифференцированному владению, так и к прозрачным ограничениям. Этот интерфейс поддерживает токены владельца для группировки в разделы, каждый из которых представлен идентифицирующим ключом и балансом.

Некоторые из этих разделов могут быть взаимозаменяемыми, в то время как другие не являются взаимозаменяемыми. Например, нефункционируемый раздел токенов может иметь определенные условия (например, период перехода, определенный для владельцев безопасности).

#erc #erc1410
👍1
ERC-1450

ERC-1450 (также называемый LDGRToken) относится к токену, совместимому с ERC-20, который соответствует новым Правилам Закона о ценных бумагах: Правило Crowdfunding, Правило D и Правило A. Этот стандарт был разработан компанией Start Engine.

#erc #erc1450
👍1
ERC-1594

Этот стандарт предоставляет интерфейс, который вводит проверки на потенциальное ограничение в цепочке, ввод данных вне цепочки для ограничений на передачу и семантику выдачи / погашения.

Внедрение данных относится к правилам, которые определены вне цепочки, которые могут применяться и обновляться администратором договора для определения набора применимых механизмов выдачи и погашения и потенциальных ограничений передачи между адресами.

#erc #erc1594
👍1
ERC-1643

Этот стандарт позволяет связывать документы со смарт-контрактом и предоставляет стандартный интерфейс для запроса или изменения этих контрактов, а также для получения обновлений (через события) изменений в этих документах.

#erc #erc1643
👍1
ERC-1644

Этот стандарт позволяет «токену прозрачно заявлять, может ли контроллер в одностороннем порядке передавать токены между адресами».

Контроллер относится к программе, которая управляет или направляет поток данных между двумя адресами.

#erc #erc1644
👍1
ERC-3475

Стандарт токенов EIP-3475 принят Ethereum Foundation в качестве нового стандарта интерфейса для создания токенезированных облигаций— EIP-3475 позволяет кредиторам выпускать деривативы по непогашенным ссудам, формируя из них новые облигации с различными комбинациями параметров риска и прибыли.

Новый стандарт также позволяет распределять кредитные риски между поставщиками ликвидности — это является основным преимуществом для кредитора по сравнению с другими существующими DeFi-протоколами кредитования. Главным плюсом для заемщика станет то, что залоговое обеспечение не придется ликвидировать, если его стоимость опустится ниже установленного порога.

#erc #erc3475
👍1
ERC-4626

В начале апреля 2022 года разработчики yEarn объявили о завершении работы над ERC-4626 и начале «Великой стандартизации хранилищ».

По их словам, построенное на базе нового стандарта хранилище может взаимодействовать с любыми токенами ERC-4626.

Как пояснили эксперты Huobi Research, ERC-4626 унифицирует следующие параметры:

- способы внесения пользовательских средств в хранилище, а также их вывода;
- функции расчета количества токенов доходности и базовых активов;
- происходящие при взаимодействии с хранилищами события, включая ввод и вывод средств;
- интерфейс для подтверждения адресов базовых активов.

ERC-4626 также экономит время на разработку, придает интеграции гибкость, повышает безопасность взаимодействия пользователей с приложениями и способствует инновациям.

#erc #erc4626
👍1
ERC-4907

Он позволяет владельцу NFT разрешить другому лицу использовать его NFT в течение определенного периода времени. По истечении этого времени пользователь больше не имеет доступа к NFT. Видеоигры Play-to-earn (P2E) все еще являются относительно новым явлением как в криптовалюте, так и в игровом бизнесе.

#erc #erc4907
👍1
Популярные ошибки в Solidity

Нашел интересный пост с корявым переводом ошибок, которые могут появиться при проведении транзакций. Это точно не полный список, но теперь это будет постоянная рубрика на канале.

Если вы получили какую-то ошибку у себя в практике и решили ее, то поделитесь этим решением с другими участниками. А пока, вот небольшой список:

1. Error: VM Exception while processing transaction: out of gas

В Solidity нельзя настроить постоянное выполнение транзакций.
Транзакция может выполняться, пока не будет достигнут лимит газа. Как только это произойдет, транзакция выдаст ошибку и вернет "out of gas".

Чаще всего это происходит в циклах функций.

2. Error: VM Exception while processing transaction: invalid opcode

Смарт контракты порой используют assert() для выявления ошибок по выполнению определенных условий в функции. Но иногда они могут противоречить условиям самого контракта. Например,

function set(uint x) public {
  assert(x == 0);
  myVariable = x;
}

3. Error: VM Exception while processing transaction: revert (описание ошибки)

Обычно это происходит, когда условия модификатора не выполняются, например, модификатор onlyOwner, который может быть вызван только владельцем.

Как и с другими require(), если условие не выполнено, оно вернет "revert exception".

4. CompilerError: Stack too deep, try removing local variables.

Это зависит от сложности выражения внутри функции, где присутствует много (более 16) локальных переменных.

Решение:

-Удалите ненужные переменные;
- Разделите большие функции;

5. SyntaxError: Unexpected token in JSON at position 0

Ошибки с форматом данных json указывает на наличие проблемы при синтаксическом анализе файла .sol для создания файла .json.

Такого рода проблемы могут быть в Truffle.

6. Solidity error: Unexpected token h in JSON at position

Строку параметра необходимо передавать в двойных кавычках.

7. The transaction has been reverted to the initial state. Note: The called function should be payable if you send value and the value you send should be less than your current balance.

Одна из переменных или функций должа быть помечена как payable, чтобы была возможность перевода валюты или токенов.

8. Expected pragma, import directive or contract/interface/library definition...

Проверьте версию pragma в компиляторе и в контракте.

9. ParserError: Source file requires different compiler version (current compiler is 0.6.12+commit.27d51765.Windows.msvc) - note that nightly builds are
considered to be strictly less than the released version pragma solidity ^0.8.0;

И снова следите за версиями в компиляторе и контракте.

10. Cannot estimate gas; transaction may fail or may require manual gas limit.

Возможно, что функция потребует больше газа, чем может себе позволить. В этом случаем можно либо вручную указать количество газа, либо переписать функцию.

Иногда такие ошибки возникают при использовании сторонних сервисов, когда чужой контракт должен вызвать в нашем callback функции, и у нас нет средств оплатить этот вызов.

11. Undeclared identifier.

Вы пытаетесь использовать переменную, которая нигде ранее не появлялась. Проверьте ее на опечатку или регистр.

12. ParseError: Expected '(' but got identifier.

Проверьте закрыты ли все кавычки выше или в самой функции.

13. Warning: SPDX license identifier not provided in source file. Before publishing, consider adding a comment containing "SPDX-License-Identifier: " to each source file. Use "SPDX-License-Identifier: UNLICENSED" for non-open-source code.

Скорее всего забыли прописать лицензию в начале кода смарт контракта, типа "SPDX-License-Identifier: MIT".

14. Error: invalid arrayify value

Означает, что в массиве передаете на правильный тип данных.

Читайте ошибки! По опыту могу сказать, что, внимательно прочитав ошибку, можно понять, из-за чего она появилась. Даже если вы не знаете английского языка, то онлайн переводчики отлично смогут помочь вам с этим.

В будущем поиск ошибок на канале можно будет выполнить по хештегу #error

#error
👍1
Заметка по работе с ошибками

Давно хотел написать небольшую заметку о работе с ошибками в программировании. Опять же из своего опыта.

Я состою в нескольких чатах, где пользователи активно делятся своими ошибками, дают и спрашивают совета, постят статьи и т.д.

И очень часто, складывается такое ощущение, что некоторым пользователям просто лень самим разбираться с возникающими ошибками в коде. Они делают скрин и постят в чат. Потом пишут, что не получилось и скрин новой ошибки и так до бесконечности.

Хочу дать вам пару советов, как лучше работать со своими ошибками в коде.

1. Самое первое - это прочитать ошибку. В 90% случаев вам будет понятно, в чем может быть проблема.

2. Погуглите ее. Так и пишите в поисковой строке: "Ошибка ..." и копируйте текст ошибки. Скорее всего в первых же выдачах она будет показана. Stackoverflow - наше все!

3. Если вы пошли в чат или на канал, то сначала также воспользуйтесь поиском. Велика вероятность, что у кого-то уже была такая же ошибка и сообщество помогло ее решить.

4. Если случилось невероятное, и вашей ошибки нет ни в гугле, ни в чатах, то опишите ошибку как можно подробнее! Не стоит делать скрин и спрашивать, что не так. Опишите язык программирования, который используете, покажите код или функцию, на каком этапе возникает и т.д.

Самое главное в работе с ошибками в программировании - это уметь гуглить и правильно составлять вопросы для поиска! Покопавшись несколько минут в документации вы не только сможете разобраться в данной ошибке, но и избежать ее в дальнейшем!

#error
👍1
Немного об xNFT

Недавно в одном из Телеграм каналов о криптовалюте проскальзывала новость о xNFT. Тогда я не обратил внимание на нее, но слово "xNFT" плотно засела у меня в голове. И вот я, наконец, добрался до него.

Поиск по слову "xNFT" мне мало, что дал. Какие-то протоколы, валюты и прочее, все это не то, что хотелось найти.

В итоге, это оказалось очень крутой штукой, хоть пока реализованной на языке Solana. Однако мне верится, что и для Ethereum скоро создадут нечто подобное.

Итак, сама новость:

"Компании FTX Ventures и Jump Crypto возглавили сбор средств в размере $20 млн для кошелька невзаимозаменяемых токенов (NFT) Coral на основе Solana. Среди других участников были отмечены Multicoin Capital, Anagram и K5 Global.

Стало известно, что денежные средства привлечены в рамках раунда стратегического финансирования. Собранный капитал пойдет на создание первого флагманского продукта Backpack, представляющего собой хранилище для исполняемых невзаимозаменяемых токенов (xNFT).

В случае с xNFT владелец имеет право выполнять токенизированный компьютерный код определенного типа. По сути юзер может инициировать работу приложений благодаря токену. Возможность запуска нескольких типов dApp на единой площадке может упростить адаптацию, что является глобальной проблемой криптоиндустрии, по словам создателей стартапа.

Backpack был запущен для закрытого бета-тестировании 26 сентября 2022 года. Около 10 крупнейших проектов на базе Solana уже разрабатывают продукты с использованием технологии Backpack xNFT, включая торговую площадку NFT Magic Eden, межсетевой мост Wormhole, протокол децентрализованных финансов (DeFi) Solend и фреймворк Anchor.
"

По сути скоро может появится Google Play или App Store в web3 и приложения распространяемые через них!

#backpack #xnft
👍1
Что такое ETF?

Однажды в одном из уроков про chainlink я встретил аббревиатуру ETF. Я не знал, что это такое и полагал, что это как-то связано с блокчейном. Оказалось все проще.

Оставлю здесь, вдруг, кто еще не в курсе.

Exchange Traded Fund, или ETF, — это биржевой инвестиционный фонд, зарегистрированный вне пределов России, но акции которого можно приобрести на российском фондовом рынке.

#etf
Что такое flashloan?

Это понятие часто встречалась на каналах про биржевую торговлю, и мне было интересно, как это работает.

Мгновенные займы или флэш-кредиты (от англ. Flash Loans) — это функция в ряде популярных DeFi-протоколов, позволяющая брать в долг криптовалютные активы без залогового обеспечения с условием, что долг будет возвращен в том же блоке транзакций.

Это пока также теоретическая часть, поэтому вот прекрасное видео, детально поясняющее flashloan.

#flashloan