Commit Graph

5925 Commits (de1f57ca631f8c00175e3bda1186f0758d7aa72c)

Author SHA1 Message Date
ansuz b59a14c5ac merge hyperjson changes from realtime xwiki
more resilient class serialization.
comments
ansuz 2691d85582 use forked chainpad with assertions for _socket
Yann Flory b41f0e8c50 Merge branch 'cjd-fixed-it-with-hax' into netflux2
ansuz c50690349b comments describing the role of each argument
ansuz df78d284c4 initial state should be valid JSON so JSON parse doesn't fail
ansuz 96e03fcfa4 Use latest chainpad without mutations
ansuz d5772c6315 when json-ot produces json that fails to parse...
export the relevant data to a window variable so we can inspect it better
ansuz aaf7c777cc add debugging info to the textPatcher
* kill dead code
* add assertions
* better logging for insertions and removals
ansuz 523df40d09 Debugging concurrent typing:
track whether there are local operations in progress, such that we can tell
whether a remote change is interrupting the DOM's conversion to hjson.
ansuz e446a3645c don't send funny BR attributes over the wire. Properly initialize the typing test
ansuz 22290590cb don't rely on window scope in typingTest.js
ansuz 772ca5d30e comment out debugging line
ansuz 6c340a6527 chainpad testing = true, reject non-compliant messages
ansuz afa1104d85 Pull the cursor out of bogus BR tarpits when it gets stuck
ansuz bac0e0ff88 implement hyperjson filtering
ansuz e51635c4bb fix index error
ansuz 3aebf7d2c2 minor changes to pass linting
ansuz 29e24f556c kill another window variable
ansuz e699073d45 attempt to preserve the magic line plugin while someone else is typing
ansuz 941f5361ea forgot to add 'typingTest', which main depends on
ansuz d852c578d8 removed dead code
ansuz 5591aae8fa Clean up main file
* convert.js includes the vdom library, which we aren't using anymore
  - removed, and replaced with the simple functions from Hyperjson and Hyperscript
* removed several variables that had been exported to 'window'
* moved the testing functions out into their own file for easier reuse
* restructured realtime initialization to be more compact
ansuz 478ccbf984 revert changes to chainpad
ansuz e3b78e20de Merge branch 'cjd-fixed-it-with-hax' of github.com:xwiki-labs/cryptpad into cjd-fixed-it-with-hax
ansuz e26246178f start to clean up and give things more sensible names.
get rid of the textarea entirely
Caleb James DeLisle b372b0b77c small change to chainpad in order to make it more likely to fail if the authDoc goes into the wrong state
Caleb James DeLisle f3fb674504 Merge branch 'cjd-fixed-it-with-hax' of github.com:xwiki-labs/cryptpad into cjd-fixed-it-with-hax
Caleb James DeLisle 98c85cef8b xxx
ansuz 12dcbc9121 fix quick red fox and make test.cancel work again
Caleb James DeLisle 62eabbc7ae If a message does not match parent hash, don't delete it from storage
Caleb James DeLisle dbf31798d5 json-ot triggering PARANOIA errors in ChainPad
Caleb James DeLisle 03932d0169 small changes to chainpad for testing
Caleb James DeLisle 669bcc1935 If there is a difference in the hjson then send a message back
Caleb James DeLisle f62ec85a4c Shuffled around some assertions and logs
Caleb James DeLisle 420a7098a6 more testing and crap
ansuz 4b35a145e3 Push WIP
ansuz 42c972116b leave TODO re: diffDOM and magicline
Hyperjson guarantees that magicline elements are not sent across the wire.
DiffDOM must guarantee that magicline elements will not be removed on remote edits.
ansuz e066730b68 add notes about how hyperjson is to be used
ansuz cd462ed872 Merge legacy websocket version
ansuz c047d5310f implement optional filtering in hyperjson
Implemented via callback, return falsey if you want to filter an element
and all of its children from the serialized result.

Conflicts:
	www/common/convert.js
