mirror of
https://github.com/foomo/contentserver.git
synced 2025-10-16 12:25:44 +00:00
further dimension refactoring
This commit is contained in:
parent
b5cdc00cf4
commit
9adccb0c72
@ -11,7 +11,7 @@ type RepoNode struct {
|
||||
LinkId string `json:"linkIds"` // (symbolic) link/alias to another node
|
||||
Groups []string `json:"groups"` // which groups have access to the node, if empty everybody has access to it
|
||||
URI string `json:"URI"`
|
||||
Name string `json:"names"`
|
||||
Name string `json:"name"`
|
||||
Hidden bool `json:"hidden"` // hidden in content.nodes, but can still be resolved when being directly addressed
|
||||
DestinationId string `json:"destinationId"` // if a node does not have any content like a folder the destinationIds can point to nodes that do aka. the first displayable child node
|
||||
Data map[string]interface{} `json:"data"` // what ever you want to stuff into it - the payload you want to attach to a node
|
||||
|
||||
@ -38,9 +38,11 @@ func NewRepo(server string) *Repo {
|
||||
repo.updateChannel = make(chan *RepoDimension)
|
||||
repo.updateDoneChannel = make(chan error)
|
||||
go func() {
|
||||
select {
|
||||
case newDimension := <-repo.updateChannel:
|
||||
repo.updateDoneChannel <- repo.load(newDimension.Dimension, newDimension.Node)
|
||||
for {
|
||||
select {
|
||||
case newDimension := <-repo.updateChannel:
|
||||
repo.updateDoneChannel <- repo.load(newDimension.Dimension, newDimension.Node)
|
||||
}
|
||||
}
|
||||
}()
|
||||
return repo
|
||||
@ -77,29 +79,32 @@ func (repo *Repo) load(dimension string, newNode *content.RepoNode) error {
|
||||
|
||||
func (repo *Repo) ResolveContent(dimensions []string, URI string) (resolved bool, resolvedURI string, resolvedDimension string, repoNode *content.RepoNode) {
|
||||
parts := strings.Split(URI, content.PATH_SEPARATOR)
|
||||
resolved = false
|
||||
resolvedURI = ""
|
||||
resolvedDimension = ""
|
||||
repoNode = nil
|
||||
log.Debug("repo.ResolveContent: " + URI)
|
||||
for _, dimension := range dimensions {
|
||||
if d, ok := repo.Directory[dimension]; ok {
|
||||
for i := len(parts); i > -1; i-- {
|
||||
for i := len(parts); i > 0; i-- {
|
||||
testURI := strings.Join(parts[0:i], content.PATH_SEPARATOR)
|
||||
log.Debug(" testing" + testURI)
|
||||
if testURI == "" {
|
||||
testURI = content.PATH_SEPARATOR
|
||||
}
|
||||
log.Debug(" testing[" + dimension + "]: " + testURI)
|
||||
if repoNode, ok := d.URIDirectory[testURI]; ok {
|
||||
resolved = true
|
||||
log.Debug(" => " + testURI)
|
||||
log.Debug(" destination " + fmt.Sprint(repoNode.DestinationId))
|
||||
log.Debug(" found => " + testURI)
|
||||
log.Debug(" destination " + fmt.Sprint(repoNode.DestinationId))
|
||||
if len(repoNode.DestinationId) > 0 {
|
||||
if destionationNode, destinationNodeOk := d.Directory[repoNode.DestinationId]; destinationNodeOk {
|
||||
repoNode = destionationNode
|
||||
}
|
||||
}
|
||||
return true, testURI, dimension, repoNode
|
||||
} else {
|
||||
log.Debug(" => !" + testURI)
|
||||
resolved = false
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
return
|
||||
}
|
||||
@ -163,6 +168,7 @@ func (repo *Repo) GetNodes(r *requests.Nodes) map[string]*content.Node {
|
||||
}
|
||||
|
||||
func (repo *Repo) GetContent(r *requests.Content) *content.SiteContent {
|
||||
// add more input validation
|
||||
log.Debug("repo.GetContent: " + r.URI)
|
||||
c := content.NewSiteContent()
|
||||
resolved, resolvedURI, resolvedDimension, node := repo.ResolveContent(r.Env.Dimensions, r.URI)
|
||||
@ -181,6 +187,10 @@ func (repo *Repo) GetContent(r *requests.Content) *content.SiteContent {
|
||||
c.Status = content.STATUS_NOT_FOUND
|
||||
c.Dimension = r.Env.Dimensions[0]
|
||||
}
|
||||
log.Debug(fmt.Sprintf("resolved: %v, uri: %v, dim: %v, n: %v", resolved, resolvedURI, resolvedDimension, node))
|
||||
if resolved == false {
|
||||
resolvedDimension = r.Env.Dimensions[0]
|
||||
}
|
||||
for treeName, treeRequest := range r.Nodes {
|
||||
log.Debug(" adding tree " + treeName + " " + treeRequest.Id)
|
||||
if treeNode, ok := repo.Directory[resolvedDimension].Directory[treeRequest.Id]; ok {
|
||||
@ -192,11 +202,14 @@ func (repo *Repo) GetContent(r *requests.Content) *content.SiteContent {
|
||||
return c
|
||||
}
|
||||
|
||||
/*
|
||||
func (repo *Repo) GetRepo() *content.RepoNode {
|
||||
return repo.Node
|
||||
func (repo *Repo) GetRepo() map[string]*content.RepoNode {
|
||||
response := make(map[string]*content.RepoNode)
|
||||
for dimensionName, dimension := range repo.Directory {
|
||||
response[dimensionName] = dimension.Node
|
||||
}
|
||||
return response
|
||||
}
|
||||
*/
|
||||
|
||||
func uriKeyForState(state string, uri string) string {
|
||||
return state + "-" + uri
|
||||
}
|
||||
@ -239,15 +252,17 @@ func (repo *Repo) Update() *responses.Update {
|
||||
updateResponse := responses.NewUpdate()
|
||||
newNodes := make(map[string]*content.RepoNode) //content.NewRepoNode()
|
||||
startTimeRepo := time.Now()
|
||||
ok, err := utils.Get(repo.server, newNodes)
|
||||
ok, err := utils.GetRepo(repo.server, newNodes)
|
||||
updateResponse.Stats.RepoRuntime = time.Now().Sub(startTimeRepo).Seconds()
|
||||
startTimeOwn := time.Now()
|
||||
updateResponse.Success = ok
|
||||
if ok {
|
||||
log.Debug("going to load dimensions from" + utils.ToJSON(newNodes))
|
||||
for dimension, newNode := range newNodes {
|
||||
log.Debug("loading nodes for dimension " + dimension)
|
||||
repo.Load(dimension, newNode)
|
||||
updateResponse.Stats.NumberOfNodes = len(repo.Directory[dimension].Directory)
|
||||
updateResponse.Stats.NumberOfURIs = len(repo.Directory[dimension].URIDirectory)
|
||||
updateResponse.Stats.NumberOfNodes += len(repo.Directory[dimension].Directory)
|
||||
updateResponse.Stats.NumberOfURIs += len(repo.Directory[dimension].URIDirectory)
|
||||
}
|
||||
} else {
|
||||
log.Error(fmt.Sprintf("update error: %", err))
|
||||
|
||||
@ -8,7 +8,7 @@ type Env struct {
|
||||
|
||||
type Node struct {
|
||||
Id string `json:"id"`
|
||||
Dimension string `json:"id"`
|
||||
Dimension string `json:"dimension"`
|
||||
MimeTypes []string `json:"mimeTypes"`
|
||||
Expand bool `json:"expand"`
|
||||
DataFields []string `json:"dataFields"`
|
||||
|
||||
@ -66,18 +66,16 @@ func handleSocketRequest(handler string, jsonBuffer []byte) (replyBytes []byte,
|
||||
updateResponse := contentRepo.Update()
|
||||
reply = updateResponse
|
||||
break
|
||||
/*
|
||||
case "getRepo":
|
||||
repoRequest := requests.NewRepo()
|
||||
jsonErr = json.Unmarshal(jsonBuffer, &repoRequest)
|
||||
log.Debug(" getRepoRequest: " + fmt.Sprint(repoRequest))
|
||||
repoResponse := contentRepo.GetRepo()
|
||||
reply = repoResponse
|
||||
break
|
||||
*/
|
||||
case "getRepo":
|
||||
repoRequest := requests.NewRepo()
|
||||
jsonErr = json.Unmarshal(jsonBuffer, &repoRequest)
|
||||
log.Debug(" getRepoRequest: " + fmt.Sprint(repoRequest))
|
||||
repoResponse := contentRepo.GetRepo()
|
||||
reply = repoResponse
|
||||
break
|
||||
default:
|
||||
err = errors.New(log.Error(" can not handle this one " + handler))
|
||||
errorResponse := responses.NewError(1, "unkown handler")
|
||||
errorResponse := responses.NewError(1, "unknown handler")
|
||||
reply = errorResponse
|
||||
}
|
||||
if jsonErr != nil {
|
||||
|
||||
@ -4,6 +4,7 @@ import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"github.com/foomo/contentserver/server/repo/content"
|
||||
"io/ioutil"
|
||||
"net/http"
|
||||
)
|
||||
@ -12,6 +13,10 @@ func JsonResponse(w http.ResponseWriter, obj interface{}) {
|
||||
fmt.Fprint(w, toJson(obj))
|
||||
}
|
||||
|
||||
func ToJSON(obj interface{}) string {
|
||||
return toJson(obj)
|
||||
}
|
||||
|
||||
func toJson(obj interface{}) string {
|
||||
//b, err := json.MarshalIndent(obj, "", "\t")
|
||||
b, err := json.Marshal(obj)
|
||||
@ -42,6 +47,33 @@ func PopulateRequest(r *http.Request, obj interface{}) {
|
||||
json.Unmarshal(extractJsonFromRequest(r), obj)
|
||||
}
|
||||
|
||||
func GetRepo(URL string, obj map[string]*content.RepoNode) (ok bool, err error) {
|
||||
// add proper error handling
|
||||
response, err := http.Get(URL)
|
||||
if err != nil {
|
||||
return false, err
|
||||
} else {
|
||||
defer response.Body.Close()
|
||||
if response.StatusCode != http.StatusOK {
|
||||
return false, errors.New(fmt.Sprintf("Bad HTTP Response: %v", response.Status))
|
||||
} else {
|
||||
contents, err := ioutil.ReadAll(response.Body)
|
||||
if err != nil {
|
||||
return false, err
|
||||
} else {
|
||||
fmt.Printf("json string %s", string(contents))
|
||||
jsonErr := json.Unmarshal(contents, &obj)
|
||||
if jsonErr != nil {
|
||||
panic(jsonErr)
|
||||
return false, jsonErr
|
||||
} else {
|
||||
return true, nil
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func Get(URL string, obj interface{}) (ok bool, err error) {
|
||||
// add proper error handling
|
||||
response, err := http.Get(URL)
|
||||
@ -56,9 +88,10 @@ func Get(URL string, obj interface{}) (ok bool, err error) {
|
||||
if err != nil {
|
||||
return false, err
|
||||
} else {
|
||||
// fmt.Printf("json string %s", string(contents))
|
||||
fmt.Printf("json string %s", string(contents))
|
||||
jsonErr := json.Unmarshal(contents, &obj)
|
||||
if jsonErr != nil {
|
||||
panic(jsonErr)
|
||||
return false, jsonErr
|
||||
} else {
|
||||
return true, nil
|
||||
|
||||
Loading…
Reference in New Issue
Block a user