Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
go-sectorbuilder
Commits
1c55cfb4
Unverified
Commit
1c55cfb4
authored
Jan 28, 2020
by
Łukasz Magiera
Committed by
GitHub
Jan 28, 2020
Browse files
Merge pull request #69 from filecoin-project/feat/seal-data-checks
Implement additional data checks
parents
774d1987
d9cc96c5
Changes
3
Show whitespace changes
Inline
Side-by-side
files.go
View file @
1c55cfb4
...
...
@@ -81,6 +81,21 @@ func (sb *SectorBuilder) TrimCache(sectorID uint64) error {
return
nil
}
func
(
sb
*
SectorBuilder
)
CanCommit
(
sectorID
uint64
)
(
bool
,
error
)
{
dir
,
err
:=
sb
.
sectorCacheDir
(
sectorID
)
if
err
!=
nil
{
return
false
,
xerrors
.
Errorf
(
"getting cache dir: %w"
,
err
)
}
ents
,
err
:=
ioutil
.
ReadDir
(
dir
)
if
err
!=
nil
{
return
false
,
err
}
// TODO: slightly more sophisticated check
return
len
(
ents
)
==
10
,
nil
}
func
toReadableFile
(
r
io
.
Reader
,
n
int64
)
(
*
os
.
File
,
func
()
error
,
error
)
{
f
,
ok
:=
r
.
(
*
os
.
File
)
if
ok
{
...
...
interface.go
View file @
1c55cfb4
...
...
@@ -24,6 +24,7 @@ type Interface interface {
ReadPieceFromSealedSector
(
sectorID
uint64
,
offset
uint64
,
size
uint64
,
ticket
[]
byte
,
commD
[]
byte
)
(
io
.
ReadCloser
,
error
)
GetPath
(
string
,
string
)
(
string
,
error
)
CanCommit
(
sectorID
uint64
)
(
bool
,
error
)
WorkerStats
()
WorkerStats
AddWorker
(
context
.
Context
,
WorkerCfg
)
(
<-
chan
WorkerTask
,
error
)
TaskDone
(
context
.
Context
,
uint64
,
SealRes
)
error
...
...
sectorbuild_cgo.go
View file @
1c55cfb4
...
...
@@ -5,6 +5,7 @@ package sectorbuilder
import
(
"context"
"io"
"io/ioutil"
"os"
"sync/atomic"
...
...
@@ -137,6 +138,42 @@ func (sb *SectorBuilder) ReadPieceFromSealedSector(sectorID uint64, offset uint6
func
(
sb
*
SectorBuilder
)
SealPreCommit
(
ctx
context
.
Context
,
sectorID
uint64
,
ticket
SealTicket
,
pieces
[]
PublicPieceInfo
)
(
RawSealPreCommitOutput
,
error
)
{
fs
:=
sb
.
filesystem
cacheDir
,
err
:=
sb
.
sectorCacheDir
(
sectorID
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"getting cache dir: %w"
,
err
)
}
cached
,
err
:=
ioutil
.
ReadDir
(
cacheDir
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"reading cache dir: %w"
,
err
)
}
if
len
(
cached
)
>
0
{
// TODO: can we read t_aux or p_aux to check if we have the correct thing sealed here already?
// (need to check ticket)
log
.
Warnf
(
"precommit: cache dir %s contains files %v, cleaning up"
,
cacheDir
,
cached
)
if
err
:=
os
.
RemoveAll
(
cacheDir
);
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"removing cache dir %s: %w"
,
cacheDir
,
err
)
}
}
sealedPath
,
err
:=
sb
.
SealedSectorPath
(
sectorID
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"getting sealed sector path: %w"
,
err
)
}
if
_
,
err
:=
os
.
Stat
(
sealedPath
);
!
os
.
IsNotExist
(
err
)
{
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"stat cache dir: %w"
,
err
)
}
log
.
Warnf
(
"precommit: found sealed sector %s, cleaning up"
,
sealedPath
)
if
err
:=
os
.
Remove
(
sealedPath
);
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"removing sealed sector %s: %w"
,
sealedPath
,
err
)
}
}
if
err
:=
fs
.
reserve
(
dataCache
,
sb
.
ssize
);
err
!=
nil
{
return
RawSealPreCommitOutput
{},
err
}
...
...
@@ -189,16 +226,6 @@ func (sb *SectorBuilder) SealPreCommit(ctx context.Context, sectorID uint64, tic
<-
sb
.
rateLimit
}()
cacheDir
,
err
:=
sb
.
sectorCacheDir
(
sectorID
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"getting cache dir: %w"
,
err
)
}
sealedPath
,
err
:=
sb
.
SealedSectorPath
(
sectorID
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"getting sealed sector path: %w"
,
err
)
}
e
,
err
:=
os
.
OpenFile
(
sealedPath
,
os
.
O_RDWR
|
os
.
O_CREATE
,
0644
)
if
err
!=
nil
{
return
RawSealPreCommitOutput
{},
xerrors
.
Errorf
(
"ensuring sealed file exists: %w"
,
err
)
...
...
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