ansuz 0d33af773f implement optional filtering in hyperjson
Implemented via callback, return falsey if you want to filter an element
and all of its children from the serialized result.
ansuz 475ca9bea8 hyperjson.js : used split instead of filter... oops
ansuz 1bd5cb9e27 hyperjson.js : used split instead of filter... oops
ansuz b2753ef7b7 fix string manipulation off-by-one
ansuz f98fda7604 fix string manipulation off-by-one
ansuz 4f3fcb08a4 better error reporting when the operational transform fails to parse JSON
ansuz 0ff4906f0e implement better serialization of class names
RTWYSIWYG-27 : poorly formed yet valid HTML caused hyperjson to produce element
               selectors which hyperscript could not parse.
ansuz fbe6225681 Don't attempt to use the cursor selection when it has length 0
RTWYSIWYG-20
RTWYSIWYG-24
ansuz 0c6222b5f9 better error reporting when the operational transform fails to parse JSON
ansuz 79a9998b13 implement better serialization of class names
RTWYSIWYG-27 : poorly formed yet valid HTML caused hyperjson to produce element
               selectors which hyperscript could not parse.
ansuz bd24821c6c Don't attempt to use the cursor selection when it has length 0
RTWYSIWYG-20
RTWYSIWYG-24
Yann Flory de6db0285c Limit the size of the usernames to 32 chars
Yann Flory 38d797a4f1 Fix issue with Chrome and WebRTC
Yann Flory 7237c751d5 Move 'vdom' to the main 'pad'.
Hide the right-hand panel (can de bisplayed with a 'debug' button)
Hide the IDs of users if they don't change their name
Yann Flory e77d85bc82 Trigger an onReady() method when the user's pad is fully synced (the history is loaded)
Yann Flory eca4ec699c Ability to change the username (the user ID is displayed by default)
Yann Flory 6e50ae94dd Remove unused code
Yann Flory 5da8560e22 Fix the user list in the toolbar keeping old data with the WebSocket server
Chainpad is no longer responsible for the userlist or the ping
Yann Flory 3a188625e0 Improve the detection of a disconnected peer to update the user list with the WebRTC service
Yann Flory 77e7fb5724 Fix an issue with the WebRTC service where it was impossible to join a channel once someone had left this channel
Yann Flory 06e5c84702 Clean some code
Yann Flory 29033f344c Merge branch 'netflux' of github.com:xwiki-labs/cryptpad into netflux
Yann Flory b1e8bcddef Fix the user list not working with the WebRTC service and causing major issues
Yann Flory c576241104 Add a Chainpad adapter to make Chainpad know the userList
ansuz fb0e82931d correct malformed json
Yann Flory ae8f6f7f2c Ability to choose which protocol to use (Websocket or WebRTC) with Netflux
ansuz 3a7af63c54 correct malformed json
Yann Flory b7885eb539 Fix channel history
ansuz 136e2d8cf2 pass in missing textarea argument so textpad starts working again
ansuz 8258018c1d Revert "fix undefined reference"
This reverts commit 7d65540123.

To restore functionality in convert.js
ansuz c67451bc1a Revert "remove broken functions from convert module"
Because I forgot that the /render/ page was still using vdom

