コード例 #1
0
ファイル: StoreProcessor.cs プロジェクト: jobeland/hexadb
 public JObject GetSet(string storeId)
 {
     using (var op = _storeOperationFactory.Write(storeId)) {
         var(data, _, _) = GetSetGraphs(storeId);
         return(TripleConverter.ToJson(data));
     }
 }
コード例 #2
0
ファイル: StoreProcessor.cs プロジェクト: emgarten/hexadb
        public JObject Query(string storeId, JObject query, string[] expand, int level)
        {
            using (var op = _storeOperationFactory.Write(storeId)) {
                try {
                    var(data, _, _) = GetSetGraphs(storeId);
                    ObjectQueryModel queryModel;
                    try {
                        queryModel = query.ToObject <ObjectQueryModel>();
                    } catch (Exception e) {
                        throw new StoreException(e.Message, _storeErrors.UnableToParseQuery);
                    }

                    var     result   = new ObjectQueryExecutor().Query(queryModel, data);
                    dynamic response = new
                    {
                        values = result.Values?.Select(x =>
                        {
                            var expanded = GraphOperator.Expand(data, x.Subject, level, expand);
                            var rspGraph = new MemoryGraph();
                            rspGraph.Assert(expanded).ToList();
                            return(TripleConverter.ToJson(x.Subject, rspGraph));
                        }),
                        continuation = result.Continuation,
                        aggregates   = result.Aggregates
                    };
                    return(JObject.FromObject(response));
                } catch (Exception e) {
                    _logger.LogError("Query failed. {Message}\n {StackTrace}", e.Message, e.StackTrace);
                    throw e;
                }
            }
        }
コード例 #3
0
ファイル: StoreProcessor.cs プロジェクト: angshuman/hexadb
 public JObject GetSet(string storeId)
 {
     var (data, _, _) = GetSetGraphs(storeId);
     return TripleConverter.ToJson(data);
 }