Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: Adds possibility to use holochain link language when sharing a perspective & Adds a new expression language: Junto Short Form #4

Open
wants to merge 48 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
374baac
add profiles dna
jdeepee Jan 4, 2021
df0f877
others fn in linkadapter to return promise
jdeepee Jan 4, 2021
c25c439
first pass of "social context" link language
jdeepee Jan 4, 2021
63b6784
cleanup of langs
jdeepee Jan 4, 2021
63899bb
remove gun-links & use bash oneliner for build-languages
jdeepee Jan 5, 2021
845a87f
ipfs links others() fn as async
jdeepee Jan 5, 2021
a66d20f
add missing rollup config for public social context links
jdeepee Jan 5, 2021
502295d
add dna.js to sc
jdeepee Jan 5, 2021
2a04526
script for cleaning holochain dir and building shortform
jdeepee Jan 5, 2021
a24c5f9
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 7, 2021
8be6f86
styling tweaks to ConstructorIcon.svelte
cubanmercury Jan 7, 2021
b79b376
Merge branch 'develop' of github.com:jdeepee/perspectivism into develop
cubanmercury Jan 7, 2021
458f412
Merge branch 'master' of https://github.com/lucksus/perspectivism int…
jdeepee Jan 7, 2021
032ae88
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 7, 2021
87e7de0
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 8, 2021
e39f986
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 8, 2021
4ba9d9a
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 9, 2021
229b361
lock file
jdeepee Jan 9, 2021
704317c
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 12, 2021
352ab54
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 12, 2021
02e3cbc
fix imports
jdeepee Jan 12, 2021
24333b1
wire up basic social context link store
jdeepee Jan 12, 2021
3e196e5
return get_others response from link language directly
jdeepee Jan 12, 2021
c89850b
holochain link language now an option for a shared perpective
jdeepee Jan 13, 2021
5af7fb0
short form dna now integrates with acai much more closely by storing …
jdeepee Jan 14, 2021
3218bb1
Merge remote-tracking branch 'upstream/develop' into develop
jdeepee Jan 14, 2021
2e37891
add back gun-links
jdeepee Jan 15, 2021
604f43b
added integration with update & delete zome functions for social context
jdeepee Jan 15, 2021
49aad64
add gun links rollup files
jdeepee Jan 15, 2021
25ab785
remove dev cleanup script
jdeepee Jan 15, 2021
4b41132
Merge pull request #5 from lucksus/develop
lucksus Jan 18, 2021
9c494c5
Added missing rollup files for social context
jdeepee Jan 19, 2021
204e144
added possibility to insert seed into holochain link language such th…
jdeepee Jan 20, 2021
81721a8
Merge branch 'master' of https://github.com/lucksus/perspectivism int…
jdeepee Feb 13, 2021
18b4f9f
Merge branch 'develop' of https://github.com/lucksus/perspectivism in…
jdeepee Feb 13, 2021
0ac4ef0
Updated social context dna
jdeepee Feb 13, 2021
baf2845
use lucksus remote for forked deps
jdeepee Feb 13, 2021
01af3d0
update package lock
jdeepee Feb 13, 2021
1018d9b
add languages dna js file
jdeepee Feb 13, 2021
b76e77b
add languages dna js file
jdeepee Feb 13, 2021
359a490
fix holochain link language
jdeepee Feb 13, 2021
a5d73a5
Merge branch 'develop'
lucksus Feb 24, 2021
c025fc6
Rename directory ACAI -> AD4M plus more string/doc/path replacements
lucksus Feb 24, 2021
b31d052
More path renaming acai -> ad4m
lucksus Feb 24, 2021
4b4eb64
Rewrite AD4M README
lucksus Feb 24, 2021
d7640ab
Replace old screenshots with logo in main readme
lucksus Feb 24, 2021
93bec0c
Fix typo
lucksus Feb 24, 2021
ab91494
Merge remote-tracking branch 'upstream/master' into develop
jdeepee Mar 16, 2021
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add back gun-links
  • Loading branch information
jdeepee committed Jan 15, 2021
commit 2e37891e21d21523edfa476500512d997bd02dc7
46 changes: 46 additions & 0 deletions src/languages/gun-links/Settings.svelte
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
<svelte:options tag={null}/>

<script lang="ts">
export let settings: object
import Switch from '@smui/switch';

customElements.define("notes-ipfs-mdc-switch", Switch)

if(!settings) {
settings = {
gunDbPeer: '',
runServer: false,
port: 9988,
}
}



</script>

<div class="container" on:click:stopPropagation>
{#if settings }
<table>
<tr>
<td>Bootstrap Peer:</td>
<td><input bind:value={settings.gunDbPeer}></td>
</tr>
<tr>
<td>Run server:</td>
<td><Switch bind:checked={settings.runServer}></Switch></td>
</tr>
<tr>
<td>Listen to port:</td>
<td>
{#if settings.runServer}
<input bind:value={settings.port}>
{:else}
<input disabled bind:value={settings.port}>
{/if}
</td>
</tr>
</table>
{:else}
Loading...
{/if}
</div>
Empty file.
25 changes: 25 additions & 0 deletions src/languages/gun-links/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import type Address from '../../acai/Address'
import type Agent from '../../acai/Agent'
import type Language from '../../acai/Language'
import type LanguageContext from '../../acai/LanguageContext'
import type { Interaction } from '../../acai/Language'
import { GunLinksAdapter } from './linksAdapter'
import { GunSettingsUI } from './settingsUI'

function interactions(a: Agent, expression: Address): Interaction[] {
return []
}

export default function create(context: LanguageContext): Language {
const linksAdapter = new GunLinksAdapter(context)
const settingsUI = new GunSettingsUI()

return {
name: 'gun-links',
linksAdapter,
settingsUI,
interactions,
} as Language
}

export const name: string = "gun-links"
124 changes: 124 additions & 0 deletions src/languages/gun-links/linksAdapter.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
import type Expression from "../../acai/Expression";
import type { LinksAdapter, NewLinksObserver } from "../../acai/Language";
import type Link from "../../acai/Links";
const Gun = require("gun")
require('gun/lib/load.js')
require('gun/nts.js')
import type LanguageContext from "../../acai/LanguageContext";
import { SHA3 } from "sha3";
import type ExpressionRef from "../../acai/ExpressionRef";

export class GunLinksAdapter implements LinksAdapter {
#callbacks: NewLinksObserver[];
#gun: any

constructor(context: LanguageContext) {
this.#callbacks = []

const dbPath = context.storageDirectory + "/gun"
const opts = {
file: dbPath,
localStorage: false
}

// @ts-ignore
if(context.customSettings.gunDbPeer) {
// @ts-ignore
opts.peers = {}
// @ts-ignore
opts.peers[context.customSettings.gunDbPeer] = {}
}

// @ts-ignore
if(context.customSettings.runServer) {
// @ts-ignore
const server = require('http').createServer().listen(context.customSettings.port);
// @ts-ignore
opts.web = server
}

this.#gun = new Gun(opts)

this.#gun.get('root-links').map().open(links => {
console.log("GUN-LINKS: Received root links:", links)
this.#callbacks.forEach(callback => {
callback([links])
})
})

}

writable() {
return true
}

public() {
return true
}

others() {
return []
}

async getRootLinks(): Promise<Expression[]> {
return await new Promise((resolve) => {
this.#gun
.get('root-links')
.load(linksObject => {
const links = Object.values(linksObject) as Expression[]
console.log("GUN-LINKS: Found root links:", links)
resolve(links)
}, {wait:1})
})
}

addRootLink(link: Expression) {
console.log("GUN-LINKS| adding root link:", link)
const linkNode = this.addLink(link)
this.#gun.get('root-links').set(linkNode)
}

addLink(linkExpression: Expression) {
const hash = new SHA3(256);
hash.update(JSON.stringify(linkExpression));
const addr = hash.digest('hex');

const linkNode = this.#gun.get('links').get(addr).put(linkExpression)

const link = linkExpression.data as Link

// store link in both directions:
// 1. from source to target
this.#gun.get('sources').get(link.source).set(linkNode)
// 2. from target to source
this.#gun.get('targets').get(link.target).set(linkNode)
// 2. by predicate
this.#gun.get('predicates').get(link.predicate).set(linkNode)

return linkNode
}

async getLinksFrom(source: ExpressionRef): Promise<Expression[]> {
return await new Promise((resolve) => {
this.#gun
.get('sources')
.get(source)
.load()
.once(links => resolve(links))
})
}

async getLinksTo(target: ExpressionRef): Promise<Expression[]>{
return await new Promise((resolve) => {
this.#gun
.get('sources')
.get(target)
.load()
.once(links => resolve(links))
})
}

addCallback(callback: NewLinksObserver) {
this.#callbacks.push(callback)
}
}
Loading