This reverts commit 93fb944e1f.
Yann Flory c536ecbc1c Temp commit
Yann Flory 870b2dbb7e Add the WebRTC server in Cryptpad
Yann Flory c4f62fb812 First try with WebRTC
Yann Flory 09a06a8bc5 Replace the chainpad server by the netflux server
Yann Flory 60c3aceb0d Add chatflux server
Yann Flory deb2084fc5 Add the socket connection checker
ansuz d3e2a2f52e make verbose logging switchable via a conditional
ansuz 1c54af69a1 update minor editors to use new realtime-input api
ansuz 9b228eea6b modify vdom main.js to adhere to new realtime-input api
ansuz fefb904261 realtime input changes
ansuz fd99dba4a3 modify realtime-input api to take a single object as configuration. merge netflux API
Yann Flory 62ba579d4a Add Netflux API with WebSocket service V1
ansuz 53d3e475f7 ui hints for hackpad
ansuz d2f4fbcee9 fail the toolbar from the application layer
ansuz d7b34cf6be don't call toolbar from within realtime-input.js
ansuz e8469ae1bb test out extended realtime-input api
ansuz 5e1566eaec fix incomplete 'onAbort' block
ansuz 52fe892bae invert logical relationship with flag
otherwise updates don't actually propogate
ansuz 938df2b92f lock the editor until the chain has synced
add 'onAbort' hook. lock the editor if the connection fails.
ansuz 1d6ccc99a1 add 'onAbort' hook to realtime-input.js
ansuz e5bef52850 reintroduce the toolbar
ansuz 6ff5b10486 remove local diffDOM version
ansuz 93fb944e1f remove broken functions from convert module
ansuz 7d65540123 fix undefined reference
ansuz c246adc57b Lock contenteditable until chain is done syncing.
Don't bother patching the dom until the chain has synced
ansuz 1c0074258c go back to using diffDOM from bower
The latest version is required. You'll need to update.
ansuz 79bd82a62e main.js : integrate with patched diffDOM
ansuz 6884fabda9 Use local diffDOM instead of bower_components
At least until the PR gets accepted
ansuz f5a8727254 remove some unused functions from cursor.js
ansuz db1515c445 cursor.js : commit before cleaning up
ansuz 7e367e770e resize vdom debug panel to 30% width
ansuz 91ada5ce7a export Operation from chainpad. for use with OT
ansuz 5425699f43 check if possible parent exists before checking if it contains another element
ansuz 67bdb8a65a fix a bad regex that occasionally threw an error
'nothing to repeat'
ansuz e87a4599a4 main.js : tiny patch until things are working correctly.
ansuz 9ce59c985f only do stuff with the cursor when a remote edit takes place
ansuz 39f56d4fd1 throw error when checking for the index of a node that has no parent.
it probably isn't in the dom if this is the case.
Check if it's there before using this function
ansuz de46be85ba add better helpers for finding and resetting the cursor
ansuz 7e7f1fee76 include abstracted json-ot, add comments, start to use cursor stuff
ansuz c09036bd29 snapshot cursor.js, as some things are working quite well now
ansuz 4eee1f5210 add orderOfNodes function to tree library
ansuz 7689151fc0 pull json validation for OT into its own module for reuse
ansuz fbb9163e42 main.js : clean up and commit before making big-ish changes for cursor fixing
ansuz 2c8a2406c6 cursor.js : snapshot before code deletion
ansuz 1beb3f5355 snapshot of treesome.js before deletion
ansuz 8ead5ca129 realtime-input.js : add notes regarding integration of the netflux api
ansuz 3cb94b8d80 jshint compliance
ansuz d1885fbab6 better jshint compliance for common files
ansuz 539cc3a2fa remove unused files from common directory
ansuz afa2811472 remove local version of marked.js, prefer bower version
ansuz 587f95b6d7 don't overflow
ansuz a01331cb9a hide styling textarea no matter what
ansuz a600ece5c5 fix jshint complaints in common directory
ansuz 4a05a859e6 fix initialization routines
ansuz f1915d3b7c fix jshint complaints in pad directory
ansuz fe3917c0f1 fix jshint complaints in codemirror directory
ansuz 2c5a2b6023 remove unused code, add todos, fix minor errors
ansuz c5ab5dfe26 realtime style editor with lorum ipsum
ansuz 967d636df9 address more jshint complaints
ansuz f6c848385f hyperjson.js : jshint complains about var index in for loop
ansuz 0fbbb51f7f drop this useless line
ansuz d1dd497457 html-patcher.js : add missing semicolon
ansuz 62ea172ff4 errorbox.js : add missing semicolon so jshint doesn't complain
ansuz 3b5c932252 jshint ignore eval line
ansuz 7f92abc7bf Merge branch 'diffdom' of github.com:xwiki-labs/cryptpad into demoEffect
Caleb James DeLisle a7da21ccba Remove the cursor treatment
Caleb James DeLisle 86c4a69a97 Switch to patching with DiffDOM for testing :D
ansuz 653ba33b65 Merge branch 'vdom' of github.com:xwiki-labs/cryptpad into demoEffect
Caleb James DeLisle 2031191261 testing=false
Caleb James DeLisle 37db31b09e Attempt an operational transformation and if the result is not valid JSON then fail
Caleb James DeLisle e16299b5c4 Revert "restub OT until it's verified"
This reverts commit 350c9e6c76.
ansuz c22269e36e cursor.js : make the console a little less noisy
ansuz 350c9e6c76 restub OT until it's verified
ansuz 99a23154b7 files for unstubbing OT
ansuz c740c0ec92 add stuff for walking the tree
ansuz ad184b1114 add stuff to recover the cursor
ansuz 1aea11bb30 describe all the prototypes which are available
ansuz 9b13fd8f34 pull cursor correction code out of main.js
put it in cursor.js
ansuz 3b0ac3af4c More sensible styles
respond to viewport size
don't use gigantic font
ansuz b43674eb53 switch back to two-panel layout
ansuz f33e061c9a visit /hack/ to see what this is
I'll leave it up to the users to decide
whether XSS is a bug or a feature
ansuz 019750bea8 realtime-input.js : callback onInit if exists
ansuz 61fbf81dcd factor out rainbow stuff into rainbow.js
ansuz 7102a0a164 make rainbows
ansuz aa3880f442 up to date
ansuz d2f6c63d8a realtime-input.js : changed the api and left an undefined reference. fixed
ansuz 150c9a300d scale viewport so mobile is readable
ansuz d96124229b clean up realtime-input.js, break API
use an object for configuration, so as to be more extensible.
modify applications which use the API to match.
ansuz e43b9715e8 remove /md/ prototype
use /text/ and /render/ instead.
ansuz 64cc177a60 remove vmd directory
it was only a prototype, and only contained code which was no longer useful
ansuz e220113e98 fix the 'crapstorm' bug
ansuz ed03a48092 minor patches that make things a bit more reliable, still some bugs
ansuz ac0f7852fc committing latest changes for review
ansuz 2016550e01 virtual-dom.js : identify problem area?
ansuz 08fb010627 give 'onChange' a name
ansuz b52327be49 restyle /text/ page
ansuz 266e5eccce change styles for rendered page
ansuz 2adfeaaaaa test having multiple textareas in one page
ansuz 3cffdc982f remove unused functions from render/main.js
better comments
ansuz 317abf36f3 make rendered images sort of responsive
ansuz 388c6de64a minor style tweaks for /render/
ansuz ec172b6d21 rendered html should be scrollable
ansuz a484b920e3 disallow resizing of textarea
ansuz d9d4abb9a5 don't let the textarea overflow the body
ansuz dcbbeea734 solarized dark color scheme in /text/
ansuz c2eb29b75e fix typo
ansuz fd1e5d5735 better styling on render page
now solarized dark
ansuz a718f89e08 make a new pad that doesn't allow input.
It simply renders markdown that's being written in the same channel
but in another editor that allows input.
ansuz 2e3b424a1a sanitize markdown before rendering to prevent XSS
draw rainbox borders on element redraws in vdom method.
This lets us see what being redrawn, as the vdom.diff method
is breaking a few things.
ansuz 13f5371199 remove duplicated files
ansuz aa6bbabc62 prototype a vdom-based markdown editor
avoid unnecessary redraws.

