mirror of
https://github.com/gocsaf/csaf.git
synced 2025-12-22 11:55:40 +01:00
write dynamic categories into feed categories document.
This commit is contained in:
parent
72a7240fd0
commit
198e5b8897
4 changed files with 122 additions and 8 deletions
|
|
@ -14,6 +14,7 @@ import (
|
|||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
"log"
|
||||
"net/http"
|
||||
"os"
|
||||
"path/filepath"
|
||||
|
|
@ -182,11 +183,24 @@ func (c *controller) upload(r *http.Request) (interface{}, error) {
|
|||
}
|
||||
}
|
||||
|
||||
ex, err := csaf.NewAdvisorySummary(util.NewPathEval(), content)
|
||||
// Extract informations from the document.
|
||||
pe := util.NewPathEval()
|
||||
|
||||
ex, err := csaf.NewAdvisorySummary(pe, content)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// Check if we have to search for dynamic categories.
|
||||
var dynamicCategories []string
|
||||
if catExprs := c.cfg.DynamicCategories(); len(catExprs) > 0 {
|
||||
var err error
|
||||
if dynamicCategories, err = pe.Strings(catExprs, true, content); err != nil {
|
||||
// XXX: Should we die here?
|
||||
log.Printf("eval of dynamic catecory expressions failed: %v\n", err)
|
||||
}
|
||||
}
|
||||
|
||||
t, err := c.tlpParam(r)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
|
|
@ -217,6 +231,14 @@ func (c *controller) upload(r *http.Request) (interface{}, error) {
|
|||
return err
|
||||
}
|
||||
|
||||
// if we have found dynamic categories merge them into
|
||||
// the existing once.
|
||||
if len(dynamicCategories) > 0 {
|
||||
if err := c.mergeCategories(folder, t, dynamicCategories); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
// Create yearly subfolder
|
||||
year := strconv.Itoa(ex.InitialReleaseDate.Year())
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue