-
Notifications
You must be signed in to change notification settings - Fork 42
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
Support an in-browser POD : local storage via data:// scheme #113
Comments
Or how about a browser extension that stores data in its own storage? Would love to brainstorm about this! |
How about a separate library that can create a POD on the service worker? Likes https://github.com/linonetwo/ipfs-browser-gateway But SW is not very convenient for some of the developers and environments. So yes, if it's integrated into I think a potential usage is using it as a local cache when the user doesn't actually have a WebID. If you are new to SoLiD and want to try out a note-taking app, It may provide a local POD for you. (maybe |
I think a browser extension is a great idea to use in addition to my idea rather than a replacement for it. The advantage of building it into solid-auth-client is that any app will then be able to dependably use rdflib/query-ldflex to interact with the local storage (or indexed db) whereas they could not count on having an extension installed. |
@michielbdejong I've created a file:// handler for rdflib which basically treats the file system as a minimal Solid REST server. It might be a useful piece of a browser extension for an in-browser POD. It also has some tests that might be useful elsewhere. |
My in-browser-pod is almost ready for prime time. It can store and access resources and containers in localStorage via rdflib. It would be accessible in all apps if you include a cutout for it in solid-auth-client (if the IRI scheme is app://, use solid-rest-browser's fetch). Here's links to a working demo and the code repo.. It's not finalized, but it does the basics, such as returning a GET request for a Container as a set of LDP:contains triples. |
Update : the in-browser storage can now handle GET, PUT, POST, DELETE on resources and containers according to (my interpretation of) the Solid REST spec. It can transparently handle all rdflib methods except those requiring PATCH and that most likely goes for most other Solid libraries. It doesn't touch ACL or other related specs, only the REST interaction. I've had reports it works fine on iPhone and Android. |
@RubenVerborgh I am ready to submit a PR to include a single line at the top of solid-auth-client's fetch
Should I expect the user to load solid-rest-browser themselves so that appfetch pre-exists? Or should it be imported by solid-auth-client? Or are you considering not including the PR at all. If so, please explain. |
If possible, I would suggest |
I'm sorry, I'm pretty slow-witted when it comes to require/import and webpack. Could you clarify where the require would occur and what you mean about the webpack? |
Sure, so that would need to become: if(input.startsWith("app:"))
return require("solid-rest-browser").fetch(input,options); and https://github.com/solid/solid-auth-client/blob/v2.3.0/webpack/webpack.common.config.js#L28 would need something like
|
Ah! Thanks so much! I am starting to get it. It does sound like the cleanest way. Two more questions: users will need to import solid-rest-browser in a script tag placed before the script tag for solid-auth-client? And solid-rest-browser will not be included at all in the package.json for solid-auth-client? Oops third question: users will get an error if they try an app:// url without having imported it ... should there perhaps be a try/catch around the require in solid-auth-client to warn them? |
If they use the default webpack build
It would actually. It would just not be bundled with the default webpack build.
That wouldn't be really clean, because a |
Great! I'll set that all up and submit a PR. Thanks very much for your help! |
This may be hair-brained, but it could potentially have many uses. It could work by making a cut-out in solid-auth-client.fetch() that handed fetching of data:// URIs to a local-storage aware library that returns success/failure in an object similar to what an HTTP fetch returns. There could be sync apps that would use standard rdflib or ldflex methods to copy files to a cloud-based POD. I can work on this if you think it's useful.
The text was updated successfully, but these errors were encountered: