Where communities thrive


  • Join over 1.5M+ people
  • Join over 100K+ communities
  • Free without limits
  • Create your own community
People
Repo info
Activity
  • 01:49
    fsvieira edited #1168
  • 01:33
    fsvieira edited #1168
  • 01:08
    fsvieira edited #1168
  • 01:04
    fsvieira opened #1168
  • Nov 27 17:42
    amark commented #1164
  • Nov 27 12:29
    davay42 updated the wiki
  • Nov 26 19:12
    amark commented #1163
  • Nov 26 10:29
    aethiop commented #1163
  • Nov 25 20:02
    davay42 updated the wiki
  • Nov 25 20:00
    davay42 updated the wiki
  • Nov 25 20:00
    davay42 updated the wiki
  • Nov 25 01:36

    amark on master

    Thanks to @DimensionDev https:/… (compare)

  • Nov 25 01:26
    resession commented #1167
  • Nov 25 00:25
    amark commented #1167
  • Nov 24 23:32
    resession edited #1167
  • Nov 24 23:32
    resession opened #1167
  • Nov 24 07:14
    sirpy commented #1163
  • Nov 23 22:56
    amark commented #1163
  • Nov 23 21:52

    amark on master

    Change Dockerfile `python` pack… (compare)

  • Nov 23 21:52
    amark closed #1166
