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

Create fastlane query for siblinks #1

Open
Gozala opened this issue Apr 16, 2020 · 0 comments
Open

Create fastlane query for siblinks #1

Gozala opened this issue Apr 16, 2020 · 0 comments

Comments

@Gozala
Copy link
Contributor

Gozala commented Apr 16, 2020

Moved from (inkandswitch/ksp-browser#9 (comment))

Querying ksp for siblinks currently looks as follows:

query Siblinks {
  resource(url: "https://www.inkandswitch.com/local-first.html") {
    url
    sibLinks: links {
      ...sibLink
    }
  }
}

fragment sibLink on Link {
  target {
    url
    backLinks {
      ...backLink
    }
    tags {
      ...tag
    }
  }
}

fragment tag on Tag {
  name
}

fragment backLink on Link {
  kind
  identifier
  name
  title
  fragment
  location
  referrer {
    url
    info {
      title
      description
      cid
    }
    tags {
      ...tag
    }
  }
}

There are multiple problems with this:

  1. n+1 SQL queries
    1. First query will get links from the resource (with passed url) to materialize corresponding resources.
    2. Then it will query each materialized resource for backlinks.
  2. Resulted backlinks for each URL will contain resource for the passed URL itself. Which then on client we will have to filter out.

I don't want to spend time on optimizing this right now, but think we should expose another query endpoint to have something like:

query {
  siblinks(url: "https://www.inkandswitch.com/local-first.html") {
      ...sibLink
  }
}

Which in the KSP can accomplish this with single SQL query and exclude links for the passed url itself.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant