Files
sam-forwarder/config/reduceclose.go
2019-08-31 03:02:13 -04:00

132 lines
3.7 KiB
Go

package i2ptunconf
// GetReduceOnIdle takes an argument and a default. If the argument differs from the
// default, the argument is always returned. If the argument and default are
// the same and the key exists, the key is returned. If the key is absent, the
// default is returned.
func (c *Conf) GetReduceOnIdle(arg, def bool, label ...string) bool {
if arg != def {
return arg
}
if c.Config == nil {
return arg
}
if x, o := c.GetBool("i2cp.reduceOnIdle", label...); o {
return x
}
return arg
}
// GetReduceIdleTime takes an argument and a default. If the argument differs from the
// default, the argument is always returned. If the argument and default are
// the same and the key exists, the key is returned. If the key is absent, the
// default is returned.
func (c *Conf) GetReduceIdleTime(arg, def int, label ...string) int {
if arg != def {
return arg
}
if c.Config == nil {
return arg
}
if x, o := c.GetInt("i2cp.reduceIdleTime", label...); o {
return x
}
return arg
}
// GetReduceIdleQuantity takes an argument and a default. If the argument differs from the
// default, the argument is always returned. If the argument and default are
// the same and the key exists, the key is returned. If the key is absent, the
// default is returned.
func (c *Conf) GetReduceIdleQuantity(arg, def int, label ...string) int {
if arg != def {
return arg
}
if c.Config == nil {
return arg
}
if x, o := c.GetInt("i2cp.reduceIdleQuantity", label...); o {
return x
}
return arg
}
// GetCloseOnIdle takes an argument and a default. If the argument differs from the
// default, the argument is always returned. If the argument and default are
// the same and the key exists, the key is returned. If the key is absent, the
// default is returned.
func (c *Conf) GetCloseOnIdle(arg, def bool, label ...string) bool {
if arg != def {
return arg
}
if c.Config == nil {
return arg
}
if x, o := c.GetBool("i2cp.closeOnIdle", label...); o {
return x
}
return arg
}
// GetCloseIdleTime takes an argument and a default. If the argument differs from the
// default, the argument is always returned. If the argument and default are
// the same and the key exists, the key is returned. If the key is absent, the
// default is returned.
func (c *Conf) GetCloseIdleTime(arg, def int, label ...string) int {
if arg != def {
return arg
}
if c.Config == nil {
return arg
}
if x, o := c.GetInt("i2cp.closeIdleTime", label...); o {
return x
}
return arg
}
// SetReduceIdle sets the config to reduce tunnels after idle time from config file
func (c *Conf) SetReduceIdle(label ...string) {
if v, ok := c.GetBool("i2cp.reduceOnIdle", label...); ok {
c.ReduceIdle = v
} else {
c.ReduceIdle = false
}
}
// SetReduceIdleTime sets the time to wait before reducing tunnels from config file
func (c *Conf) SetReduceIdleTime(label ...string) {
if v, ok := c.GetInt("i2cp.reduceIdleTime", label...); ok {
c.ReduceIdleTime = v
} else {
c.ReduceIdleTime = 300000
}
}
// SetReduceIdleQuantity sets the number of tunnels to reduce to from config file
func (c *Conf) SetReduceIdleQuantity(label ...string) {
if v, ok := c.GetInt("i2cp.reduceQuantity", label...); ok {
c.ReduceIdleQuantity = v
} else {
c.ReduceIdleQuantity = 3
}
}
// SetCloseIdle sets the tunnel to automatically close on idle from the config file
func (c *Conf) SetCloseIdle(label ...string) {
if v, ok := c.GetBool("i2cp.closeOnIdle", label...); ok {
c.CloseIdle = v
} else {
c.CloseIdle = false
}
}
// SetCloseIdleTime sets the time to wait before killing a tunnel from a config file
func (c *Conf) SetCloseIdleTime(label ...string) {
if v, ok := c.GetInt("i2cp.closeIdleTime", label...); ok {
c.CloseIdleTime = v
} else {
c.CloseIdleTime = 300000
}
}