Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
M
mybee
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
vicotor
mybee
Commits
c8e5969d
Unverified
Commit
c8e5969d
authored
Jun 12, 2020
by
Janoš Guljaš
Committed by
GitHub
Jun 12, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
api bzz-chunk and bzz-raw rename (#284)
Co-authored-by:
svetomir
<
svetomirsmiljkovic@gmail.com
>
parent
3f67887e
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
62 additions
and
56 deletions
+62
-56
beekeeper.yaml
.github/workflows/beekeeper.yaml
+3
-3
io.go
cmd/internal/file/io.go
+1
-1
bytes.go
pkg/api/bytes.go
+16
-16
bytes_test.go
pkg/api/bytes_test.go
+5
-5
chunk.go
pkg/api/chunk.go
+19
-19
chunk_test.go
pkg/api/chunk_test.go
+2
-2
export_test.go
pkg/api/export_test.go
+2
-2
router.go
pkg/api/router.go
+12
-6
tag_test.go
pkg/api/tag_test.go
+1
-1
pin_test.go
pkg/debugapi/pin_test.go
+1
-1
No files found.
.github/workflows/beekeeper.yaml
View file @
c8e5969d
...
@@ -48,9 +48,9 @@ jobs:
...
@@ -48,9 +48,9 @@ jobs:
run
:
./beekeeper check fullconnectivity --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}"
run
:
./beekeeper check fullconnectivity --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}"
-
name
:
Test pingpong
-
name
:
Test pingpong
run
:
./beekeeper check pingpong --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}"
run
:
./beekeeper check pingpong --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}"
-
name
:
Test pushsync
-
name
:
Test pushsync
(bytes)
run
:
./beekeeper check pushsync --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node
3
run
:
./beekeeper check pushsync --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node
3
-
name
:
Test pushsync (
bzz-chunk API
)
-
name
:
Test pushsync (
chunks
)
run
:
./beekeeper check pushsync --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node 3 --
bzz-chunk
run
:
./beekeeper check pushsync --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node 3 --
upload-chunks
-
name
:
Test retrieval
-
name
:
Test retrieval
run
:
./beekeeper check retrieval --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node
3
run
:
./beekeeper check retrieval --api-scheme http --debug-api-scheme http --disable-namespace --debug-api-domain localhost --api-domain localhost --node-count "${REPLICA}" --upload-node-count "${REPLICA}" --chunks-per-node
3
cmd/internal/file/io.go
View file @
c8e5969d
...
@@ -116,7 +116,7 @@ func NewApiStore(host string, port int, ssl bool) putGetter {
...
@@ -116,7 +116,7 @@ func NewApiStore(host string, port int, ssl bool) putGetter {
u
:=
&
url
.
URL
{
u
:=
&
url
.
URL
{
Host
:
fmt
.
Sprintf
(
"%s:%d"
,
host
,
port
),
Host
:
fmt
.
Sprintf
(
"%s:%d"
,
host
,
port
),
Scheme
:
scheme
,
Scheme
:
scheme
,
Path
:
"
bzz-chunk
"
,
Path
:
"
chunks
"
,
}
}
return
&
ApiStore
{
return
&
ApiStore
{
Client
:
http
.
DefaultClient
,
Client
:
http
.
DefaultClient
,
...
...
pkg/api/
raw
.go
→
pkg/api/
bytes
.go
View file @
c8e5969d
...
@@ -21,16 +21,16 @@ import (
...
@@ -21,16 +21,16 @@ import (
"github.com/ethersphere/bee/pkg/swarm"
"github.com/ethersphere/bee/pkg/swarm"
)
)
type
raw
PostResponse
struct
{
type
bytes
PostResponse
struct
{
Hash
swarm
.
Address
`json:"hash
"`
Reference
swarm
.
Address
`json:"reference
"`
}
}
//
raw
UploadHandler handles upload of raw binary data of arbitrary length.
//
bytes
UploadHandler handles upload of raw binary data of arbitrary length.
func
(
s
*
server
)
raw
UploadHandler
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
func
(
s
*
server
)
bytes
UploadHandler
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
ctx
:=
r
.
Context
()
ctx
:=
r
.
Context
()
responseObject
,
err
:=
s
.
splitUpload
(
ctx
,
r
.
Body
,
r
.
ContentLength
)
responseObject
,
err
:=
s
.
splitUpload
(
ctx
,
r
.
Body
,
r
.
ContentLength
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
raw
: %v"
,
err
)
s
.
Logger
.
Debugf
(
"
bytes upload
: %v"
,
err
)
o
:=
responseObject
.
(
jsonhttp
.
StatusResponse
)
o
:=
responseObject
.
(
jsonhttp
.
StatusResponse
)
jsonhttp
.
Respond
(
w
,
o
.
Code
,
o
)
jsonhttp
.
Respond
(
w
,
o
.
Code
,
o
)
}
else
{
}
else
{
...
@@ -68,18 +68,18 @@ func (s *server) splitUpload(ctx context.Context, r io.ReadCloser, l int64) (int
...
@@ -68,18 +68,18 @@ func (s *server) splitUpload(ctx context.Context, r io.ReadCloser, l int64) (int
err
=
fmt
.
Errorf
(
"%s: %v"
,
response
.
Message
,
err
)
err
=
fmt
.
Errorf
(
"%s: %v"
,
response
.
Message
,
err
)
return
response
,
err
return
response
,
err
}
}
return
rawPostResponse
{
Hash
:
address
},
nil
return
bytesPostResponse
{
Reference
:
address
},
nil
}
}
//
raw
GetHandler handles retrieval of raw binary data of arbitrary length.
//
bytes
GetHandler handles retrieval of raw binary data of arbitrary length.
func
(
s
*
server
)
raw
GetHandler
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
func
(
s
*
server
)
bytes
GetHandler
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
addressHex
:=
mux
.
Vars
(
r
)[
"address"
]
addressHex
:=
mux
.
Vars
(
r
)[
"address"
]
ctx
:=
r
.
Context
()
ctx
:=
r
.
Context
()
address
,
err
:=
swarm
.
ParseHexAddress
(
addressHex
)
address
,
err
:=
swarm
.
ParseHexAddress
(
addressHex
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
raw
: parse address %s: %v"
,
addressHex
,
err
)
s
.
Logger
.
Debugf
(
"
bytes
: parse address %s: %v"
,
addressHex
,
err
)
s
.
Logger
.
Error
(
"
raw
: parse address error"
)
s
.
Logger
.
Error
(
"
bytes
: parse address error"
)
jsonhttp
.
BadRequest
(
w
,
"invalid address"
)
jsonhttp
.
BadRequest
(
w
,
"invalid address"
)
return
return
}
}
...
@@ -89,13 +89,13 @@ func (s *server) rawGetHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -89,13 +89,13 @@ func (s *server) rawGetHandler(w http.ResponseWriter, r *http.Request) {
dataSize
,
err
:=
j
.
Size
(
ctx
,
address
)
dataSize
,
err
:=
j
.
Size
(
ctx
,
address
)
if
err
!=
nil
{
if
err
!=
nil
{
if
errors
.
Is
(
err
,
storage
.
ErrNotFound
)
{
if
errors
.
Is
(
err
,
storage
.
ErrNotFound
)
{
s
.
Logger
.
Debugf
(
"
raw
: not found %s: %v"
,
address
,
err
)
s
.
Logger
.
Debugf
(
"
bytes
: not found %s: %v"
,
address
,
err
)
s
.
Logger
.
Error
(
"
raw
: not found"
)
s
.
Logger
.
Error
(
"
bytes
: not found"
)
jsonhttp
.
NotFound
(
w
,
"not found"
)
jsonhttp
.
NotFound
(
w
,
"not found"
)
return
return
}
}
s
.
Logger
.
Debugf
(
"
raw
: invalid root chunk %s: %v"
,
address
,
err
)
s
.
Logger
.
Debugf
(
"
bytes
: invalid root chunk %s: %v"
,
address
,
err
)
s
.
Logger
.
Error
(
"
raw
: invalid root chunk"
)
s
.
Logger
.
Error
(
"
bytes
: invalid root chunk"
)
jsonhttp
.
BadRequest
(
w
,
"invalid root chunk"
)
jsonhttp
.
BadRequest
(
w
,
"invalid root chunk"
)
return
return
}
}
...
@@ -104,8 +104,8 @@ func (s *server) rawGetHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -104,8 +104,8 @@ func (s *server) rawGetHandler(w http.ResponseWriter, r *http.Request) {
w
.
Header
()
.
Set
(
"Content-Length"
,
fmt
.
Sprintf
(
"%d"
,
dataSize
))
w
.
Header
()
.
Set
(
"Content-Length"
,
fmt
.
Sprintf
(
"%d"
,
dataSize
))
c
,
err
:=
file
.
JoinReadAll
(
j
,
address
,
w
)
c
,
err
:=
file
.
JoinReadAll
(
j
,
address
,
w
)
if
err
!=
nil
&&
c
==
0
{
if
err
!=
nil
&&
c
==
0
{
s
.
Logger
.
Errorf
(
"
raw
: data write %s: %v"
,
address
,
err
)
s
.
Logger
.
Errorf
(
"
bytes
: data write %s: %v"
,
address
,
err
)
s
.
Logger
.
Error
(
"
raw
: data input error"
)
s
.
Logger
.
Error
(
"
bytes
: data input error"
)
jsonhttp
.
InternalServerError
(
w
,
"retrieval fail"
)
jsonhttp
.
InternalServerError
(
w
,
"retrieval fail"
)
}
}
}
}
pkg/api/
raw
_test.go
→
pkg/api/
bytes
_test.go
View file @
c8e5969d
...
@@ -20,11 +20,11 @@ import (
...
@@ -20,11 +20,11 @@ import (
mockbytes
"gitlab.com/nolash/go-mockbytes"
mockbytes
"gitlab.com/nolash/go-mockbytes"
)
)
// Test
Raw
tests that the data upload api responds as expected when uploading,
// Test
Bytes
tests that the data upload api responds as expected when uploading,
// downloading and requesting a resource that cannot be found.
// downloading and requesting a resource that cannot be found.
func
Test
Raw
(
t
*
testing
.
T
)
{
func
Test
Bytes
(
t
*
testing
.
T
)
{
var
(
var
(
resource
=
"/b
zz-raw
"
resource
=
"/b
ytes
"
expHash
=
"29a5fb121ce96194ba8b7b823a1f9c6af87e1791f824940a53b5a7efe3f790d9"
expHash
=
"29a5fb121ce96194ba8b7b823a1f9c6af87e1791f824940a53b5a7efe3f790d9"
mockStorer
=
mock
.
NewStorer
()
mockStorer
=
mock
.
NewStorer
()
client
=
newTestServer
(
t
,
testServerOptions
{
client
=
newTestServer
(
t
,
testServerOptions
{
...
@@ -40,8 +40,8 @@ func TestRaw(t *testing.T) {
...
@@ -40,8 +40,8 @@ func TestRaw(t *testing.T) {
}
}
t
.
Run
(
"upload"
,
func
(
t
*
testing
.
T
)
{
t
.
Run
(
"upload"
,
func
(
t
*
testing
.
T
)
{
jsonhttptest
.
ResponseDirect
(
t
,
client
,
http
.
MethodPost
,
resource
,
bytes
.
NewReader
(
content
),
http
.
StatusOK
,
api
.
Raw
PostResponse
{
jsonhttptest
.
ResponseDirect
(
t
,
client
,
http
.
MethodPost
,
resource
,
bytes
.
NewReader
(
content
),
http
.
StatusOK
,
api
.
Bytes
PostResponse
{
Hash
:
swarm
.
MustParseHexAddress
(
expHash
),
Reference
:
swarm
.
MustParseHexAddress
(
expHash
),
})
})
})
})
...
...
pkg/api/
bzz
chunk.go
→
pkg/api/chunk.go
View file @
c8e5969d
...
@@ -34,8 +34,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -34,8 +34,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
address
,
err
:=
swarm
.
ParseHexAddress
(
addr
)
address
,
err
:=
swarm
.
ParseHexAddress
(
addr
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: parse chunk address %s: %v"
,
addr
,
err
)
s
.
Logger
.
Debugf
(
"
chunk upload
: parse chunk address %s: %v"
,
addr
,
err
)
s
.
Logger
.
Error
(
"
bzz-chunk
: parse chunk address"
)
s
.
Logger
.
Error
(
"
chunk upload
: parse chunk address"
)
jsonhttp
.
BadRequest
(
w
,
"invalid chunk address"
)
jsonhttp
.
BadRequest
(
w
,
"invalid chunk address"
)
return
return
}
}
...
@@ -47,8 +47,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -47,8 +47,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
tagName
:=
fmt
.
Sprintf
(
"unnamed_tag_%d"
,
time
.
Now
()
.
Unix
())
tagName
:=
fmt
.
Sprintf
(
"unnamed_tag_%d"
,
time
.
Now
()
.
Unix
())
tag
,
err
=
s
.
Tags
.
Create
(
tagName
,
0
,
false
)
tag
,
err
=
s
.
Tags
.
Create
(
tagName
,
0
,
false
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: tag creation error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"
chunk upload
: tag creation error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-chunk
: tag creation error"
)
s
.
Logger
.
Error
(
"
chunk upload
: tag creation error"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot create tag"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot create tag"
)
return
return
}
}
...
@@ -56,16 +56,16 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -56,16 +56,16 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
// if the tag uid header is present, then use the tag sent
// if the tag uid header is present, then use the tag sent
tagUid
,
err
:=
strconv
.
ParseUint
(
tagUidStr
,
10
,
32
)
tagUid
,
err
:=
strconv
.
ParseUint
(
tagUidStr
,
10
,
32
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: parse taguid %s: %v"
,
tagUidStr
,
err
)
s
.
Logger
.
Debugf
(
"
chunk upload
: parse taguid %s: %v"
,
tagUidStr
,
err
)
s
.
Logger
.
Error
(
"
bzz-chunk
: parse taguid"
)
s
.
Logger
.
Error
(
"
chunk upload
: parse taguid"
)
jsonhttp
.
BadRequest
(
w
,
"invalid taguid"
)
jsonhttp
.
BadRequest
(
w
,
"invalid taguid"
)
return
return
}
}
tag
,
err
=
s
.
Tags
.
Get
(
uint32
(
tagUid
))
tag
,
err
=
s
.
Tags
.
Get
(
uint32
(
tagUid
))
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: tag get error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"
chunk upload
: tag get error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-chunk
: tag get error"
)
s
.
Logger
.
Error
(
"
chunk upload
: tag get error"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot create tag"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot create tag"
)
return
return
}
}
...
@@ -77,8 +77,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -77,8 +77,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
data
,
err
:=
ioutil
.
ReadAll
(
r
.
Body
)
data
,
err
:=
ioutil
.
ReadAll
(
r
.
Body
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: read chunk data error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"
chunk upload
: read chunk data error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-chunk
: read chunk data error"
)
s
.
Logger
.
Error
(
"
chunk upload
: read chunk data error"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot read chunk data"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot read chunk data"
)
return
return
...
@@ -86,8 +86,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -86,8 +86,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
seen
,
err
:=
s
.
Storer
.
Put
(
ctx
,
storage
.
ModePutUpload
,
swarm
.
NewChunk
(
address
,
data
))
seen
,
err
:=
s
.
Storer
.
Put
(
ctx
,
storage
.
ModePutUpload
,
swarm
.
NewChunk
(
address
,
data
))
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: chunk write error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"
chunk upload
: chunk write error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-chunk
: chunk write error"
)
s
.
Logger
.
Error
(
"
chunk upload
: chunk write error"
)
jsonhttp
.
BadRequest
(
w
,
"chunk write error"
)
jsonhttp
.
BadRequest
(
w
,
"chunk write error"
)
return
return
}
else
if
len
(
seen
)
>
0
&&
seen
[
0
]
{
}
else
if
len
(
seen
)
>
0
&&
seen
[
0
]
{
...
@@ -102,8 +102,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -102,8 +102,8 @@ func (s *server) chunkUploadHandler(w http.ResponseWriter, r *http.Request) {
if
pinHeaderValues
!=
""
&&
strings
.
ToLower
(
pinHeaderValues
)
==
"true"
{
if
pinHeaderValues
!=
""
&&
strings
.
ToLower
(
pinHeaderValues
)
==
"true"
{
err
=
s
.
Storer
.
Set
(
ctx
,
storage
.
ModeSetPin
,
address
)
err
=
s
.
Storer
.
Set
(
ctx
,
storage
.
ModeSetPin
,
address
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-chunk
: chunk pinning error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"
chunk upload
: chunk pinning error: %v, addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-chunk
: chunk pinning error"
)
s
.
Logger
.
Error
(
"
chunk upload
: chunk pinning error"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot pin chunk"
)
jsonhttp
.
InternalServerError
(
w
,
"cannot pin chunk"
)
return
return
}
}
...
@@ -120,8 +120,8 @@ func (s *server) chunkGetHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -120,8 +120,8 @@ func (s *server) chunkGetHandler(w http.ResponseWriter, r *http.Request) {
address
,
err
:=
swarm
.
ParseHexAddress
(
addr
)
address
,
err
:=
swarm
.
ParseHexAddress
(
addr
)
if
err
!=
nil
{
if
err
!=
nil
{
s
.
Logger
.
Debugf
(
"
bzz-
chunk: parse chunk address %s: %v"
,
addr
,
err
)
s
.
Logger
.
Debugf
(
"chunk: parse chunk address %s: %v"
,
addr
,
err
)
s
.
Logger
.
Error
(
"
bzz-
chunk: parse chunk address error"
)
s
.
Logger
.
Error
(
"chunk: parse chunk address error"
)
jsonhttp
.
BadRequest
(
w
,
"invalid chunk address"
)
jsonhttp
.
BadRequest
(
w
,
"invalid chunk address"
)
return
return
}
}
...
@@ -129,13 +129,13 @@ func (s *server) chunkGetHandler(w http.ResponseWriter, r *http.Request) {
...
@@ -129,13 +129,13 @@ func (s *server) chunkGetHandler(w http.ResponseWriter, r *http.Request) {
chunk
,
err
:=
s
.
Storer
.
Get
(
ctx
,
storage
.
ModeGetRequest
,
address
)
chunk
,
err
:=
s
.
Storer
.
Get
(
ctx
,
storage
.
ModeGetRequest
,
address
)
if
err
!=
nil
{
if
err
!=
nil
{
if
errors
.
Is
(
err
,
storage
.
ErrNotFound
)
{
if
errors
.
Is
(
err
,
storage
.
ErrNotFound
)
{
s
.
Logger
.
Trace
(
"
bzz-
chunk: chunk not found. addr %s"
,
address
)
s
.
Logger
.
Trace
(
"chunk: chunk not found. addr %s"
,
address
)
jsonhttp
.
NotFound
(
w
,
"chunk not found"
)
jsonhttp
.
NotFound
(
w
,
"chunk not found"
)
return
return
}
}
s
.
Logger
.
Debugf
(
"
bzz-
chunk: chunk read error: %v ,addr %s"
,
err
,
address
)
s
.
Logger
.
Debugf
(
"chunk: chunk read error: %v ,addr %s"
,
err
,
address
)
s
.
Logger
.
Error
(
"
bzz-
chunk: chunk read error"
)
s
.
Logger
.
Error
(
"chunk: chunk read error"
)
jsonhttp
.
InternalServerError
(
w
,
"chunk read error"
)
jsonhttp
.
InternalServerError
(
w
,
"chunk read error"
)
return
return
}
}
...
...
pkg/api/
bzz
chunk_test.go
→
pkg/api/chunk_test.go
View file @
c8e5969d
...
@@ -27,7 +27,7 @@ import (
...
@@ -27,7 +27,7 @@ import (
func
TestChunkUploadDownload
(
t
*
testing
.
T
)
{
func
TestChunkUploadDownload
(
t
*
testing
.
T
)
{
var
(
var
(
resource
=
func
(
addr
swarm
.
Address
)
string
{
return
"/
bzz-chunk
/"
+
addr
.
String
()
}
resource
=
func
(
addr
swarm
.
Address
)
string
{
return
"/
chunks
/"
+
addr
.
String
()
}
validHash
=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
validHash
=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
invalidHash
=
swarm
.
MustParseHexAddress
(
"bbccdd"
)
invalidHash
=
swarm
.
MustParseHexAddress
(
"bbccdd"
)
validContent
=
[]
byte
(
"bbaatt"
)
validContent
=
[]
byte
(
"bbaatt"
)
...
@@ -120,7 +120,7 @@ func TestChunkUploadDownload(t *testing.T) {
...
@@ -120,7 +120,7 @@ func TestChunkUploadDownload(t *testing.T) {
})
})
}
}
func
request
(
t
*
testing
.
T
,
client
*
http
.
Client
,
method
string
,
resource
string
,
body
io
.
Reader
,
responseCode
int
)
*
http
.
Response
{
func
request
(
t
*
testing
.
T
,
client
*
http
.
Client
,
method
,
resource
string
,
body
io
.
Reader
,
responseCode
int
)
*
http
.
Response
{
t
.
Helper
()
t
.
Helper
()
req
,
err
:=
http
.
NewRequest
(
method
,
resource
,
body
)
req
,
err
:=
http
.
NewRequest
(
method
,
resource
,
body
)
...
...
pkg/api/export_test.go
View file @
c8e5969d
...
@@ -5,6 +5,6 @@
...
@@ -5,6 +5,6 @@
package
api
package
api
type
(
type
(
RawPostResponse
=
raw
PostResponse
BytesPostResponse
=
bytes
PostResponse
TagResponse
=
tagResponse
TagResponse
=
tagResponse
)
)
pkg/api/router.go
View file @
c8e5969d
...
@@ -17,6 +17,13 @@ import (
...
@@ -17,6 +17,13 @@ import (
)
)
func
(
s
*
server
)
setupRouting
()
{
func
(
s
*
server
)
setupRouting
()
{
apiVersion
:=
"v1"
// only one api version exists, this should be configurable with more
handle
:=
func
(
router
*
mux
.
Router
,
path
string
,
handler
http
.
Handler
)
{
router
.
Handle
(
path
,
handler
)
router
.
Handle
(
"/"
+
apiVersion
+
path
,
handler
)
}
router
:=
mux
.
NewRouter
()
router
:=
mux
.
NewRouter
()
router
.
NotFoundHandler
=
http
.
HandlerFunc
(
jsonhttp
.
NotFoundHandler
)
router
.
NotFoundHandler
=
http
.
HandlerFunc
(
jsonhttp
.
NotFoundHandler
)
...
@@ -28,15 +35,14 @@ func (s *server) setupRouting() {
...
@@ -28,15 +35,14 @@ func (s *server) setupRouting() {
fmt
.
Fprintln
(
w
,
"User-agent: *
\n
Disallow: /"
)
fmt
.
Fprintln
(
w
,
"User-agent: *
\n
Disallow: /"
)
})
})
router
.
Handle
(
"/bzz-raw
"
,
jsonhttp
.
MethodHandler
{
handle
(
router
,
"/bytes
"
,
jsonhttp
.
MethodHandler
{
"POST"
:
http
.
HandlerFunc
(
s
.
raw
UploadHandler
),
"POST"
:
http
.
HandlerFunc
(
s
.
bytes
UploadHandler
),
})
})
handle
(
router
,
"/bytes/{address}"
,
jsonhttp
.
MethodHandler
{
router
.
Handle
(
"/bzz-raw/{address}"
,
jsonhttp
.
MethodHandler
{
"GET"
:
http
.
HandlerFunc
(
s
.
bytesGetHandler
),
"GET"
:
http
.
HandlerFunc
(
s
.
rawGetHandler
),
})
})
router
.
Handle
(
"/bzz-chunk
/{addr}"
,
jsonhttp
.
MethodHandler
{
handle
(
router
,
"/chunks
/{addr}"
,
jsonhttp
.
MethodHandler
{
"GET"
:
http
.
HandlerFunc
(
s
.
chunkGetHandler
),
"GET"
:
http
.
HandlerFunc
(
s
.
chunkGetHandler
),
"POST"
:
http
.
HandlerFunc
(
s
.
chunkUploadHandler
),
"POST"
:
http
.
HandlerFunc
(
s
.
chunkUploadHandler
),
})
})
...
...
pkg/api/tag_test.go
View file @
c8e5969d
...
@@ -22,7 +22,7 @@ import (
...
@@ -22,7 +22,7 @@ import (
func
TestTags
(
t
*
testing
.
T
)
{
func
TestTags
(
t
*
testing
.
T
)
{
var
(
var
(
resource
=
func
(
addr
swarm
.
Address
)
string
{
return
"/
bzz-chunk
/"
+
addr
.
String
()
}
resource
=
func
(
addr
swarm
.
Address
)
string
{
return
"/
chunks
/"
+
addr
.
String
()
}
tagResourceUidCreate
=
func
(
name
string
)
string
{
return
"/bzz-tag/name/"
+
name
}
tagResourceUidCreate
=
func
(
name
string
)
string
{
return
"/bzz-tag/name/"
+
name
}
tagResourceUUid
=
func
(
uuid
uint64
)
string
{
return
"/bzz-tag/uuid/"
+
strconv
.
FormatUint
(
uuid
,
10
)
}
tagResourceUUid
=
func
(
uuid
uint64
)
string
{
return
"/bzz-tag/uuid/"
+
strconv
.
FormatUint
(
uuid
,
10
)
}
validHash
=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
validHash
=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
...
...
pkg/debugapi/pin_test.go
View file @
c8e5969d
...
@@ -23,7 +23,7 @@ import (
...
@@ -23,7 +23,7 @@ import (
// invalid chunk address case etc. This test case has to be run in sequence and
// invalid chunk address case etc. This test case has to be run in sequence and
// it assumes some state of the DB before another case is run.
// it assumes some state of the DB before another case is run.
func
TestPinChunkHandler
(
t
*
testing
.
T
)
{
func
TestPinChunkHandler
(
t
*
testing
.
T
)
{
resource
:=
func
(
addr
swarm
.
Address
)
string
{
return
"/
bzz-chunk
/"
+
addr
.
String
()
}
resource
:=
func
(
addr
swarm
.
Address
)
string
{
return
"/
chunks
/"
+
addr
.
String
()
}
hash
:=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
hash
:=
swarm
.
MustParseHexAddress
(
"aabbcc"
)
data
:=
[]
byte
(
"bbaatt"
)
data
:=
[]
byte
(
"bbaatt"
)
mockValidator
:=
validator
.
NewMockValidator
(
hash
,
data
)
mockValidator
:=
validator
.
NewMockValidator
(
hash
,
data
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment