Static object session with search verb allows to search all objects in container #155
1 changed files with 15 additions and 0 deletions
|
@ -119,6 +119,7 @@ func (exec *execCtx) generateTraverser(cnr cid.ID) (*placement.Traverser, bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (exec *execCtx) writeIDList(ids []oid.ID) {
|
func (exec *execCtx) writeIDList(ids []oid.ID) {
|
||||||
|
ids = exec.filterAllowedObjectIDs(ids)
|
||||||
err := exec.prm.writer.WriteIDs(ids)
|
err := exec.prm.writer.WriteIDs(ids)
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
|
@ -134,3 +135,17 @@ func (exec *execCtx) writeIDList(ids []oid.ID) {
|
||||||
exec.err = nil
|
exec.err = nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (exec *execCtx) filterAllowedObjectIDs(objIDs []oid.ID) []oid.ID {
|
||||||
|
sessionToken := exec.prm.common.SessionToken()
|
||||||
|
if sessionToken == nil {
|
||||||
|
return objIDs
|
||||||
|
}
|
||||||
|
result := make([]oid.ID, 0, len(objIDs))
|
||||||
|
for _, objID := range objIDs {
|
||||||
|
if sessionToken.AssertObject(objID) {
|
||||||
|
result = append(result, objID)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue