,

23 ноября, 2024

DeFi. Что такое децентрализованные финансы

Всем привет! Сегодня хочу рассказать о технологии, которая меня заинтересовала — децентрализованные финансы (DeFi).

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

  1. Зависимость от посредников
    Деньги и данные приходится доверять банкам, брокерам и другим организациям, что несет риски утраты средств из-за ошибок, злоупотреблений или банкротства.
  2. Ограниченный доступ
    Некоторые регионы остаются отрезанными от финансовых услуг из-за слабой инфраструктуры или высоких требований со стороны учреждений.
  3. Высокие комиссии
    Централизованные учреждения часто берут значительные комиссии за переводы, обслуживание счетов и другие операции.
  4. Контроль со стороны третьих лиц
    Банки и другие организации могут устанавливать лимиты, замораживать счета или накладывать ограничения.
  5. Уязвимость для кибератак
    Централизация делает крупные финансовые структуры привлекательными для хакеров.

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

Что такое DeFi

DeFi (Decentralized Finance) — это один из самых горячих трендов в мире блокчейнов и криптовалют. На русском языке термин переводится как «децентрализованные финансы», что дает намек на его суть. DeFi — это финансовые услуги, которые работают без посредников, таких как банки, используя блокчейн и смарт-контракты.

Основные принципы DeFi

  1. Децентрализация: Вместо того чтобы полагаться на банки или другие учреждения, все операции происходят в блокчейне. Это устраняет необходимость в посредниках.
  2. Прозрачность: Любой пользователь может проверить транзакции в сети, что обеспечивает высокую степень доверия.
  3. Доступность: DeFi-платформы открыты для всех. Нужен только интернет и криптовалютный кошелек.
  4. Автоматизация: Используются смарт-контракты, которые автоматически выполняют условия сделки.

Основные направления применения DeFi

  1. Децентрализованные биржи (DEX)
    Это платформы для обмена криптовалют, такие как Uniswap или SushiSwap. В отличие от традиционных бирж, здесь нет центрального органа управления. Сделки заключаются напрямую между пользователями.
  2. Кредитование и займы
    DeFi позволяет брать и давать займы без участия банков. Пример платформы — Aave. Кредиторы могут зарабатывать проценты, а заемщики использовать свои криптоактивы как залог.
  3. Доходное фермерство (Yield Farming)
    Пользователи предоставляют ликвидность (свои активы) для работы протоколов и получают за это вознаграждение.
  4. Стейблкоины
    DeFi активно использует стейблкоины, такие как USDT, DAI и USDC, которые привязаны к стоимости фиатных валют, что снижает волатильность.
  5. Страхование
    В DeFi существуют платформы, которые предоставляют услуги страхования, такие как Nexus Mutual. Они защищают пользователей от финансовых рисков, например, хакерских атак.
  6. Токенизация активов
    DeFi позволяет токенизировать реальные активы, такие как недвижимость, акции или драгоценные металлы, делая их доступными для торговли.

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

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

, ,

10 ноября, 2024

Что такое стейблкоины и зачем они вообще нужны?

Стейблкоины (от англ. stablecoin) — это криптовалюты, стоимость которых привязана к какому-то стабильному активу, чаще всего к фиатным деньгам, как доллар или евро. В отличие от обычных криптовалют, курс которых может «плавать» вверх и вниз, стейблкоины держат фиксированную цену. Идея проста: дать пользователям крипты стабильный инструмент для хранения и обмена денег, который не будет зависеть от рыночных «качелей».

Почему это важно? Представь, что ты хочешь сохранить деньги в криптовалюте, но не хочешь рисковать из-за волатильности. Стейблкоины идеально подходят для таких целей — они, как бы, балансируют между миром фиата и крипты.

Какие бывают стейблкоины?

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

1. Фиатные стейблкоины

Это самые популярные стейблкоины, например USDT (Tether), USDC (USD Coin) и BUSD (Binance USD). Такие монеты обеспечены реальными деньгами на банковском счёте или ликвидными активами. Один USDT или USDC всегда должен быть равен одному доллару, потому что за ним лежит настоящий доллар или его эквивалент. Фирмы, которые выпускают такие стейблкоины, должны регулярно доказывать наличие резервов для поддержания доверия.

2. Криптообеспеченные стейблкоины

Эти стейблкоины обеспечены криптовалютами. Самый известный пример — DAI от проекта MakerDAO. В отличие от USDT или USDC, здесь используется алгоритм и резерв криптовалюты (чаще всего ETH) для обеспечения курса. Поскольку криптовалюта нестабильна, такие стейблкоины часто имеют избыточное обеспечение — то есть на каждый доллар DAI приходится больше одного доллара в крипте, чтобы компенсировать возможные колебания.

3. Алгоритмические стейблкоины

