Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
36bdc456
提交
36bdc456
authored
10月 24, 2014
作者:
Matt Bell
提交者:
Juan Batiz-Benet
11月 14, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
commands/http: Moved HTTP RPC into commands/http package
上级
201ad30a
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
5 行增加
和
67 行删除
+5
-67
ipfs.go
cmd/ipfs/ipfs.go
+5
-67
没有找到文件。
cmd/ipfs/ipfs.go
浏览文件 @
36bdc456
package
main
import
(
"encoding/json"
"fmt"
"io"
"net/http"
"os"
"runtime/pprof"
"strings"
cmds
"github.com/jbenet/go-ipfs/commands"
"github.com/jbenet/go-ipfs/commands/cli"
cmdsCli
"github.com/jbenet/go-ipfs/commands/cli"
cmdsHttp
"github.com/jbenet/go-ipfs/commands/http"
"github.com/jbenet/go-ipfs/core/commands"
u
"github.com/jbenet/go-ipfs/util"
)
...
...
@@ -18,19 +16,17 @@ import (
// log is the command logger
var
log
=
u
.
Logger
(
"cmd/ipfs"
)
const
API_PATH
=
"/api/v0"
func
main
()
{
args
:=
os
.
Args
[
1
:
]
req
,
err
:=
cli
.
Parse
(
args
,
Root
)
req
,
err
:=
c
mdsC
li
.
Parse
(
args
,
Root
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
os
.
Exit
(
1
)
}
if
len
(
req
.
Path
())
==
0
{
req
,
err
=
cli
.
Parse
(
args
,
commands
.
Root
)
req
,
err
=
c
mdsC
li
.
Parse
(
args
,
commands
.
Root
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
os
.
Exit
(
1
)
...
...
@@ -82,7 +78,7 @@ func main() {
// TODO: spin up node
res
=
root
.
Call
(
req
)
}
else
{
res
,
err
=
sendRequest
(
req
)
res
,
err
=
cmdsHttp
.
Send
(
req
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
os
.
Exit
(
1
)
...
...
@@ -105,61 +101,3 @@ func main() {
fmt
.
Println
(
err
.
Error
())
}
}
func
sendRequest
(
req
cmds
.
Request
)
(
cmds
.
Response
,
error
)
{
// TODO: load RPC host from config
url
:=
"http://localhost:8080"
+
API_PATH
url
+=
"/"
+
strings
.
Join
(
req
.
Path
(),
"/"
)
// TODO: support other encodings once we have multicodec to decode response
// (we shouldn't have to set this here)
encoding
:=
cmds
.
JSON
req
.
SetOption
(
cmds
.
EncShort
,
encoding
)
query
:=
"?"
options
:=
req
.
Options
()
for
k
,
v
:=
range
options
{
query
+=
"&"
+
k
+
"="
+
v
.
(
string
)
}
httpRes
,
err
:=
http
.
Post
(
url
+
query
,
"application/octet-stream"
,
req
.
Stream
())
if
err
!=
nil
{
return
nil
,
err
}
res
:=
cmds
.
NewResponse
(
req
)
contentType
:=
httpRes
.
Header
[
"Content-Type"
][
0
]
contentType
=
strings
.
Split
(
contentType
,
";"
)[
0
]
if
contentType
==
"application/octet-stream"
{
res
.
SetValue
(
httpRes
.
Body
)
return
res
,
nil
}
// TODO: decode based on `encoding`, using multicodec
dec
:=
json
.
NewDecoder
(
httpRes
.
Body
)
if
httpRes
.
StatusCode
>=
http
.
StatusBadRequest
{
e
:=
cmds
.
Error
{}
err
=
dec
.
Decode
(
&
e
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
return
nil
,
err
}
res
.
SetError
(
e
,
e
.
Code
)
}
else
{
var
v
interface
{}
err
=
dec
.
Decode
(
&
v
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
return
nil
,
err
}
res
.
SetValue
(
v
)
}
return
res
,
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论