Ai
1 Star 0 Fork 1

mysnapcore/mysnapd

forked from tupelo-shen/mysnapd 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
seccomp.go 1.85 KB
一键复制 编辑 原始数据 按行查看 历史
tupelo-shen 提交于 2022-11-07 22:24 +08:00 . fix: sandbox commit
// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2018 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package seccomp
import (
"io/ioutil"
"sort"
"strings"
"sync"
)
var secCompProber = &secCompProbe{}
// Actions returns a sorted list of seccomp actions like
// []string{"allow", "errno", "kill", "log", "trace", "trap"}.
func Actions() []string {
return secCompProber.actions()
}
func SupportsAction(action string) bool {
actions := Actions()
i := sort.SearchStrings(actions, action)
if i < len(actions) && actions[i] == action {
return true
}
return false
}
// probing
type secCompProbe struct {
probedActions []string
once sync.Once
}
func (scp *secCompProbe) actions() []string {
scp.once.Do(func() {
scp.probedActions = probeActions()
})
return scp.probedActions
}
var ioutilReadFile = ioutil.ReadFile
func probeActions() []string {
contents, err := ioutilReadFile("/proc/sys/kernel/seccomp/actions_avail")
if err != nil {
return []string{}
}
actions := strings.Split(strings.TrimRight(string(contents), "\n"), " ")
sort.Strings(actions)
return actions
}
// mocking
func MockActions(actions []string) (restore func()) {
old := secCompProber
secCompProber = &secCompProbe{
probedActions: actions,
}
secCompProber.once.Do(func() {})
return func() {
secCompProber = old
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/mysnapcore/mysnapd.git
git@gitee.com:mysnapcore/mysnapd.git
mysnapcore
mysnapd
mysnapd
v0.1.0

搜索帮助