Здесь ситуация интереснее. Эти стейблкоины вообще не имеют реального обеспечения, а удерживают курс с помощью алгоритмов и смарт-контрактов. Примеры: UST (Terra), FRAX. Механизм такой: если цена монеты падает ниже доллара, алгоритм сжигает часть монет, уменьшая их предложение и повышая цену. Если цена выше доллара, выпускаются новые монеты, снижая курс. Однако такие модели несут риск, так как устойчивость зависит только от алгоритма и спроса на рынке.

Стейблкоины в программном коде

Если рассмотреть стейблкоин с точки зрения кода, то это смарт-контракт, который выполняет разные функции по управлению выпуском и сжиганием монет. Наиболее распространённый стандарт для создания таких токенов на Ethereum — это ERC-20, который поддерживает базовые функции для создания и передачи токенов. Однако у стейблкоинов есть и уникальные особенности, которые добавляются к стандарту.

Вот базовый пример смарт-контракта стейблкоина на Solidity:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

contract StableCoin is ERC20, Ownable {
    constructor() ERC20("MyStableCoin", "MSC") {
        _mint(msg.sender, 1000000 * 10 ** decimals());
    }

    function mint(address to, uint256 amount) public onlyOwner {
        _mint(to, amount);
    }

    function burn(uint256 amount) public {
        _burn(msg.sender, amount);
    }
}

Что здесь происходит?

  • ERC20 — мы используем стандарт ERC-20, который предоставляет функции для работы с токенами: transfer, balanceOf, allowance и другие.
  • Ownable — это модификатор, который даёт владельцу контракта (обычно компании-эмитенту) возможность управлять ключевыми функциями. Например, только владелец может «минтить» (выпускать) новые токены.
  • mint — функция для выпуска новых токенов. В фиатных стейблкоинах такие функции используются, когда компания пополняет резервы.
  • burn — функция для сжигания токенов, если их нужно вывести из обращения.

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

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

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

, ,

9 ноября, 2024

Что такое Solidity и для чего используется

Что такое Solidity и зачем он вообще нужен?

Solidity — это язык программирования, созданный специально для разработки смарт-контрактов на блокчейне Ethereum. Если ты когда-нибудь хотел создать свою крипту, сделать децентрализованное приложение (dApp) или написать контракт, который сам выполняет условия, как только они наступят, то Solidity — это твой инструмент. На этом языке пишутся «самоисполняющиеся» контракты, которые потом живут в блокчейне, то есть никто их не может изменить или удалить, и они автоматически выполняют всё, что в них прописано.

Где применяется Solidity?

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

  • Binance Smart Chain,
  • Polygon,
  • Avalanche,
  • Fantom.

Эти блокчейны поддерживают виртуальную машину Ethereum (EVM), которая выполняет контракты, написанные на Solidity. Вот несколько популярных применений Solidity:

  • Токены: Можешь создать свою криптовалюту, например, на стандартном шаблоне ERC-20. Это именно те «монетки», которыми торгуют на биржах.
  • NFT: Уникальные цифровые активы (например, произведения искусства или предметы коллекционирования) тоже создаются на Solidity, часто с использованием стандарта ERC-721.
  • Децентрализованные финансы (DeFi): Можно писать контракты для кредитования, ставок, торговли и других финансовых операций без посредников.
  • DAO: Децентрализованные автономные организации, в которых решения принимаются на основе смарт-контрактов и голосования участников.
  • Игры и децентрализованные приложения (dApps): Контракты на Solidity управляют логикой игр и других приложений, где нужен блокчейн.

Как работает Solidity и с чего начать?

Solidity компилируется в байт-код, который понимает EVM. То есть, мы пишем код на Solidity, компилируем его, и после этого он становится «понятен» блокчейну. Если хочешь начать, тебе понадобится среда разработки, которая поддерживает Solidity, например:

  1. Remix — бесплатный веб-инструмент, созданный для Solidity-разработки. Он работает прямо в браузере и идеально подходит для старта.
  2. Truffle и Hardhat — фреймворки для локальной разработки, тестирования и развертывания контрактов. Они дают больше возможностей, чем Remix, и больше подходят для продвинутых проектов.
  3. MetaMask — кошелёк для взаимодействия с блокчейном Ethereum, который пригодится для тестирования и развертывания контрактов.

Основы синтаксиса Solidity

Solidity напоминает C++ и JavaScript, так что если ты знаком с этими языками, разобраться будет проще. Давай начнём с простейшего примера контракта.

Простой контракт: «Привет, мир!»

Вот минимальный код, который создаёт контракт, хранящий одну строку:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract HelloWorld {
    string public greeting = "Hello, World!";
}
  • pragma solidity ^0.8.0; — указывает версию Solidity (в данном случае 0.8 и выше).
  • contract HelloWorld — объявляем контракт с именем HelloWorld.
  • string public greeting — создаём переменную greeting, доступную всем (она публичная), и сразу присваиваем ей значение "Hello, World!".

