Наверняка вы замечали, что в Python есть удобная функция для получения переменной окружения
os.getenv(NAME)
И её "сестра" для создания или изменения переменных окружения
os.putenv(NAME, VALUE)
Но почему-то putenv() не работает как должно. Энвайромент не обновляется!
os.putenv('MYVAR', '1')
print(os.getenv('MYVAR'))
... и ничего 😴
Почему так?
На самом деле энвайромент обновляется, но это значение не добавляется в словарь os.environ.
Откройте исходник функции os.getenv(). Это просто шорткат для os.environ.get()
В то время как putenv() это built-in С-функция.
Словарь os.environ (или точней класс из MutableMapping) создаётся из энвайромента в момент инициализации. Функция putenv() самостоятельно его не изменяет.
В тоже время, когда вы создаёте или изменяете ключ в os.environ, автоматически вызывается putenv() в методе __setitem__().
То есть, технически putenv() всё делает верно, но в os.environ это не отражается. Можно проверить так:
>>> os.putenv('MYVAR', '123')
>>> os.system('python -c "import os;print(os.getenv(\'MYVAR\'))"')
123
Я объявил переменную в текущем процессе и вызвал дочерний процесс, который её унаследовал и получил в составе os.environ.
Аналогично при удалении переменной вызывается еще одна built-in функция unsetenv(), удаляющая переменную из системы.
Итого
▫️ Удобней всего явно обновлять переменные через os.environ
▫️ Есть способ неявно создать/удалить переменную через putenv/unsetenv, что не повлияет на os.environ но изменит энвайромент и передаст изменения сабпроцессам. Но так лучше не делать!
▫️os.environ это просто обертка для built-in функций putenv() и unsetenv().
#basic
🎯🎯Excellent 31% Profit on #DOT/USDT for all Premium Members
🚀🚀It has crossed all the targets
👁🗨Contact @futurechief to enter the premium group & make daily gains
🚀🚀Raining Profits in the Premium Group
🎯🎯#DOT/USDT has covered all the targets to give an amazing profit of 30% for all Premium Members
👁🗨Contact @futurechief to enter the premium group & make daily gains on Futures as well as Spot Market
🏦 Биржа Bybit отразила атаку с фейковыми депозитами на ~$1,000,000,000.
В Bybit сообщили о том, что остановили серию атак с поддельными депозитами сразу в нескольких сетях. Потенциальный ущерб мог превысить $1b в токенах #DOT, но ни один пользователь не пострадал.
▪Схема:
➥ Злоумышленники создавали транзакции, которые выглядели как успешные депозиты, хотя реальные средства НЕ поступали.
➥ Использовали батч-операции – часть переводов проходила, а часть специально завершалась с ошибкой.
➥ Также применяли многошаговые транзакции, создавая «иллюзию» поступления средств без роста баланса.
▪В чем проблема:
➥ Некоторые системы смотрят только на статус транзакции или логи и могут засчитать «фейковый» депозит как настоящий.
▪Как отбились:
➥ Bybit проверяет не просто транзакцию, а фактическое изменение баланса и разбирает каждую операцию внутри нее:
⊹ Анализ внутренних транзакций.
⊹ Разбор батчей по частям.
⊹ Проверка владельца и структуры аккаунтов.
⊹ Финальная валидация по реальному балансу.
Ранее: Bybit Card в России
Crypto Headlines
#DOT/USDT analysis -
#DOT is in a downtrend, forming lower lows (LLs) and lower highs (LHs). The price is currently experiencing a pullback and facing rejection from the resistance zone. It is expected that the price will decline from this point and revisit previous lows.
TF : 4h
Entry : $6.154
Target : $5.538
SL : $6.462