feat: Implement WebcamFileSource for life webcam capture #12

Open
busti wants to merge 51 commits from busti/proto/frontend into jedi/proto/frontend
Showing only changes of commit b4ea1d8df2 - Show all commits

View file

@ -14,6 +14,7 @@ export default createStore({
item_map: {}, item_map: {},
//notifications: [], //notifications: [],
messages: [], messages: [],
home_server: null,
resolver: new FallBackResolver(), resolver: new FallBackResolver(),
unreachable_neighbors: new NeighborsCache(), unreachable_neighbors: new NeighborsCache(),
}, },
@ -95,7 +96,7 @@ export default createStore({
} }
}, },
async getFriends(state) { async getFriends(state) {
return ['jedi@j3d1.de', 'foobar@example.com', 'foobaz@example.eleon']; return ['jedi@j3d1.de', 'foobar@example.com', 'foobaz@example.eleon', 'alice@example2.com'];
}, },
async getFriendServer({state}, {username}) { async getFriendServer({state}, {username}) {
const domain = username.split('@')[1] const domain = username.split('@')[1]
@ -105,6 +106,10 @@ export default createStore({
return ['127.0.0.1:8000']; return ['127.0.0.1:8000'];
if (domain === 'example.com') if (domain === 'example.com')
return ['10.23.42.128:8000']; return ['10.23.42.128:8000'];
if (domain === 'example.jedi')
return ['10.23.42.128:8000'];
if (domain === 'example2.com')
return ['10.23.42.128:9000'];
const request = '_toolshed-server._tcp.' + domain + '.' const request = '_toolshed-server._tcp.' + domain + '.'
return await state.resolver.query(request, 'SRV').then( return await state.resolver.query(request, 'SRV').then(
(result) => result.map( (result) => result.map(
@ -175,13 +180,28 @@ export default createStore({
if (username in state.friends) { if (username in state.friends) {
return true; return true;
} }
const server = await dispatch('getFriendServer', {username}) state.home_server = 'localhost:8000'
const data = await dispatch('apiFederatedPost', { const home_reply = await dispatch('apiFederatedPost', {
host: server[0], host: state.home_server,
target: '/api/friendrequests/', target: '/api/friendrequests/',
data: {befriender: state.user, befriendee: username, befriender_key: nacl.to_hex(state.keypair.signPk)} data: {befriender: state.user, befriendee: username}
}) })
console.log(data) if (home_reply.status !== 'pending' || !home_reply.secret)
return false;
console.log('home_reply', home_reply)
const befriendee_server = await dispatch('getFriendServer', {username})
const ext_reply = await dispatch('apiFederatedPost', {
host: befriendee_server[0],
target: '/api/friendrequests/',
data: {
befriender: state.user,
befriendee: username,
befriender_key: nacl.to_hex(state.keypair.signPk),
secret: home_reply.secret
}
})
console.log('ext_reply', ext_reply)
return true; return true;
} }
}, },