Запустив этот контракт, ты сможешь увидеть строку "Hello, World!", просто вызвав переменную greeting.

Пример контракта для хранения чисел

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

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract SimpleStorage {
    uint256 private storedData;

    // Функция для записи значения
    function set(uint256 x) public {
        storedData = x;
    }

    // Функция для чтения значения
    function get() public view returns (uint256) {
        return storedData;
    }
}

Этот контракт хранит значение и позволяет его записывать и считывать. Основные моменты:

  • uint256 private storedData; — переменная storedData для хранения числа, которая доступна только внутри контракта.
  • set(uint256 x) — функция для записи значения в storedData.
  • get() — функция для получения текущего значения storedData.

Теперь, когда контракт развернут, ты можешь вызвать функцию set, чтобы записать число, и get, чтобы его прочитать.

Пример контракта для создания простого токена

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

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import "@openzeppelin/contracts/token/ERC20/ERC20.sol";

contract MyToken is ERC20 {
    constructor() ERC20("MyToken", "MTK") {
        _mint(msg.sender, 1000 * 10 ** decimals());
    }
}
  • Мы подключаем библиотеку OpenZeppelin, чтобы не писать всё с нуля. Она предоставляет готовые стандарты, включая ERC-20.
  • constructor — это специальная функция, которая выполняется один раз при создании контракта. Здесь мы называем токен MyToken с символом MTK.
  • _mint(msg.sender, 1000 * 10 ** decimals()); — создаёт 1000 токенов и отправляет их на кошелёк создателя.

Запустив этот контракт, ты получишь свои токены прямо на кошелёк! Их можно передавать, использовать в других dApps, или даже листить на бирже (при выполнении дополнительных условий).

Советы для работы с Solidity

  1. Начинай с простых контрактов: Это поможет понять, как работает блокчейн и какие функции обязательны.
  2. Используй тестовые сети: Разворачивай контракты в тестовых сетях (например, Rinkeby или Ropsten), чтобы не тратить настоящие деньги.
  3. Будь осторожен с безопасностью: Ошибки в смарт-контрактах могут привести к уязвимостям. Изучай лучшие практики, такие как использование библиотеки OpenZeppelin, и обязательно проверяй код перед запуском.
  4. Тестируй код: Перед тем как контракт развернётся в реальной сети, обязательно протестируй его на различных сценариях.

Solidity — мощный инструмент для создания всего, от токенов до полноценных децентрализованных приложений. Начать может любой, у кого есть базовые знания программирования и интерес к блокчейну. Контракты, которые ты создаёшь, будут жить в блокчейне, оставаясь неизменными и выполняемыми автоматически. Так что, если ты хочешь попробовать себя в создании смарт-контрактов или даже запуска своей криптовалюты, Solidity — идеальный старт!

Если тебе так же интересна разработка под Solidity и все что связано с блокчейном, смарт-контрактами и разработкой под web3, то обязательно пиши мне в телегу, нам будет что обсудить!

, ,

8 ноября, 2024

Что такое смарт контракт и с чем его едят :)

Что такое смарт-контракт и как он работает?

Смарт-контракт — это, по сути, цифровой контракт, запрограммированный в блокчейне, который выполняет всё сам, как только выполняются нужные условия. Представьте, что у вас есть договор, но вместо бумаги и подписей он закодирован на языке программирования и загружен в блокчейн. Никто не может его изменить или удалить, а всё, что в нём прописано, произойдёт автоматически, как только наступят оговоренные условия.

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

Как устроен смарт-контракт?

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

Пример смарт-контракта на Solidity

Solidity — это популярный язык программирования для создания смарт-контрактов на платформе Ethereum. Если вы хотите попробовать написать свой смарт-контракт, вот простой пример:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract SimpleStorage {
    uint256 private storedData;

    // Сохраняем значение
    function set(uint256 x) public {
        storedData = x;
    }

    // Получаем значение
    function get() public view returns (uint256) {
        return storedData;
    }
}

Что тут происходит:

  • pragma solidity ^0.8.0; — это версия Solidity, которая гарантирует, что код будет совместим с текущей версией.
  • uint256 private storedData; — переменная, которая хранит число. Она приватная, так что доступна только из этого контракта.
  • set(uint256 x) — функция, которая позволяет записать значение в переменную.
  • get() — функция, возвращающая значение storedData, просто читает данные.

В этом контракте всё просто: мы можем задать какое-то число и потом получить его. Такой код можно развернуть в блокчейне, и он всегда будет там работать так, как запрограммировано.

Смарт-контракты — это мощный инструмент, который можно использовать для автоматизации действий, которые раньше требовали доверия к третьим лицам. Хочешь отправить средства по расписанию? Или обеспечить, чтобы сделка произошла только при определённых условиях? Всё это можно сделать через смарт-контракт. Это не только экономит время, но и делает процесс прозрачным и надёжным.

, ,

14 августа, 2024

Организация автодиплоя с BitBucket в WordPress

Доработка моего блога пошла быстрее и файлики стало неудобно заливать по штучно через ssh поэтому пришло время настроить автодеплой. В своих разработках я использую чаще всего git на Bitbucket.

Сделать автодеплой для связки Bitbucket+Wordpress не состовляет большого труда. Далее в статье я покажу как это достаточно просто можно организавать.

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

$ git clone git@bitbucket.org:<repository>
$ echo 'www/wp-config.php' >> .gitignore
$ echo '.env' >> .gitignore
$ git add *
$ git push 

Теперь переходим на сервер на котором планируем осуществлять автодеплой. Нам потребуется создать публичный ключ ssh для пользователя от которого будет осуществляться автодеплой ( он же должен быть владельцем файлов сайта на сервере ). Для моего сайта таким пользователем является пользователь www-data, но у него нет shell поэтому генерацию ключей нужно будет осуществить при помощи команды sudo

$ sudo -u www-data ssh-keygen -t rsa

Нажимаем Enter на все вопросы и далее копируем наш публичный ключ для того чтобы вставить его в настройки репозитория на битбаките

$ cat <dir_home_user_www-data>/.ssh/id_rsa.pub

Копируем в буфер обмена то что отобразилось и идем на битбакет с этим


Переходим в раздел Ключи доступа в настройках репозитория нашего сайта

Нажимаем Add key

Называем наш ключ доступа и заполняем нашим публичным ключем, который скопировали ранее

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

Жамкаем на добавление веб-хука

Заполняем название веб-хука
Обязательно указываем адрес к нашему скрипту автодеплоя
Выбираем триггером PUSH событие ( наш скрипт будет вызываться когда в Битбакет будет запушены изменения ) и не забываем проставить статус активности веб-хука


Вот и все, теперь переходим к созданию скрипта деплоя.

<?php

$root_dir = realpath(exec('pwd').'/..');
$result = exec(sprintf('cd %s ; git fetch ; git pull', $root_dir));

После изменений внесенных в код необходимо закомитить и запушить наш скрипт в репозиторий.

Теперь мы можем выкачать репозиторий с сайтом на наш удаленный сервер.
Делаем клон рядом с нашей директорией на которую указывает настройки http сервера.
Чаще всего это /var/www

$ cd /var/www
$ sudo -u www-data git clone git@bitbucket.org:wikide/killercoder.git killercoder_git 

И переименовываем директории

$ mv killercoder killercoder_old ; mv killercoder_git killercoder

Теперь мы имеем рабочий сайт, который подключен к репозиторию
И при выполнение команды git push в ветку main будет происходить автоматический деплой на боевом сервере.

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

А если остались вопросы, то можете писать комментарии под статьей или писать мне сразу в теолеграм. Так же если вам нужна поддержка или разработка сайтов на WordPress, написание плагинов или любая помощь по вашему сайту на WordPress, то можете писать мне сразу в телеграм, а так же присоединяйтесь к каналу в телеграм чтобы следить за обновлениями на сайте.

Что такое блокчейн

,

28 июля, 2024

Что такое блокчейн

Блокчейн — это особый вид базы данных. Но в отличие от обычных баз данных, информация в блокчейне хранится не в одном месте, а в виде «цепочки блоков» на множестве компьютеров одновременно. Это делает блокчейн децентрализованным и более защищённым от изменений или взломов.

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

Область применения блокчейна:

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

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

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

Так же технология блокчейна лежит в основе новой парадигмы интернета под Web3

,

Что такое web3

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

Другими словами, web3 — это новая эра интернета, которая использует блокчейн и децентрализованные технологии для создания более прозрачного, безопасного и пользователь-ориентированного интернета. Если Web1 был статичным и информативным, а Web2 — интерактивным и социальным, то Web3 делает упор на децентрализацию и контроль пользователей над своими данными.

Уже сейчас существуют приложения и сервисы, которые успешно работают в парадигме web3, вот некоторые из них:

IPFS (InterPlanetary File System): Протокол для децентрализованного хранения и передачи данных. IPFS позволяет хранить файлы распределённо по многим компьютерам, делая их доступными и надёжными.

Ethereum Name Service (ENS): Децентрализованная система для регистрации доменных имен в блокчейне Ethereum. ENS позволяет привязывать длинные и сложные адреса кошельков к простым и запоминающимся именам.

Minds: Децентрализованная социальная сеть, которая поощряет свободу слова и приватность. Пользователи могут зарабатывать токены за создание и распространение контента.

MakerDAO: Децентрализованная автономная организация, которая управляет стейблкоином DAI. Пользователи могут заложить свои криптовалюты в смарт-контракт, чтобы создать DAI, который привязан к доллару США.

