What have you tried so far? The filter body code is sent as javascript and interpreted on the server, test the length before doing the filtering if (position.length()>2){position.length()>2}else{position.length()>1} would work in both cases.
Den lördagen den 5:e april 2014 kl. 06:23:59 UTC+2 skrev Rio Eduardo: > > yeah because if the model graph is changed, the way to return filter also > changes. For example: > In your case here: > CREATE (Pontus:People { name:'Pontus Lundin' }),(John:People { name: 'John > Hellberg' }),(Jack:People { name: 'Jack Hellberg' }),(Sandra:People { name > : 'Sandra Johansson', sex:'female' }),(Fredrik:People { name:'Fredrik > Hansson' }),(Nils:People { name:'Nils Poppe' }),(Pontus)-[:FRIEND]->(Jack > ),(Jack)-[:FRIEND]->(Sandra),(John)-[:FRIEND]->(Jack),(Jack)-[:FRIEND]->( > John),(Sandra)-[:FRIEND]->(Fredrik),(Fredrik)-[:FRIEND]->(Ronny),(Pontus > )-[:FRIEND]->(John),(Pontus)-[:FRIEND]->(Fredrik),(Sandra)-[:FRIEND]->( > Nils); > > your Traversal Api will work well: > POST > http://localhost:7474/db/data/node/0/traverse/node{"order":"breadth_first","uniqueness":"node_global","prune_evaluator":{"name":"none","language":"builtin"}, > > "return_filter":{ "body":"position.length()>2", "language":"javascript" }, > "relationships":{"direction":"out","type":"FRIEND"},"max_depth":3} > > But in my case here: > User | Friends > 1 | 9,2,8,7,5 > 2 | 1,6,3,8,10 > 3 | 5,7,1,10,2 > 4 | 3,10,6,9,5 > 5 | 4,8,1,9,3 > 6 | 7,9,3,2,10 > 7 | 9,5,10,6,8 > 8 | 6,9,1,10,5 > 9 | 6,5,10,1,8 > 10 | 8,6,4,5,9 > > with your Traversal Api it will not work, it will return null instead > because you set position.length() > 2. But if I set position.length() > 1, > it will work well: > POST http://localhost:7474/db/data/node/1/traverse/node > {"order":"breadth_first","uniqueness":"node_global","prune_evaluator":{"name":"none","language":"builtin"}, > > "return_filter":{ "body":"position.length()>1", "language":"javascript" }, > "relationships":{"direction":"out","type":"Friend"},"max_depth":3} > > And if I have graph that has structure like tree: > User | Friends > A | B,C,Q > B | A,E,D > C | A,G,F > D | B,H > E | B,J,I > F | C > G | C,L,K > H | D,N,M > I | E > J | E > K | G,O > L | G > M | H,P > N | H,Q > O | K,R > P | M,A > Q | N,A > R | O,A > > with your Traversal Api it will work well while mine is not. > > That's why I said it works sometimes. So maybe you have a solution for > this case? > > Thank you. > > > On Saturday, April 5, 2014 7:43:06 AM UTC+7, Lundin wrote: >> >> First, why do you say it works sometimes ? That sounds like a bug to me >> in that case. Can you please start with a small dataset so you know and >> being sure that you know whats going on in the graph ? >> >> CREATE (Pontus:People { name:'Pontus Lundin' }),(John:People { name: >> 'John Hellberg' }),(Jack:People { name: 'Jack Hellberg' }),(Sandra:People { >> name: 'Sandra Johansson', sex:'female' }),(Fredrik:People { name:'Fredrik >> Hansson' }),(Nils:People { name:'Nils Poppe' >> }),(Pontus)-[:FRIEND]->(Jack),(Jack)-[:FRIEND]->(Sandra),(John)-[:FRIEND]->(Jack),(Jack)-[:FRIEND]->(John),(Sandra)-[:FRIEND]->(Fredrik),(Fredrik)-[:FRIEND]->(Ronny),(Pontus)-[:FRIEND]->(John),(Pontus)-[:FRIEND]->(Fredrik),(Sandra)-[:FRIEND]->(Nils); >> >> This creates a graph with fof where i would like to query for fof where i >> am not already friend with. >> >> POST >> http://localhost:7474/db/data/node/0/traverse/node{"order":"breadth_first","uniqueness":"node_global","prune_evaluator":{"name":"none","language":"builtin"}, >> >> "return_filter":{ "body":"position.length()>2", "language":"javascript" }, >> "relationships":{"direction":"out","type":"FRIEND"},"max_depth":3} >> >> Will return Nils Poppe which is a friend to Sandra. Sandra is also Friend >> to Fredrik but i am already friend to him so he is excluded. >> >> As for your second question i dont know if that is possible with the REST >> API i dont think so >> The actual docs for path is >> >> http://components.neo4j.org/neo4j/2.0.1/apidocs/org/neo4j/graphdb/Path.html >> >> but you will have to use cypher and do yet another query and a simple >> query like this will return the number: >> >> MATCH (n)-[r]-(friends) >> RETURN count(r), type(r); >> >> >> >> Den lördagen den 5:e april 2014 kl. 02:25:48 UTC+2 skrev Rio Eduardo: >>> >>> Lundin, Do you know the way how to count many relationships in the graph >>> because I don't see it in the doc(method for the position object(the path))? >>> >>> Thank you. >>> >>> On Saturday, April 5, 2014 12:43:01 AM UTC+7, Lundin wrote: >>>> >>>> Have you tried experimenting with ther filter and the path length ? >>>> endNod() is not the only method for the position object(the path), >>>> Mabey position.length>1 or something. >>>> >>>> Den fredagen den 4:e april 2014 kl. 18:10:33 UTC+2 skrev Rio Eduardo: >>>>> >>>>> Please anyone in this group help me. I already posted my problem at >>>>> >>>>> >>>>> http://stackoverflow.com/questions/22861424/neo4j-traversal-to-find-friends-of-friends-that-are-not-friends-with-the-user >>>>> >>>>> Thank you. >>>>> >>>> -- You received this message because you are subscribed to the Google Groups "Neo4j" group. To unsubscribe from this group and stop receiving emails from it, send an email to neo4j+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.