discover a bug, apparently vdom replaces all child elements after an
element which was modified.

As such, changing b in [a, b, c, d] causes b, c, and d to be redrawn.
This is undesirable.
ansuz d14e42fedd start on a vdom-based wysiwyg realtime
There are still a few conditions that cause it to 'explode'
when different browsers disagree on element semantics.

Overall it's a much cleaner approach, but it will require
extensive tuning to improve performance, as there are still
many complete dom traversals which will not scale for large documents
ansuz 1f7f90165f Slap marked.js onto a textarea
Multiple people can now edit markdown and see the results in realtime.
ansuz d5a1629a93 A really basic shared text area with encryption.
...and not much else. If you want to hack on something
this is a great place to start.
ansuz 50121c8ab6 a really basic collaborative input
type="text" is typically slower than the same code
when used to sync a textarea.

WATCH OUT!
ansuz b18dfef656 sharejs textarea is used by realtime-input.js
ansuz 997ce1147f realtime input wraps up basic realtime stuff
so we don't have to rewrite the realtime api for every application.
starting to move towards a portable api :D
ansuz 40b8c0efe8 drop in chjj's marked.js for a cool demo
ansuz 2d8ffdf31c Merge branch 'master' of github.com:ansuz/cryptpad
ansuz 0c2e057f9d export component APIs from convert
ansuz b958caebdd dom, vdom, hyperjson, and an api which provides a matrix of conversions
ansuz 4cf2a8a0bd rtwiki.js : catch some typeErrors
Lars-Magnus Skog 84c0ea6d26 refactor: pass in ifrw.CodeMirror into andThen()
ansuz 663e987345 fix race condition in codemirror initialization
over slow connections, iframes don't load fast enough to be ready for code
which depends on certain features existing.

