цели | использование | изменения
Простые служебные функции для сравнения и синхронизации локальных файлов с корзинами S3.
[confetti/s3-deploy " 0.1.4 " ] ; ; latest release
Большинство функций, которые являются частью общедоступного API этой библиотеки, работают с простыми картами, такими как следующие, которые также называются file-maps
:
{ :s3-key " desired/destination/file.txt "
:file #object[java.io.File " file.txt.gz " ]
:metadata { :content-encoding " gzip " }}
Используя file-maps
мы отделяем структуру файловой системы от структуры, которую мы в конечном итоге хотим достичь в нашей целевой корзине S3.
По умолчанию метаданные
:content-type
получаются из расширения значения, которое вы указали как:s3-key
.
Синхронизация возможна через confetti.s3-deploy/sync!
:
( confetti.s3-deploy/sync! creds bucket-name file-maps)
Для создания file-maps
из каталога эта библиотека включает в себя крошечный вспомогательный dir->file-maps
, который будет генерировать карты файлов:
( dir->file-maps ( io/file " src " ))
; ;=> [{:s3-key "confetti/s3_deploy.clj",
; ; :file #object[java.io.File 0x4795c68f "/Users/martin/code/confetti-s3-deploy/src/confetti/s3_deploy.clj"]}]
В зависимости от вашего варианта использования вы захотите создать свою собственную функцию создания file-maps
. Также доступны функции более низкого уровня:
( confetti.s3-deploy/diff* bucket-objects file-maps)
Может использоваться для получения различий между объектами сегментов и заданной коллекцией file-maps
.
( confetti.s3-deploy/calculate-ops bucket-objects file-maps)
Возвращает вектор операций, необходимых для синхронизации сегмента с предоставленными file-maps
.
Для более подробной информации проверьте реализацию.
s3-deploy
предоставляет API высокого уровня, что делает его привлекательным для задач CLI. Вот минимальный пример:
; ; cat deploy.clj
( require '[confetti.s3-deploy :as s3]
'[clojure.java.io :as io])
( def dir-to-sync ( io/file " public " ))
( s3/sync!
{ :access-key ( System/getenv " AWS_ACCESS_KEY " )
:secret-key ( System/getenv " AWS_SECRET_KEY " )}
( System/getenv " S3_BUCKET_NAME " )
( s3/dir->file-maps dir-to-sync)
{ :dry-run? true
:report-fn ( fn [{ :keys [s3-key op]}]
( println op s3-key))})
Который можно запустить с помощью:
clj -Sdeps '{:deps {confetti/s3-deploy {:mvn/version "0.1.3"}}}' deploy.clj
Inst
relative-path
, чтобы она правильно работала в Windows. (#16)