Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
9119435c
提交
9119435c
authored
12月 10, 2014
作者:
Matt Bell
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
cmd/ipfs: Added gateway server to daemon
上级
8603e829
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
51 行增加
和
3 行删除
+51
-3
daemon.go
cmd/ipfs/daemon.go
+51
-3
没有找到文件。
cmd/ipfs/daemon.go
浏览文件 @
9119435c
...
@@ -108,6 +108,13 @@ func daemonFunc(req cmds.Request) (interface{}, error) {
...
@@ -108,6 +108,13 @@ func daemonFunc(req cmds.Request) (interface{}, error) {
return
nil
,
err
return
nil
,
err
}
}
// ignore error for gateway address
// if there is an error (invalid address), then don't run the gateway
gatewayMaddr
,
_
:=
ma
.
NewMultiaddr
(
cfg
.
Addresses
.
Gateway
)
if
gatewayMaddr
==
nil
{
fmt
.
Println
(
"Invalid gateway address, not running gateway"
)
}
// mount if the user provided the --mount flag
// mount if the user provided the --mount flag
mount
,
_
,
err
:=
req
.
Option
(
mountKwd
)
.
Bool
()
mount
,
_
,
err
:=
req
.
Option
(
mountKwd
)
.
Bool
()
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -138,11 +145,14 @@ func daemonFunc(req cmds.Request) (interface{}, error) {
...
@@ -138,11 +145,14 @@ func daemonFunc(req cmds.Request) (interface{}, error) {
fmt
.
Printf
(
"IPNS mounted at: %s
\n
"
,
nsdir
)
fmt
.
Printf
(
"IPNS mounted at: %s
\n
"
,
nsdir
)
}
}
if
gatewayMaddr
!=
nil
{
listenAndServeGateway
(
node
,
gatewayMaddr
)
}
return
nil
,
listenAndServeAPI
(
node
,
req
,
apiMaddr
)
return
nil
,
listenAndServeAPI
(
node
,
req
,
apiMaddr
)
}
}
func
listenAndServeAPI
(
node
*
core
.
IpfsNode
,
req
cmds
.
Request
,
addr
ma
.
Multiaddr
)
error
{
func
listenAndServeAPI
(
node
*
core
.
IpfsNode
,
req
cmds
.
Request
,
addr
ma
.
Multiaddr
)
error
{
_
,
host
,
err
:=
manet
.
DialArgs
(
addr
)
_
,
host
,
err
:=
manet
.
DialArgs
(
addr
)
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
...
@@ -163,7 +173,7 @@ func listenAndServeAPI(node *core.IpfsNode, req cmds.Request, addr ma.Multiaddr)
...
@@ -163,7 +173,7 @@ func listenAndServeAPI(node *core.IpfsNode, req cmds.Request, addr ma.Multiaddr)
serverExited
:=
make
(
chan
struct
{})
serverExited
:=
make
(
chan
struct
{})
go
func
()
{
go
func
()
{
fmt
.
Printf
(
"
daemon
listening on %s
\n
"
,
addr
)
fmt
.
Printf
(
"
API server
listening on %s
\n
"
,
addr
)
serverError
=
server
.
ListenAndServe
(
host
,
mux
)
serverError
=
server
.
ListenAndServe
(
host
,
mux
)
close
(
serverExited
)
close
(
serverExited
)
}()
}()
...
@@ -176,9 +186,47 @@ func listenAndServeAPI(node *core.IpfsNode, req cmds.Request, addr ma.Multiaddr)
...
@@ -176,9 +186,47 @@ func listenAndServeAPI(node *core.IpfsNode, req cmds.Request, addr ma.Multiaddr)
case
<-
node
.
Closing
()
:
case
<-
node
.
Closing
()
:
log
.
Infof
(
"daemon at %s terminating..."
,
addr
)
log
.
Infof
(
"daemon at %s terminating..."
,
addr
)
server
.
Shutdown
<-
true
server
.
Shutdown
<-
true
<-
serverExited
// now, DO wait until server exit
s
<-
serverExited
// now, DO wait until server exit
}
}
log
.
Infof
(
"daemon at %s terminated"
,
addr
)
log
.
Infof
(
"daemon at %s terminated"
,
addr
)
return
serverError
return
serverError
}
}
func
listenAndServeGateway
(
node
*
core
.
IpfsNode
,
addr
ma
.
Multiaddr
)
error
{
_
,
host
,
err
:=
manet
.
DialArgs
(
addr
)
if
err
!=
nil
{
return
err
}
server
:=
manners
.
NewServer
()
mux
:=
http
.
NewServeMux
()
ifpsHandler
:=
&
ipfsHandler
{
node
}
mux
.
Handle
(
"/ipfs/"
,
ifpsHandler
)
done
:=
make
(
chan
struct
{},
1
)
defer
func
()
{
done
<-
struct
{}{}
}()
// go wait until the node dies
go
func
()
{
select
{
case
<-
node
.
Closed
()
:
case
<-
done
:
return
}
log
.
Infof
(
"terminating gateway at %s..."
,
addr
)
server
.
Shutdown
<-
true
}()
fmt
.
Printf
(
"Gateway listening on %s
\n
"
,
addr
)
go
func
()
{
if
err
:=
server
.
ListenAndServe
(
host
,
mux
);
err
!=
nil
{
log
.
Error
(
err
)
}
}()
return
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论