wait until they're ready, then initialize.
ansuz 2ed9f0867a Merge branch 'master' of github.com:xwiki-labs/cryptpad into codepad
ansuz c71b060dc2 main.js : wait until your editor is defined before trying to reference it. addresses a race condition that caused ckeditor to fail half the time.
ansuz ff52f050e5 chainpad.js : pull in upstream changes to chainpad.js. new APIs
ansuz 9fc44cdf0c add notes to clientside js files
mouhb af80bed07b XWR-190: Make CryptPad version with rtwiki/CodeMirror
mouhb 9626dfc365 XWR-190: Make CryptPad version with rtwiki/CodeMirror
Yann Flory 9a932a3f56 Patch Realtime into CodeMirror in CryptPad
Yann Flory 32f44161a7 Patch Realtime into CodeMirror in CryptPad
Caleb James DeLisle 88fb6772e8 Cleaned up the front page and added a little piece of code to show recent pads
Caleb James DeLisle 51544db9a2 Completed adding of customization system and bottom infobar
Caleb James DeLisle 84164123b6 not quite finished
Caleb James DeLisle 0e44b10aeb Seperated common crypto operations to common file and made common toolbar used for both pad and spreadsheet
Caleb James DeLisle e039e90a24 upgrade to most recent chainpad
Caleb James DeLisle c13bfe978a Switched cryptpad to use common/toolbar.js which is shared with cryptsheet
Caleb James DeLisle 50c10f818e Added cryptsheet to cryptpad suite!
Caleb James DeLisle 4a63ba7df3 Give cryptpad a proper main page
Caleb James DeLisle 652a1da7a4 oops changed some work in the js file
Revert "change logo"

This reverts commit 9325100a02.
Caleb James DeLisle 9325100a02 change logo
Caleb James DeLisle 3330fae47e typo
Caleb James DeLisle 8fc732d879 remove the 'magic line' because it causes problems with the realtime
Caleb James DeLisle 0d3ded68a0 use a websocket which automatically reconnects if the connection is lost
Caleb James DeLisle e3a54c11ee remove some code which may be over-engineering
Caleb James DeLisle 2a1f3f9027 show a little spinner which spins when loading and when people type
Caleb James DeLisle 87aa1aaf91 don't start measuring lag until after syncing and update readme
Caleb James DeLisle 6d68bb0bde error when opening error message window D:
Caleb James DeLisle 6cbdcdec65 Show users editing and lag, properly send message to indicate that all users have left channel and show basic error box if disconnected.
Caleb James DeLisle 5ae599fa07 support different ports for websocket and http
Caleb James DeLisle a6b88e276c use the slower version of applyHTMLOp
Caleb James DeLisle b6523adb1f rand fixed
Caleb James DeLisle 1508c7ba71 and so it begins