代码拉取完成,页面将自动刷新
同步操作将从 tupelo-shen/mysnapd 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
// -*- Mode: Go; indent-tabs-mode: t -*-
//go:build !nomanagers
// +build !nomanagers
/*
* Copyright (C) 2017-2022 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 configcore
import (
"fmt"
"strconv"
"time"
"gitee.com/mysnapcore/mysnapd/overlord/configstate/config"
"gitee.com/mysnapcore/mysnapd/overlord/devicestate"
"gitee.com/mysnapcore/mysnapd/strutil"
"gitee.com/mysnapcore/mysnapd/timeutil"
)
func init() {
supportedConfigurations["core.refresh.hold"] = true
supportedConfigurations["core.refresh.schedule"] = true
supportedConfigurations["core.refresh.timer"] = true
supportedConfigurations["core.refresh.metered"] = true
supportedConfigurations["core.refresh.retain"] = true
supportedConfigurations["core.refresh.rate-limit"] = true
}
func reportOrIgnoreInvalidManageRefreshes(tr config.Conf, optName string) error {
// check if the option is set as part of transaction changes; if not than
// it's already set in the config state and we shouldn't error out about it
// now. refreshScheduleManaged will do the right thing when refresh cannot
// be managed anymore.
for _, k := range tr.Changes() {
if k == "core."+optName {
return fmt.Errorf("cannot set schedule to managed")
}
}
return nil
}
func validateRefreshSchedule(tr config.Conf) error {
refreshRetainStr, err := coreCfg(tr, "refresh.retain")
if err != nil {
return err
}
if refreshRetainStr != "" {
if n, err := strconv.ParseUint(refreshRetainStr, 10, 8); err != nil || (n < 2 || n > 20) {
return fmt.Errorf("retain must be a number between 2 and 20, not %q", refreshRetainStr)
}
}
refreshHoldStr, err := coreCfg(tr, "refresh.hold")
if err != nil {
return err
}
if refreshHoldStr != "" && refreshHoldStr != "forever" {
if _, err := time.Parse(time.RFC3339, refreshHoldStr); err != nil {
return fmt.Errorf("refresh.hold cannot be parsed: %v", err)
}
}
refreshOnMeteredStr, err := coreCfg(tr, "refresh.metered")
if err != nil {
return err
}
switch refreshOnMeteredStr {
case "", "hold":
// noop
default:
return fmt.Errorf("refresh.metered value %q is invalid", refreshOnMeteredStr)
}
// check (new) refresh.timer
refreshTimerStr, err := coreCfg(tr, "refresh.timer")
if err != nil {
return err
}
if refreshTimerStr == "managed" {
st := tr.State()
st.Lock()
defer st.Unlock()
if !devicestate.CanManageRefreshes(st) {
return reportOrIgnoreInvalidManageRefreshes(tr, "refresh.timer")
}
return nil
}
if refreshTimerStr != "" {
// try legacy refresh.schedule setting if new-style
// refresh.timer is not set
if _, err = timeutil.ParseSchedule(refreshTimerStr); err != nil {
return err
}
}
// check (legacy) refresh.schedule
refreshScheduleStr, err := coreCfg(tr, "refresh.schedule")
if err != nil {
return err
}
if refreshScheduleStr == "" {
return nil
}
if refreshScheduleStr == "managed" {
st := tr.State()
st.Lock()
defer st.Unlock()
if !devicestate.CanManageRefreshes(st) {
return reportOrIgnoreInvalidManageRefreshes(tr, "refresh.schedule")
}
return nil
}
_, err = timeutil.ParseLegacySchedule(refreshScheduleStr)
return err
}
func validateRefreshRateLimit(tr config.Conf) error {
refreshRateLimit, err := coreCfg(tr, "refresh.rate-limit")
if err != nil {
return err
}
// reset is fine
if len(refreshRateLimit) == 0 {
return nil
}
if _, err := strutil.ParseByteSize(refreshRateLimit); err != nil {
return err
}
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。