CAP_RIGHTS_LIMIT(2) | FreeBSD System Calls Manual | CAP_RIGHTS_LIMIT(2) |
名称
cap_rights_limit — ケーパビリティの権利を制限するライブラリ
Standard C Library (libc, -lc)解説
ファイル記述子が accept(2), accept4(2), fhopen(2), kqueue(2), mq_open(2), open(2), openat(2), pdfork(2), pipe(2), shm_open(2), socket(2) または socketpair(2) のような関数によって作成されるとき、すべてのケーパビリティの権利が割り当てられます。それらの権利は、 cap_rights_limit() システムコールを使用することによって縮小 (しかし、決して拡張されません) することができます。いったんケーパビリティの権利が縮小されると、ファイル記述子での操作は、 rights (権利) によって許可されたものに制限されます。rights 引数は、 cap_rights_init(3) 関数ファミリを使用して準備されるべきです。
ファイル記述子に割り当てられたケーパビリティの権利は、 cap_rights_get(3) 関数で取得することができます。
ケーパビリティの権利の完全なリストは、 rights(4) マニュアルページで見つけることができます。
戻り値
Upon successful completion, the value 0 is returned; otherwise the value -1 is returned and the global variable errno is set to indicate the error.使用例
次の例は、読み込みのみを許可するファイル記述子のケーパビリティの権利を制限する方法の実例の説明です。
cap_rights_t rights; char buf[1]; int fd; fd = open("/tmp/foo", O_RDWR); if (fd < 0) err(1, "open() failed"); if (cap_enter() < 0) err(1, "cap_enter() failed"); cap_rights_init(&setrights, CAP_READ); if (cap_rights_limit(fd, &setrights) < 0) err(1, "cap_rights_limit() failed"); buf[0] = 'X'; if (write(fd, buf, sizeof(buf)) > 0) errx(1, "write() succeeded!"); if (read(fd, buf, sizeof(buf)) < 0) err(1, "read() failed");
エラー
cap_rights_limit() は、次の場合以外成功します:- [ EBADF]
- fd 引数が、有効でアクティブな記述子ではありません。
- [ EINVAL]
- 無効の権利が、 rights で要求されました。
- [ ENOTCAPABLE]
- rights 引数が与えられたファイル記述子に存在しないケーパビリティの権利を含んでいます。ケーパビリティの権利のリストは、決して拡張されず、縮小することのみができます。
関連項目
accept(2), accept4(2), cap_enter(2), fhopen(2), kqueue(2), mq_open(2), open(2), openat(2), pdfork(2), pipe(2), read(2), shm_open(2), socket(2), socketpair(2), write(2), cap_rights_get(3), cap_rights_init(3), err(3), capsicum(4), rights(4)歴史
ケーパビリティとケーパビリティモードのサポートは、 TrustedBSD プロジェクトの一環として開発されました。作者
この関数は、FreeBSD 財団の資金提供の下で <pawel@dawidek.net>によって作成されました。February 23, 2013 | FreeBSD |