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

WIP: kappa-next #14

Open
wants to merge 87 commits into
base: master
Choose a base branch
from
Open

WIP: kappa-next #14

wants to merge 87 commits into from

Conversation

Frando
Copy link
Member

@Frando Frando commented Dec 7, 2019

This PR is the current state of my efforts to make kappa-core work with different kinds of sources.
It is based on the #13 and incoroprates a lot of useful feedback from noffle, substack and others.

  • Makes kappa-core dependency-less
  • Includes breaking changes, thus the kappa-classic export retaining api compatibility with current kappa-core is not possible anymore.

Breaking changes are:

  • the use function takes a name, a source, and a view
  • both sources and views can expose APIs, they are mounted on kappa.view[name] and kappa.source[name]
  • sources are expected to keep track of state, so that each call to pull only ever returns messages which haven't been returned before

I added documentation for the new API, see the rendered README.

I think this is ready for review now. If wanted, I can also do a writeup of the changes? But maybe its quite obvious already also from the new README and tests.

@Frando
Copy link
Member Author

Frando commented Apr 27, 2020

So finally I'll get back here this week, sorry that it took so long.

I think I'll go over @noffle's review in two steps:

  • First, I'll try to handle everything non-API-breaking (onto the current state of things) which I'll push onto this PR
  • Then, I'll compile an overview of the proposed API changes, possibly adding some that I myself am thinking about so that we can then discuss these once more before committing to them.

As far as I know Sonar and Cobox are currently depending on this branch, if there are others please chime in too!

@Frando
Copy link
Member Author

Frando commented May 2, 2020

I finished a big round of non-api breaking changes from @noffle's review. Yay! I added a couple of comments to things I did not address right away.

Now, to the proposed API changes:

  • The main proposed API change by @noffle is to change the signature of the next callback in a source's pull handler from next({ messages, finished, onindexed }) to next(err, messages, finished, onindexed). And, at the same time, change the default for finished to true. I think I like both changes.

  • I have another change I'd propose that is purely asthetic: I'd maybe like to rename ready to sync. It seems clearer to me, as a kappa is never "ready" if it's listening for remote sources that can update at any time. Also it may be confusing as oftenly in our ecosystem ready is an open alias.

  • One thing I've been thinking about: Currently kappa-core injects itself as a first argument to the API functions. I added a context op to make this overridable with another object, as oftenly I've seen me needing the "object in which the kappa is used" (e.g. a cabal, a kappa-record-db) and not the kappa-core itself. At the same time, this can also be passed as an option into the createView or createSource function. So I thought if we should just remove this injected first argument to the API functions. Thoughts?

  • I have an improved version for the SimpleState utility that I wrote for kappa-sparse-indexer. I'll add this too once I start with the breaking changes.

  • The internal state for each flow currently is either Ready, Running, Paused. Likely we want to have an Error state also, into which a flow is put when either a view returned an error from map or a source returned an error from pull

  • Maybe we want to expose a getState function that returns the current state of things, and also asks the source for the indexing state (as in the recently added feature to multifeed-index)

I am using this API in kappa-sparse-indexer and kappa-record-db, which I'd update accordingly then. I think cobox uses only sources internal to kappa-core. @kyphae or did you implement custom sources somewhere? Also if someone else apart from me and @kyphae is using this branch in dependencies, could you give a quick ping here? I'd like to know how "free" I am at the moment with regard to API changes. I've seen @substack using it in examples at least. For those currently depending on it - you can pin to github:Frando/kappa-core#exp-0.2.3 to not get API breaking changes right away if I push to this branch.

@ghost
Copy link

ghost commented May 2, 2020

I was already expecting some changes so pushing is fine for me.

As far as the argument-prepending goes, I find that I very rarely use this feature because I will almost always do kcore.use(someView(arg1, arg2, ...)) where someView is module.exports = function (arg1, arg2...) {} so where I need the kcore instance or other arguments I pass it in there. Or more commonly, I will pass in particular exported apis instead of the whole kappa-core instance.

@hackergrrl
Copy link
Member

👋! Hi @Frando, sorry it's taken so long to get back to you on this. It seems like every time there are updates I need to sit down for a long time and download it all into my brain again. :) I appreciate the summary of proposed changes.

The main proposed API change by @noffle is to change the signature of the next callback in a source's pull handler from next({ messages, finished, onindexed }) to next(err, messages, finished, onindexed). And, at the same time, change the default for finished to true. I think I like both changes.

Great!

I have another change I'd propose that is purely asthetic: I'd maybe like to rename ready to sync. It seems clearer to me, as a kappa is never "ready" if it's listening for remote sources that can update at any time. Also it may be confusing as oftenly in our ecosystem ready is an open alias.

Do you think it might be confusing, since it's so similar in meaning to replicate? Could indexesReady() work, or something else that hints at this being a means to wait on the views to catch up? If you disagree, feel free to use sync -- this doesn't feel worth bikeshedding too much on.

One thing I've been thinking about: Currently kappa-core injects itself as a first argument to the API functions. I added a context op to make this overridable with another object, as oftenly I've seen me needing the "object in which the kappa is used" (e.g. a cabal, a kappa-record-db) and not the kappa-core itself. At the same time, this can also be passed as an option into the createView or createSource function. So I thought if we should just remove this injected first argument to the API functions. Thoughts?

I'm down with this change. I really regret the kludge I chose of injecting fake arguments.

The internal state for each flow currently is either Ready, Running, Paused. Likely we want to have an Error state also, into which a flow is put when either a view returned an error from map or a source returned an error from pull

Yes please.

Maybe we want to expose a getState function that returns the current state of things, and also asks the source for the indexing state (as in the recently added feature to multifeed-index)

I'm ok with punting on this until after these changes get merged. This PR is also very big, so anything we can do to keep the scope down and change later would be 🔥.

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

Successfully merging this pull request may close these issues.

5 participants