Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
7652f86c
提交
7652f86c
authored
10月 09, 2014
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixed a parsing bug on Version.CheckPeriod
And refactored a few names/comments
上级
16b53456
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
58 行增加
和
21 行删除
+58
-21
ipfs.go
cmd/ipfs/ipfs.go
+5
-3
config.go
config/config.go
+2
-0
version.go
config/version.go
+51
-18
没有找到文件。
cmd/ipfs/ipfs.go
浏览文件 @
7652f86c
...
...
@@ -120,16 +120,18 @@ func localNode(confdir string, online bool) (*core.IpfsNode, error) {
return
nil
,
err
}
if
cfg
.
Version
.
EligibleForUpdateCheck
()
{
if
cfg
.
Version
.
ShouldCheckForUpdate
()
{
obsolete
:=
updates
.
CheckForUpdates
()
if
obsolete
!=
nil
{
if
cfg
.
Version
.
Check
==
config
.
CheckError
{
return
nil
,
obsolete
}
log
.
Warning
(
fmt
.
Sprintf
(
"%v"
,
obsolete
))
// when "warn" version.check mode we just show warning message
// when "warn" version.check mode we just show warning message
log
.
Warning
(
fmt
.
Sprintf
(
"%v"
,
obsolete
))
}
else
{
// update most recent check timestamp in config
c
fg
.
RecordCurrentUpdateCheck
(
filename
)
c
onfig
.
RecordUpdateCheck
(
cfg
,
filename
)
}
}
...
...
config/config.go
浏览文件 @
7652f86c
...
...
@@ -11,6 +11,8 @@ import (
u
"github.com/jbenet/go-ipfs/util"
)
var
log
=
u
.
Logger
(
"config"
)
// Identity tracks the configuration of the local node's identity.
type
Identity
struct
{
PeerID
string
...
...
config/version.go
浏览文件 @
7652f86c
package
config
import
"time"
import
(
"strconv"
"time"
)
// Version regulates checking if the most recent version is run
type
Version
struct
{
Check
string
// "ignore" for do not check, "warn" and "error" for reacting when obsolete
Current
string
// ipfs version for which config was generated
UpdateCheckedTime
time
.
Time
// timestamp for the last time API endpoint was checked for updates
UpdateCheckPeriod
time
.
Duration
// time duration over which the update check will not be performed
// Current is the ipfs version for which config was generated
Current
string
// Check signals how to react on updates:
// - "ignore" for not checking
// - "warn" for issuing a warning and proceeding
// - "error" for exiting with an error
Check
string
// CheckDate is a timestamp for the last time API endpoint was checked for updates
CheckDate
time
.
Time
// CheckPeriod is the time duration over which the update check will not be performed
// (Note: cannot use time.Duration because marshalling with json breaks it)
CheckPeriod
string
}
// supported Version.Check values
const
(
CheckError
=
"error"
// value for Version.Check to raise error and exit if version is obsolete
CheckWarn
=
"warn"
// value for Version.Check to show warning message if version is obsolete
CheckIgnore
=
"ignore"
// value for Version.Check to not perform update check
// CheckError value for Version.Check to raise error and exit if version is obsolete
CheckError
=
"error"
// CheckWarn value for Version.Check to show warning message if version is obsolete
CheckWarn
=
"warn"
// CheckIgnore value for Version.Check to not perform update check
CheckIgnore
=
"ignore"
)
var
defaultUpdateCheckPeriod
=
time
.
Hour
*
48
// defaultCheckPeriod governs h
var
defaultCheckPeriod
=
time
.
Hour
*
48
// EligibleForUpdateCheck returns if update check API endpoint is needed for this specific runtime
func
(
v
*
Version
)
EligibleForUpdateCheck
()
bool
{
if
v
.
Check
==
CheckIgnore
||
v
.
UpdateCheckedTime
.
Add
(
v
.
UpdateCheckPeriod
)
.
After
(
time
.
Now
())
{
func
(
v
*
Version
)
checkPeriodDuration
()
time
.
Duration
{
d
,
err
:=
strconv
.
Atoi
(
v
.
CheckPeriod
)
if
err
!=
nil
{
log
.
Error
(
"config.Version.CheckPeriod parse error. Using default."
)
return
defaultCheckPeriod
}
return
time
.
Duration
(
d
)
}
// ShouldCheckForUpdate returns if update check API endpoint is needed for this specific runtime
func
(
v
*
Version
)
ShouldCheckForUpdate
()
bool
{
period
:=
v
.
checkPeriodDuration
()
if
v
.
Check
==
CheckIgnore
||
v
.
CheckDate
.
Add
(
period
)
.
After
(
time
.
Now
())
{
return
false
}
return
true
}
// RecordCurrentUpdateCheck is called to record that update check was performed and showed that the running version is the most recent one
func
(
cfg
*
Config
)
RecordCurrentUpdateCheck
(
filename
string
)
{
cfg
.
Version
.
UpdateCheckedTime
=
time
.
Now
()
if
cfg
.
Version
.
UpdateCheckPeriod
==
time
.
Duration
(
0
)
{
// UpdateCheckPeriod was not initialized for some reason (e.g. config file used is broken)
cfg
.
Version
.
UpdateCheckPeriod
=
defaultUpdateCheckPeriod
// RecordUpdateCheck is called to record that an update check was performed,
// showing that the running version is the most recent one.
func
RecordUpdateCheck
(
cfg
*
Config
,
filename
string
)
{
cfg
.
Version
.
CheckDate
=
time
.
Now
()
if
cfg
.
Version
.
CheckPeriod
==
""
{
// CheckPeriod was not initialized for some reason (e.g. config file broken)
cfg
.
Version
.
CheckPeriod
=
strconv
.
Itoa
(
int
(
defaultCheckPeriod
))
}
WriteConfigFile
(
filename
,
cfg
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论