А так же множество других разнобраных сервисов и децентрализованных приложений.

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

Подписывайтесь на канал в телеграме, чтобы следить за обновлениями на сайте. Будем вместе разбираться в таинственном и прекрасном мире web3 =)

28 января, 2013

Ошибка ld: symbol(s) not found for architecture x86_64

При попытке собрать php-5.2.10 на macOS 10.8.2, появляется ошибка ld: symbol(s) not found for architecture x86_64.

Решить проблему можно следующем образом:

1) добавляем в Makefile строку

EXTRA_CFLAGS=-lresolv

2) меняем в ext/iconv/iconv.c

#define iconv libiconv to #define iconv iconv

После этого php собирается отлично и без проблем.

28 декабря, 2012

Выравнивание дива по вертикали и горизонтали

Иногда бывает нужно отцентрировать div на странице, это достаточно просто сделать через абсолютное позиционирование:

<!DOCTYPE html>
<html>
<head>
    <style type="text/css">
        div {
            background-color: #000;
            height: 500px;
            left: 50%;
            margin: -250px 0 0 -250px;
            top: 50%;
            position: absolute;
            width: 500px;
        }
    </style>
</head>
<body>
<div></div>
</body>
</html> 

Это создаст квадрат Малевича 500×500 пикселей по центу страницы.

14 октября, 2012

Отрывок из книги Сергея Тормашева «Наследие»

Даже волки, преследуя стадо оленей и пожирая слабых и плохо приспособленных, убивали лишь следствие. ГМО же боролось с самой сутью проблемы — уничтожала стадо по генетическому принципу. Ты не хочешь заботиться о себе и будущем своих детей? Тебе наплевать, что происходит с планетой и какая экология тебя окружает? Тебя не интересует, что ты ешь, пьешь, вдыхаешь? У тебя не хватает мозгов заработать достаточно денег на покупку чистой пищи в магазинах МАГБ? Тогда ГМО для тебя, добро пожаловать в фаст-фуд. Ешь на здоровье, и природа вздохнет спокойно — твои дети родятся нежизнеспособными и не дадут потомства. После твоей смерти уже никто не передаст следующему поколению твои гены тупоумия и недалекости. Вот что такое естественный отбор по Уэйну! Да будет так, и так будет!

25 декабря, 2010

Скругление углов на PHP / GD

<?php

$filename = 'image.jpg';
$radius = 15;

/**
 * Чем выше rate, тем лучше качество сглаживания и больше время обработки и
 * потребление памяти.
 *
 * Оптимальный rate подбирается в зависимости от радиуса.
 */
$rate = 3;

$img = imagecreatefromstring(file_get_contents($filename));
imagealphablending($img, false);
imagesavealpha($img, true);

$width = imagesx($img);
$height = imagesy($img);

$rs_radius = $radius * $rate;
$rs_size = $rs_radius * 2;

$corner = imagecreatetruecolor($rs_size, $rs_size);
imagealphablending($corner, false);

$trans = imagecolorallocatealpha($corner, 255, 255, 255, 127);
imagefill($corner, 0, 0, $trans);

$positions = array(
    array(0, 0, 0, 0),
    array($rs_radius, 0, $width — $radius, 0),
array($rs_radius, $rs_radius, $width — $radius, $height — $radius),
array(0, $rs_radius, 0, $height — $radius),
);

foreach ($positions as $pos) {
    imagecopyresampled($corner, $img, $pos[0], $pos[1], $pos[2], $pos[3], $rs_radius, $rs_radius, $radius, $radius);
}

$lx = $ly = 0;
$i = —$rs_radius;
$y2 = —$i;
$r_2 = $rs_radius * $rs_radius;

for (; $i <= $y2; $i++) {

    $y = $i;
    $x = sqrt($r_2 — $y * $y);

$y += $rs_radius;
$x += $rs_radius;

imageline($corner, $x, $y, $rs_size, $y, $trans);
imageline($corner, 0, $y, $rs_size — $x, $y, $trans);

$lx = $x;
$ly = $y;
}

foreach ($positions as $i => $pos) {
    imagecopyresampled($img, $corner, $pos[2], $pos[3], $pos[0], $pos[1], $radius, $radius, $rs_radius, $rs_radius);
}

header(‘Content - Type: image / png’);
imagepng($img);

18 декабря, 2010

И снова fluxbox

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

Для начала обнаружил, что после перехода у меня слетела возможность переключаться на русский язык.
Это показалось странным так как setxkbmap у меня запускался в .xsession, но как я понял после запуска fluxbox
любые команды прописанные в startup игнорируются, поэтому прописал

<code>setxkbmap -layout us,ru -variant ,winkeys -option </code>
<code>grp:caps_toggle,grp_led:scroll,terminate:ctrl_alt_bksp,compose:ralt</code>


