1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
/*
* This file is part of the go-nft project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Copyright 2021 Red Hat, Inc.
*
*/
package nft
import (
"github.com/networkplumbing/go-nft/nft/schema"
)
type ChainType string
type ChainHook string
type ChainPolicy string
// Chain Types
const (
TypeFilter ChainType = schema.TypeFilter
TypeNAT ChainType = schema.TypeNAT
TypeRoute ChainType = schema.TypeRoute
)
// Chain Hooks
const (
HookPreRouting ChainHook = schema.HookPreRouting
HookInput ChainHook = schema.HookInput
HookOutput ChainHook = schema.HookOutput
HookForward ChainHook = schema.HookForward
HookPostRouting ChainHook = schema.HookPostRouting
HookIngress ChainHook = schema.HookIngress
)
// Chain Policies
const (
PolicyAccept ChainPolicy = schema.PolicyAccept
PolicyDrop ChainPolicy = schema.PolicyDrop
)
// NewRegularChain returns a new schema chain structure for a regular chain.
func NewRegularChain(table *schema.Table, name string) *schema.Chain {
return NewChain(table, name, nil, nil, nil, nil)
}
// NewChain returns a new schema chain structure for a base chain.
// For base chains, all arguments are required except the policy.
// Missing arguments will cause an error once the config is applied.
func NewChain(table *schema.Table, name string, ctype *ChainType, hook *ChainHook, prio *int, policy *ChainPolicy) *schema.Chain {
c := &schema.Chain{
Family: table.Family,
Table: table.Name,
Name: name,
}
if ctype != nil {
c.Type = string(*ctype)
}
if hook != nil {
c.Hook = string(*hook)
}
if prio != nil {
c.Prio = prio
}
if policy != nil {
c.Policy = string(*policy)
}
return c
}
|