extattr - filesystem extended attributes manipurator for Ruby
extattr is filesystem extended attributes manipurator for Ruby on FreeBSD, GNU/Linux and Microsoft Windows.
- Quick Reference (in Japanese)
- HISTORY (in Japanese)
extattr はファイルシステムの拡張属性を操作するライブラリで、FreeBSD、GNU/Linux、Windows に対応しています。
サポートされる環境で、統一的なメソッドを提供します。
実装については、以下のようになっています。
- FreeBSD: extattr (
extattr_list
,extattr_get
,extattr_set
,extattr_delete
) - GNU/Linux: xattr (
listxattr
,getxattr
,setxattr
,removexattr
) - Microsoft Windows: NTFS ADS (代替データストリーム) / 拡張ファイル属性 (
NtQueryEaFile
,NtSetEaFile
)
Tested system
- PC-BSD/AMD64 10.0
- lubuntu 13.10 (i386)
- Microsoft Windows XP Professional SP3
- Microsoft Windows 7 Professional SP1
GNU/Linux における特記事項
- GNU/Linux で利用されている名前空間〈security〉〈trusted〉には未対応です。
Microsoft Windows における特記事項
-
Windows XP 以降を必要とします。Win2k でも動作するかもしれません (未検証)。
Windows 9x シリーズではrequire "extattr"
の段階で例外が発生すると思われます (未検証)。 -
ExtAttr::USER
は (比較的よく利用される) NTFS ADS に対する操作で、ExtAttr::SYSTEM
が本来の (あまり利用されていない) 拡張ファイル属性に対する操作となります。 -
リパースポイント (ジャンクションやシンボリックリンク) に対する NTFS ADS は要素の取得や設定、削除は出来ません。
必ずリンク先に対する操作となります (やり方がわかりません)。 -
64 KiB を超える NTFS ADS は取得も設定も出来ません。
これは『拡張属性』と捉えた場合、巨大なデータを扱えるべきではないという考えによるためです (本当のところは FreeBSD の拡張属性が最大 64KiB 弱であることが由来です)。 -
巨大な NTFS ADS を扱いたい場合は、
File.open
でファイルとして扱えるので自由に読み書きできます。
これは Ruby に限ったことではなく、Windows による仕様です。
この場合の与えるファイル名は、path + ":" + name
という形になります。filepath = "sample.txt" extattrname = "category" ntfs_ads_name = filepath + ":" + extattrname File.open(ntfs_ads_name, "r") do |file| ... end
既知のバグ
-
extattr_list
のブロック内でextattr_set
extattr_delete
を行うと正確な列挙がされない場合がある解決方法:
extattr_set
かextattr_delete
のどちらかを同時に利用したい場合、extattr_list.each
を用いてください。
参考資料
- extattr
- xattr
- windows
- https://msdn.microsoft.com/en-us/library/cc232069.aspx
- https://undocumented.ntinternals.net/UserMode/Undocumented%20Functions/NT%20Objects/File/FILE_INFORMATION_CLASS.html
- https://undocumented.ntinternals.net/UserMode/Undocumented%20Functions/NT%20Objects/File/NtQueryInformationFile.html
- https://undocumented.ntinternals.net/UserMode/Undocumented%20Functions/NT%20Objects/File/NtQueryEaFile.html
- https://undocumented.ntinternals.net/UserMode/Undocumented%20Functions/NT%20Objects/File/NtSetEaFile.html
- FileTest http://www.zezula.net/en/fstools/filetest.html https://github.com/ladislav-zezula/FileTest
Specification
- package name: extattr
- Author: dearblue
- Version: 0.4
- Product quality: technical preview
- License: 2-clause BSD License
- Project page: https://github.com/dearblue/ruby-extattr
- Support Ruby: Ruby 2.5+