в файл .fluxbox/startup перед командой запуска fluxbox

<br><code>exec fluxbox</code><br>

Прописал так же в этом же файле запуск коньков

<br><code>conky&amp;</code>

Туда же добавляем обои рабочего стола, закидываем обои куда-нибудь в .fluxbox/bg/ и прописываем путь к обоене. В качестве обоены я решил использовать няшку из манги с тату-логотипом арчилинукса %))
Например вот так:

<br><code>fbsetbg -f bg/archMangaBabe.jpg</code><br>

Название виртуальных столов в панели — «Рабочий стол <N>» смотрится уныло и слишком длинно, поэтому решил поправить название на D<N>, правится это в файле .fluxbox/init:

<br><code>session.screen0.workspaceNames: D1,D2,D3,D4</code>


Можно немного сэкономить место на экране и сделать автоскрытие тулбара

<br><code>session.screen0.toolbar.autoHide: true</code>


Так как экран на нетбуке маленький, то удобно когда в тулбаре показывается как можно больше открытых приложений, так что изменил ширину тулбара с 70 на 80

session.screen0.toolbar.widthPercent: 80


Редактим .fluxbox/menu и добавляем то что хотим видеть в меню, а так же убираем ненужные пункты, у меня получилось что-то вроде этого:

[begin] (Trinity)
[encoding] {UTF-8}
[exec] (Terminal) {terminal}
[separator]
[exec] (Mc) {mc}
[exec] (Thunar) {thunar}
[separator]
[exec] (Eclipse) {eclipse}
[separator]
[exec] (Firefox) {firefox}
[separator]
[exec] (Climm) {terminal -e climm}
[exec] (Skype) {skype}
[separator]
[exec] (Moc) {terminal -e mocp}
[exec] (Alsamixer) {terminal -e alsamixer}
[exec] (Alsa reload) {terminal -e sudo alsactl restore}
[separator]
[exec] (Gimp) {gimp}
[separator]
[submenu] (System Tools)
[exec]
 (top) {xterm}
[exec]
 (top) {xterm -e top}
[separator]
[end]
[submenu] (Fluxbox menu)
[config] (Configure)
[submenu] (System Styles) {Choose a style...}
[stylesdir] (/usr/share/fluxbox/styles)
[end]
[submenu] (User Styles) {Choose a style...}
[stylesdir] (~/.fluxbox/styles)
[end]
[workspaces] (Workspace List)
[commanddialog] (Fluxbox Command)
[reconfig] (Reload config)
[exec] (About) {(fluxbox -v; fluxbox -info | sed 1d) | xmessage -file - -center}
[end]
[separator]
[exec] (Xlock) {xlock -mode blank}
[separator]
[restart] (Restart)
[exit] (Exit)
[endencoding]
[end]

,

17 июля, 2010

javascript как узнать все свойства объекта

Небольшая функция на javascript, которая позволяет узнать все свойства объекта

Вот сама функция:

function fnShowProps(obj, objName) {
    var result = "";
    for (var i in obj) // обращение к свойствам объекта по индексу
        result += objName + "." + i + " = " + obj[i] + "\n";
    document.write(result);
}

Вот пример исползования:

fnShowProps(window.location, "location")

Результат:

location.pathname = /JavaScript/
location.protocol = http:
location.search = ?8
location.hash =
location.hostname = htmlcssjs.ru
location.href = http://htmlcssjs.ru/JavaScript/?8
location.host = htmlcssjs.ru
location.port =
location.reload = function reload() { [native code] }
location.replace = function replace() { [native code] }
location.assign = function assign() { [native code] }

Источник: http://htmlcssjs.ru/JavaScript/?8

 

,

foreach в javascript

Во несколько способов реализации foreach в javascript

Вариант 1:

for (var key in some_array) {
            var val = some_array [key];
	    alert (key+' = '+val);	
}

Вариант 2:

for(i=0, c=arr.length; i&lt;c; i++) {
	my_func(arr[i]);
}

Нужно отметить, что второй вариант не совсем реализует foreach, так как перебираются только значения массива без ключей.

15 июля, 2010

Немного об svn

Вот небольшой мануал по использованию svn

Создать репозитарий можно вот так:

$ svnadmin create new_repo

Настраиваем svn вот так:
Идем в new_repo/conf и открываем в любимом редакторе файл svnserve.conf.
В нём мне пригодилось исправить только секцию [general] вот так:

[general]<br>anon-access = none<br>password-db = passwd

anon-access = none — этим сообщаем, что анонимный доступ нужно запретить
password-db = passwd — этим сообщаем, что пароли и логины пользователей svn находится в файле passwd

Файл passwd правим таким образом:

[users]<br>user = password