Jabis Sevon
@jabis
testing get {'.':{'>':'2021/06'} expecting 7 outputs
mapfn Map functions are experimental, their behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
getter found data {
  _: { '#': 'chat.-1b4get8', '>': { stuff: 1632567525735 } },
  stuff: '2021/06'
}
ok 1 expected result to be `2021/06` correct
getter found data {
  _: { '#': 'chat.-ipfkim', '>': { stuff: 1632567525904 } },
  stuff: '22'
}
ok 2 expected result to be `22` correct
getter found data {
  _: { '#': 'chat.-oi86lk', '>': { stuff: 1632567525905.003 } },
  stuff: '23'
}
ok 3 expected result to be `23` correct
getter found data {
  _: { '#': 'chat.-ug9s0o', '>': { stuff: 1632567525906.002 } },
  stuff: '24'
}
ok 4 expected result to be `24` correct
getter found data {
  _: { '#': 'chat.-1492e3m', '>': { stuff: 1632567525907.002 } },
  stuff: '25'
}
ok 5 expected result to be `25` correct
getter found data {
  _: { '#': 'chat.1tg6rqc', '>': { stuff: 1632567525907.006 } },
  stuff: '31 1.00'
}
ok 6 expected result to be `31 1.00` correct
getter found data {
  _: { '#': 'chat.1tirdef', '>': { stuff: 1632567525908 } },
  stuff: '31 1.30'
}
ok 7 expected result to be `31 1.30` correct
valonce Chainable val is experimental, its behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
# force test to end
ok 8 forcing test to end with process.exit

1..8
# tests 8
# pass  8

# ok
and
testing get {'.':{'*':'2021/06'} expecting 7 outputs
mapfn Map functions are experimental, their behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
getter found data {
  _: { '#': 'chat.-1b4get8', '>': { stuff: 1632567559855 } },
  stuff: '2021/06'
}
ok 1 expected result to be `2021/06` correct
getter found data {
  _: { '#': 'chat.-ipfkim', '>': { stuff: 1632567559960 } },
  stuff: '22'
}
ok 2 expected result to be `22` correct
getter found data {
  _: { '#': 'chat.-oi86lk', '>': { stuff: 1632567559960.004 } },
  stuff: '23'
}
ok 3 expected result to be `23` correct
getter found data {
  _: { '#': 'chat.-ug9s0o', '>': { stuff: 1632567559961.003 } },
  stuff: '24'
}
ok 4 expected result to be `24` correct
getter found data {
  _: { '#': 'chat.-1492e3m', '>': { stuff: 1632567559962.002 } },
  stuff: '25'
}
ok 5 expected result to be `25` correct
getter found data {
  _: { '#': 'chat.1tg6rqc', '>': { stuff: 1632567559962.006 } },
  stuff: '31 1.00'
}
ok 6 expected result to be `31 1.00` correct
getter found data {
  _: { '#': 'chat.1tirdef', '>': { stuff: 1632567559963.002 } },
  stuff: '31 1.30'
}
ok 7 expected result to be `31 1.30` correct
valonce Chainable val is experimental, its behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
# force test to end
ok 8 forcing test to end with process.exit

1..8
# tests 8
# pass  8

# ok
Object was
_: {
    '#': 'chat',
    '>': {
      '2021/06': 1632567559855,
      '2021/06/22 01:00:00': 1632567559960,
      '2021/06/23 01:30:00': 1632567559960.004,
      '2021/06/24 01:00:00': 1632567559961.003,
      '2021/06/25 01:30:00': 1632567559962.002,
      '2021/06/31 01:00:00': 1632567559962.006,
      '2021/06/31 01:30:00': 1632567559963.002
    }
  },
  '2021/06': { '#': 'chat.-1b4get8' },
  '2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
  '2021/06/23 01:30:00': { '#': 'chat.-oi86lk' },
  '2021/06/24 01:00:00': { '#': 'chat.-ug9s0o' },
  '2021/06/25 01:30:00': { '#': 'chat.-1492e3m' },
  '2021/06/31 01:00:00': { '#': 'chat.1tg6rqc' },
  '2021/06/31 01:30:00': { '#': 'chat.1tirdef' }
}
Wasis Haryo Sasoko
@yokowasis

let me rephrase my quesiton :
imagine this is the data

'2021/05/31': { '#': 'chat.102jvom' },
'2021/05/30 01:00:00': { '#': 'chat.-ipfkim' },
'2021/05/29 01:00:00': { '#': 'chat.-ipfkim' },
'2021/05/28 01:00:00': { '#': 'chat.-ipfkim' },
'2021/05': { '#': 'chat.-ipfkim' },
'2021/06': { '#': 'chat.-ipfkim' },
'2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
'2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
'2021/06/23 01:30:00': { '#': 'chat.-oi86lk' },
'2021/06/24 01:00:00': { '#': 'chat.-ug9s0o' },
'2021/06/25 01:30:00': { '#': 'chat.-1492e3m' },
'2021/06/31 01:00:00': { '#': 'chat.1tg6rqc' },
'2021/06/31 01:30:00': { '#': 'chat.1tirdef' }

What's the query to get

'2021/06': { '#': 'chat.-ipfkim' },
'2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
'2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
'2021/06/23 01:30:00': { '#': 'chat.-oi86lk' },
'2021/06/24 01:00:00': { '#': 'chat.-ug9s0o' },
'2021/06/25 01:30:00': { '#': 'chat.-1492e3m' },
'2021/06/31 01:00:00': { '#': 'chat.1tg6rqc' },
'2021/06/31 01:30:00': { '#': 'chat.1tirdef' }
Jabis Sevon
@jabis
lemme add the 2021/05 back in :)
>2021/06 would result in anything over 2021/06
 _: {
    '#': 'chat',
    '>': {
      '2021/05': 1632567792690,
      '2021/06': 1632567792795,
      '2021/06/22 01:00:00': 1632567792796.002,
      '2021/06/23 01:30:00': 1632567792796.006,
      '2021/06/24 01:00:00': 1632567792797.002,
      '2021/06/25 01:30:00': 1632567792798.002,
      '2021/06/31 01:00:00': 1632567792798.006,
      '2021/06/31 01:30:00': 1632567792799.001
    }
  },
  '2021/05': { '#': 'chat.-1b4get9' },
  '2021/06': { '#': 'chat.-1b4get8' },
  '2021/06/22 01:00:00': { '#': 'chat.-ipfkim' },
  '2021/06/23 01:30:00': { '#': 'chat.-oi86lk' },
  '2021/06/24 01:00:00': { '#': 'chat.-ug9s0o' },
  '2021/06/25 01:30:00': { '#': 'chat.-1492e3m' },
  '2021/06/31 01:00:00': { '#': 'chat.1tg6rqc' },
  '2021/06/31 01:30:00': { '#': 'chat.1tirdef' }
}
total dataset
and still passing
testing get {'.':{'*':'2021/06'} expecting 7 outputs
mapfn Map functions are experimental, their behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
getter found data {
  _: { '#': 'chat.-1b4get8', '>': { stuff: 1632567792795 } },
  stuff: '2021/06'
}
ok 1 expected result to be `2021/06` correct
getter found data {
  _: { '#': 'chat.-ipfkim', '>': { stuff: 1632567792796.002 } },
  stuff: '22'
}
ok 2 expected result to be `22` correct
getter found data {
  _: { '#': 'chat.-oi86lk', '>': { stuff: 1632567792796.006 } },
  stuff: '23'
}
ok 3 expected result to be `23` correct
getter found data {
  _: { '#': 'chat.-ug9s0o', '>': { stuff: 1632567792797.002 } },
  stuff: '24'
}
ok 4 expected result to be `24` correct
getter found data {
  _: { '#': 'chat.-1492e3m', '>': { stuff: 1632567792798.002 } },
  stuff: '25'
}
ok 5 expected result to be `25` correct
getter found data {
  _: { '#': 'chat.1tg6rqc', '>': { stuff: 1632567792798.006 } },
  stuff: '31 1.00'
}
ok 6 expected result to be `31 1.00` correct
getter found data {
  _: { '#': 'chat.1tirdef', '>': { stuff: 1632567792799.001 } },
  stuff: '31 1.30'
}
ok 7 expected result to be `31 1.30` correct
valonce Chainable val is experimental, its behavior and API may change moving forward. Please play with it and report bugs and ideas on how to improve it.
# force test to end
ok 8 forcing test to end with process.exit

1..8
no 2021/05 in the hoods
also with "*" prefixed it's returning correctly only 2021/06
why don't you try it yourself
Jabis Sevon
@jabis
not many requirements
const fs = require('fs');
const tape = require('tape');
const _test = require('tape-promise').default // <---- notice 'default'
const test = _test(tape) // decorate tape
const Gun = require('../gun')
const SEA = require('../gun/sea')
require('../gun/lib/then.js')
require('../gun/lib/promise.js')
const RAD = require('../gun/lib/radisk.js')
const mkdirp = require('mkdirp');
const { Random } = require('random-js');
const random = new Random();
const _ = require('lodash');
const sleep = (milliseconds) => {
  return new Promise(resolve => setTimeout(resolve, milliseconds))
}
Gun.log.once=function(...args){ console.log(...args)}
tape tape-promise random-js mkdirp and lodash
tho I'm not really sure all of those are even required, maybe they were - long ass time since I used it since now :D
Wasis Haryo Sasoko
@yokowasis
ok, it works. it's the bug acting up. @jabis some callback is refused to fired.
it's frustating. Any idea what caused it ?
my complete html
<!DOCTYPE html>
<html lang="en" translate="no">
  <head>
    <title>PEERJS TS</title>

    <script src="https://cdn.jsdelivr.net/npm/gun/gun.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/gun/sea.js"></script>    
    <script src="https://cdn.jsdelivr.net/npm/gun/lib/radix.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/gun/lib/radisk.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/gun/lib/store.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/gun/lib/rindexed.js"></script>    
    <script src="https://unpkg.com/peerjs@1.3.1/dist/peerjs.min.js"></script>
    <script>
        var peer = new Peer(); 
        peer.on('open',(s)=>{
            console.log (s);
        })
        peer.on('connection', function(conn) {
            conn.on('data', function(data){
                // Will print 'hi!'
                console.log(data);
            });
        });        

        const gun = Gun({
                    localStorage : false,
                    axe : false,
                    file : "test",
                })
        const gunHeroku = Gun({
                    localStorage : false,
                    axe : false,
                    file : "test",
                    peers : [
                        "https://fire-gun.herokuapp.com/gun"
                    ]
                })
    </script>

  </head>
  <body>
      PEERJS TEST
  </body>
</html>
Jabis Sevon
@jabis
one thing in your constructor invalid peer it should be peers
Wasis Haryo Sasoko
@yokowasis

for some unknown reason after I commenting out the put the once callback only fired 1 out of 7

@jabis thanks. Fixed it. but still the same. Tried with peers and local, same result.

@jabis can you connect to peers https://fire-gun.herokuapp.com/gun and run this command
gunHeroku.get('chat2').get({'.': {'*': '2021/06'}}).map().once(s=>{
  console.log (s);
})
Jabis Sevon
@jabis

@jabis can you connect to peers https://fire-gun.herokuapp.com/gun and run this command

gunHeroku.get('chat2').get({'.': {'*': '2021/06'}}).map().once(s=>{
  console.log (s);
})

Well, I expected undefined and got undefined lol

writing to ./testdb/ef9oOX406VUVK0IE.json
testing get {'.': {'*': '2021/06'}} expecting output
data undefined
ok 1 s was undefined
# force test to end
ok 2 forcing test to end with process.exit

1..2
# tests 2
# pass  2

# ok
Wasis Haryo Sasoko
@yokowasis
@jabis try it again
gun only allocated i think 30ms to fetch the data before returning undefined.
Jabis Sevon
@jabis
Ok this works, first fetching the parent object
console.log("testing get {'.': {'*': '2021/06'}} expecting output")
  await gun.get('chat2').then();  
  await gun.get('chat2').get({'.': {'>': '2021/06'}}).map().once(s=>{
    console.log ("data",s);
    t.notEqual(s,undefined,"s was not undefined");
  }).then()
I think that was a known bug
testing get {'.': {'*': '2021/06'}} expecting output
data { _: { '#': 'chat2/2021/06/25 01:30:00' } }
ok 1 s was not undefined
data { _: { '#': 'chat2/2021/06/31 01:00:00' } }
ok 2 s was not undefined
data { _: { '#': 'chat2/2021/06/31 01:30:00' } }
ok 3 s was not undefined
data { _: { '#': 'chat2/2021/06' } }
ok 4 s was not undefined
data { _: { '#': 'chat2/2021/06/22 01:00:00' } }
ok 5 s was not undefined
data { _: { '#': 'chat2/2021/06/23 01:30:00' } }
ok 6 s was not undefined
data { _: { '#': 'chat2/2021/06/24 01:00:00' } }
ok 7 s was not undefined
# force test to end
ok 8 forcing test to end with process.exit

1..8
# tests 8
# pass  8

# ok
Wasis Haryo Sasoko
@yokowasis
@jabis does that mean you have to fetch all the data first ? if possible I want to fetch only the data I need.
Jabis Sevon
@jabis
I'd say you only need to trigger a query first
fetching the parent "chat" -object once won't fetch all data I think, only one level
Wasis Haryo Sasoko
@yokowasis
if this is a chat app, 1 level can easily have 1000 entries.
Jabis Sevon
@jabis
add some metadata node that doesn't have anything interesting
Gessic
@gessicapps_twitter
Hi, how do I set something to null? everytime I try, it just adds a new entry/node:
feedProviders.get(providerAddress.Algaddress).set(null);
image.png
Wasis Haryo Sasoko
@yokowasis
@gunar put(null)
@gessicapps_twitter put(null)
Gessic
@gessicapps_twitter
Perfect, thanks @yokowasis
Gessic
@gessicapps_twitter
how can I return the values from .once() without using a callback? It doesnt seem to be an async function...
Jabis Sevon
@jabis
include gun/lib/then.js or gun/lib/promise.js
4 replies
@gessicapps_twitter ^
Jabis Sevon
@jabis
image.png
for example
David Dahl
@daviddahl
@amark No worries. My ignorance of AXE was the issue. I have watched the talk you gave on it... Exciting stuff man. And yes, I get it ,making shit just WORK is important. Now that I think about it, Libp2p and IPFS do that too :)
There are a lot of onion skins for me to pull back yet with GUN.
David Dahl
@daviddahl
@amark was that talk yesterday recorded? I am curious about your concept - I have been talking about UX and crypto for some time - Search & privacy sounds interesting...
aaronsantiago
@aaronsantiago

I'm using gun to update a react page with a lot of user-editable elements that are synced across devices, and I'm noticing that it can sometimes take a while (30 - 90 seconds) to get to the latest version (it seems like it runs through a lot of the history). I would think that gun would locally cache calls to .get()?

Also would using .set() instead alleviate some of these issues? There are a lot of entries in there that are nulled or marked as deleted and it has to download the non-nulled versions first before deleting them making for a poor UX

Adam
@adam-12:matrix.org
[m]
@aaronsantiago might benefit from using the option change: true when using once().