Skip to content
This repository has been archived by the owner on Feb 12, 2024. It is now read-only.

Factor out Daemon / Gateway endpoints handlers #1855

Closed
Gozala opened this issue Jan 30, 2019 · 3 comments
Closed

Factor out Daemon / Gateway endpoints handlers #1855

Gozala opened this issue Jan 30, 2019 · 3 comments
Assignees
Labels
kind/support A question or request for support kind/wontfix status/ready Ready to be worked

Comments

@Gozala
Copy link
Contributor

Gozala commented Jan 30, 2019

  • Version: v0.33.1
  • Platform: Browser
  • Subsystem: Workers / WebExtensions

Type:

Feature

Severity:

Medium

Description:

TL;DR

IPFS SW should use local IPFS node on the system and transparently fallback to in-browser IPFS node when local node isn't available.

Overview

I am working towards makeing in-browser IPFS exposed through SW compatible with a REST API exposed by local IPFS daemon / gateway. For more details see ipfs/in-web-browsers#137

There is already code in place that binds API endpoints to IPFS API calls, but it's not available in browser dist and there is an assumption about running in nodejs using hapi.

Proposal

I would like to propose to factor out API endpoint binding code into separate lib or maybe just bundle and in a way that would remove node / hapi assumptions, such that would allow us to share that codebase across SW and nodejs contexts.

@Gozala
Copy link
Contributor Author

Gozala commented Jan 30, 2019

There is obvious overlap with #1820, it maybe that just expanding it's context would make more sense than having this as separate issue. However it was fairly easy to address issue pointed out there using https://github.com/ipfs/js-ipfs-http-response but dealing with Daemon REST API continues to be quite painful due to larger API surface.

@alanshaw
Copy link
Member

alanshaw commented Mar 6, 2019

As a data point, require('src/http/routes') gives you an array of route handlers that look something like this for example:

{
  method: '*',
  path: '/api/v0/dns',
  handler: async (request, h) { /* ... */ }
}

There should be no dependencies on Hapi in this tree but it does use joi for validation and boom for creating http friendly error messages.

So, in that sense if we just extracted src/http to a seperate module as-is, you could share it without further work if you built an adapter to map whatever request system you're using to them.

@alanshaw alanshaw added kind/support A question or request for support status/ready Ready to be worked labels Mar 6, 2019
@SgtPooki SgtPooki self-assigned this May 17, 2023
@SgtPooki SgtPooki moved this to 🥞 Todo in js-ipfs deprecation May 17, 2023
@SgtPooki
Copy link
Member

js-ipfs is being deprecated in favor of Helia. You can #4336 and read the migration guide.

Please feel to reopen with any comments by 2023-06-02. We will do a final pass on reopened issues afterwards (see #4336).

This issue will most likely be handled as we improve on Helia, but marking as "wontfix" for now for the sake of analyzing any of these js-ipfs deprecation issues.

@github-project-automation github-project-automation bot moved this from 🥞 Todo to ✅ Done in js-ipfs deprecation May 26, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
kind/support A question or request for support kind/wontfix status/ready Ready to be worked
Projects
No open projects
Status: Done
Development

No branches or pull requests

3 participants