Запуск серванта svn в FreeBSD:
Если уже запущен, то убиваем процесс (скорее всего прекращать работу сервера через killall -9 не совсем правильно, да простит меня Джа)

$ killall -9 svnserve<br>$ svnserve -d -r ./new_repo

Чекаем свой проджект вот так:

$ svn co svn://my_name_user@host_svn/new_repo project_dir

my_name_user — пользователь svn
host_svn — хост с svn
new_repo — наша директория с репозитарием
project_dir — локальная папка проекта

Далее svn спросит пароль, имя ползователя и возможно задаст ещё пару вопросов, отвечаем..
Если всё правильно, то svn выдаст сообщение типа — Checked out revision n,
где n — номер версии (если репозитарий чекается первый раз, то версия будет 0)

Далее добавляем файлы своего проекта в папку проекта (project_dir) и делаем вот так :

$ svn add * Отправляем обновление на svn сервер:
$ svn commit -m "Добавляем файло в нашу репу ;) "

Вот и все! Кратко, дёшево и сердито, как и должно быть у бадлокодера %)))

З.Ы. Не забывайте про руководства svn и google! Всем удачи!

9 июля, 2010

Немного о шифровании

Шифрование

Если нужно зашифровать отдельный файл (к примеру архив или документ) — можно воспользоваться утилитой openssl.
Шифрование файла file будет выглядеть так:

$ openssl enc -e -aes-256-cbc -k ПАРОЛЬ -in ./file -out ./file.encoded

или так:

$ cat ./file | openssl enc -e -aes-256-cbc -k ПАРОЛЬ &gt; file.encoded

Параметр -k и пароль можно не указывать, тогда он будет запрошен во время выполнения команды.

вот ещё варианты:

$ openssl aes-128-cbc -salt -in file -out file.aes
$ openssl aes-128-cbc -d -salt -in file.aes -out file

Дешифрование

Расшифровать обратно файл можно будет командой:

<span style="font-family: monospace;">$ </span>openssl enc -d -aes-256-cbc -k ПАРОЛЬ -in ./file -out ./file.encoded

(параметр -e меняется на -d) ну или соответственно:

$ cat ./file.encoded | openssl enc -d -aes-256-cbc -k ПАРОЛЬ &gt; ./file

Параметр -k и пароль можно не указывать, тогда он будет запрошен во время выполнения команды.

Комбинирование (Создание шифрованого архива, разбиение на тома)

Естественно команды можно комбинировать, и к примеру создание архива директории dir со сжатием gzip и шифрованием openssl aes будет выглядеть так:

$ tar -czf - ./dir | openssl enc -e -aes-256-cbc -k ПАРОЛЬ > archive.tar.gz.encoded

Рашифровываем (в обратном порядке):

$ openssl enc -d -aes-256-cbc -in ./archive.tar.gz.encoded | tar -xz

Плюс если шифрованный архив надо разбить на куски — добавляем split, все ограничивается только вашей фантазией :)

$ tar -czf - ./dir | openssl enc -e -aes-256-cbc -k ПАРОЛЬ | split -db 4M - arc

Склеиваем, дешифруем, разжимаем, разворачиваем:

$ cat arc* | openssl enc -d -aes-256-cbc | tar -xzf - 

Шифрование GPG

GnuPG очень известный способ шифрования и подписи электронных писем или других данных, кроме того gpg предоставляет расширенную систему управления ключами. В данных примерах рассматривается только шифрование файлов
Самым простым является симметричный шифр. В этом случае файл шифруется с помощью пароля, соответственно расшифровать его може тот, кто знает этот пароль, никаких ключей не требуется. Gpg добавляет расширение «*.gpg» к имени зашифрованного файла.

$ gpg -c file                        # Зашифровать файл по паролю
$ gpg file.gpg                       # Расшифровать файл ( -o другой файл) 

19 июня, 2010

Отрывок из книге Ф.Г. Углова — «В ПЛЕНУ ИЛЛЮЗИЙ»

Нашел интересный отрывок из книге Ф.Г. Углова — В ПЛЕНУ ИЛЛЮЗИЙ». Вообще если будет время и желание обязательно напишу об этом человеке, а пока хочу представить отрывок из его книге для тех людей которые попали под промывку мозгов о том, что пьянство — это то что в России было всегда и естественно для нашей Родины. ( в числе тех кому промыли мозги по поводу истории употребления алкоголя у нас в стране оказался и я сам, поэтому собсвенно меня и заинтересовали подобные факты из книге )

Отрывок из книге Ф.Г. Углова — «В ПЛЕНУ ИЛЛЮЗИЙ»

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

Что можно сказать по этому поводу?

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

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

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

В течение многих веков наш народ, истекая кровью, вел круговую оборону, отстаивая свою независимость. По 40-50 лет в столетие он находился в состоянии войны, и мирная жизнь была для него лишь короткой передышкой. В целом для России XIII-XVIII веков состояние мира было скорее исключением, а война — жестоким правилом. Воевать приходилось и на северо-западе, и на западе, и на южных, юго-восточных и восточных границах. В таких условиях требовалось невиданное напряжение сил всего народа, и именно поэтому в нашей стране намного позднее других стран потребление спиртных напитков получает широкое распространение.

Утверждение о том, что потребление опьяняющих напитков известно давно, верно, однако никогда это потребление не достигало таких размеров, как в последние два столетия, ибо до этого времени хмельные напитки изготовлялись в слабой концентрации, кустарно. Фабричное производство чистого спирта, а вместе с ним и потребление крепких напитков, получило широкое распространение лишь с начала 19-го столетия. Последнее обстоятельство и оказало огромное влияние на степень и быстроту распространения пьянства во всем мире и в нашей стране.

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

9 февраля, 2010

На сайте заработал раздел ‘Кодинг-медитация’

[announce]По мере возможностей буду выкладывать в раздел то что у меня накодилось за время функционирования. Начну с класса на php, который был написан одним из первых. Думаю в ближайшем будущем выложить самописный класс с пэджлистером и частично сворованные класы [/announce]
По мере возможностей буду выкладывать в раздел то что у меня накодилось за время функционирования. Начну с класса на php, который был написан одним из первых. Думаю в ближайшем будущем выложить самописный класс с пэджлистером и частично сворованные класы шаблонизатора и работы с мускулом.
Ссылка на раздел http://killercoder.ru/coding/

14 января, 2010

Сказка о драконе и воине

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

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

И начал Воин жить с девушкой. Прекрасно они жили: утром вместе встречали Солнышко, а по ночам вместе разговаривали со звездами. Всё было бы хорошо, если бы не жил по соседству тиран страшный и не было бы у этого тирана армии жестокой, которая грабила и подчиняла себе людей.

Как-то весенним утром, когда солнышко только начало согревать землю своим теплом, пришли в дом к девушке всадники тирана, все в черных доспехах с эмблемой дракона на шлемах. Солдаты привыкли, что им всё дозволено, и никто им не может ничего запретить. Они решили воспользоваться небесной красотой девушки, пока Воин был на охоте. Но девушка не разрешила к себе прикоснуться, за что ее убили, а дом подожгли.

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

Два дня и две ночи Воин лежал рядом с могилой девушки, а на третью ночь сердце воина покрылось мраком. В один миг Воин перестал ощущать жалость и сострадание к людям. Это был самый страшный день в этом Мире, так как солнечное небо заволокло тучами в тот миг. По следам Воин нашел путь к замку, нашел всё необходимое, продумал, как свергнет и убьет тирана, а вместе с ним и всех его подданных. Так и сделал.

Долго времени понадобилось Воину на осуществление своего плана, но так и было, как он задумал. Только с каждой новой смертью, с каждой новой каплей крови, сердце Воина становилось темнее. Настал момент, когда перестали с ним говорить звезды и здороваться Солнышко по утрам, так как всё небо заволокло темными черными тучами. Сам Воин перестал существовать, а вместо него появился страшный дракон, сильный, могущественный и безжалостный. У дракона этого появился свой замок на том месте, где раньше был замок тирана, и армия со всадниками, которые были еще сильнее и могущественнее, чем всадники тирана. Всадники занимались грабежами и подчиняли себе людей, так как им было дозволено всё.

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

Философ заговорил первым: «Знаю, кем был ты когда-то, и знаю, кто ты есть сейчас и почему стал таким». Дракон удивился такой дерзости и сказал: «Не можешь ты знать, кто я, старик, и не можешь знать моего пути, потому что кто и знал об этом, того уже нет на этом свете, а кто пытался узнать, того я лично своими руками лишил жизни. Ты, видно, с ума сошел от своих странствий, раз смеешь у меня в замке так дерзить мне». Но старик выслушал дракона и без страха продолжил: «Я знаю, что когда-то не было дракона, а был Воин с сердцем, как чистый родник, и умело это сердце разговаривать со звездами, и здоровалось с ним Солнышко каждое утро. Любило это сердце девушку небесной красоты, но сломило сердце жестокость человеческая, и умер воин, а вместо него появился дракон, который своей жестокостью и беспощадностью наводит страх на людей».

Дракон, услышав такое, пришел в ярость: «Как ты смеешь говорить мне такое! Я лично убью тебя сейчас!». С этими словами, вынув из ножен меч, дракон кинулся на философа. Старик поднял руку навстречу, и всё перед драконом застыло в один миг. Только слова философа прозвучали в его ушах: «Я дам тебе еще один шанс, и исход битвы будет зависеть только от тебя». С этими словами дракон забыл всё, что помнил, и в тот же миг Воин открыл глаза на поляне с чудесными травами и прекрасными цветами…