cli icon indicating copy to clipboard operation
cli copied to clipboard

Make contexts shareable

Open fmvilas opened this issue 3 years ago β€’ 8 comments

Reason/Context

Currently, contexts are stored in the user's home directory. I think it would be cool to store the contexts in the repo directory so they can be shared.

Description

This would work the same way package.json works. The asyncapi CLI would seek for the file (let's call it .asyncapi) in the CWD and, if not found, it would look for it in the parent directory, then the parent of the parent, etc.

The cool thing is that if you don't want to share it, you could just place the file in your home dir, effectively behaving as it is now (global). Also, the global context would be the fallback if a "local" one is not found in a specific project.

Also, this would remove the need to set up contexts yourself manually. Since the file is already in the repo, running asyncapi will already load the context automatically.

Additionally, this eliminates the problem where a user doesn't have permission to write to disk. Very likely to happen in private built in-house CI systems (this was the case at New Relic).

fmvilas avatar Jul 26 '21 14:07 fmvilas

I like this idea a lot!

derberg avatar Jul 26 '21 19:07 derberg

would like to start by talking about the data structure for context. All context is doing right now is storing file paths that supposedly point to a spec path. Storing it in a key-value pair. So context in general looks something like this.

interface Context {
  current?: string,
  store: {
    [name: string]: string
  }
}

ContextService is loading this data and providing functions to read and manipulate this. Now the problem is there is a case that the global .asyncapi might be missing. For this case, the loader is throwing a ContextFileNotFoundError which serves the purpose, but this means we have to check for this error every time we are using this. This is making the code messy, I would like to give some examples -

While autoloading the spec file, there was a case where when there was no global .asyncapi file it was unable to autodetect spec files in the working directory as it was throwing the ContextFileNotFoundError. Had to work around like this. https://github.com/asyncapi/cli/blob/87970d12bb9a3dadc392805beb0ab3fd025c9048/src/hooks/context/hooks.tsx#L158-L168

Was playing around with the idea that we don't throw an error rather return an object with undefined context.

Something like this.
import * as fs from 'fs';
import * as path from 'path';


const SPEC_FILE_PATH = path.resolve(__dirname, 'asyncapi');

interface Context {
  current?: string,
  store: {
    [name: string]: string
  }
}

const saveContext = (ctx: Context) => {
  fs.writeFileSync(SPEC_FILE_PATH, JSON.stringify(ctx), {encoding: 'utf-8'});
}

class ContextService{
  constructor(private _context:Context | undefined){
    
  }

  current(){
    return this._context?.current;
  }

  context(contextName?:string){
    if(!contextName) return this._context;
    return this._context?.store[contextName];
  }

  isContext(){
    return typeof this._context !== 'undefined'
  }

  addContext(name: string, specPath: string){
    if(this._context) {
      this._context.store[name] = specPath;
      saveContext(this._context)
    }
    return true
  }

  static load(){
    try{
      const ctx = fs.readFileSync(SPEC_FILE_PATH, 'utf-8');
      return new ContextService(JSON.parse(ctx) as Context);
    }catch(e) {
      return new ContextService(undefined);
    }
  }
}

const ctxService = ContextService.load();
console.log(ctxService.isContext());
console.log(ctxService.addContext('test', 'url/to/specFile'))

Souvikns avatar Sep 03 '21 08:09 Souvikns

Yeah, I don't think it should throw an error as it's optional to have .asyncapi files. Much better to return undefined IMHO.

fmvilas avatar Sep 06 '21 11:09 fmvilas

This issue has been automatically marked as stale because it has not had recent activity :sleeping:

It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation.

There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model.

Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here.

Thank you for your patience :heart:

github-actions[bot] avatar Jan 05 '22 00:01 github-actions[bot]

Removing stale label as we still plan to implement this. If someone is up for this, it's a good one!

fmvilas avatar Jan 07 '22 17:01 fmvilas

This issue has been automatically marked as stale because it has not had recent activity :sleeping:

It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation.

There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model.

Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here.

Thank you for your patience :heart:

github-actions[bot] avatar May 08 '22 00:05 github-actions[bot]

This issue has been automatically marked as stale because it has not had recent activity :sleeping:

It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation.

There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model.

Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here.

Thank you for your patience :heart:

github-actions[bot] avatar Sep 08 '22 00:09 github-actions[bot]

Dear bot, keep this issue open. Thanks!

fmvilas avatar Sep 09 '22 16:09 fmvilas

This issue has been automatically marked as stale because it has not had recent activity :sleeping:

It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation.

There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model.

Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here.

Thank you for your patience :heart:

github-actions[bot] avatar Jan 08 '23 00:01 github-actions[bot]

Still relevant.

fmvilas avatar Jan 10 '23 17:01 fmvilas

The scope here is to:

  • make CLI read context configuration from CWD
  • make current context home directory storage a fallback to new CWD based
  • prepare code for an option to long-term have a flag in every command to specify a custom location of the context. So instead of home or CWD, someone can specify custom file system location of context config. Do not implement, outcome should be a proper amount of good-first-issues that enable further implementation

derberg avatar Apr 17 '23 14:04 derberg

This issue is part of the AsyncAPI Bounty Program, interested contributors need to follow the guidelines below to ensure fairness and timely completion of assigned tasks:

Task Assignment

The assignment of tasks will be prioritized in the following order:

  • AsyncAPI maintainers (from any repository)
  • Regular contributors (individuals who have merged three or more pull requests)
  • Other (if an individual doesn't fall under the above, the maintainer can determine the criteria i.e regular volunteers, etc)

We encouraged everyone to apply as long as the task is for you (falls under your skill set). We will not be using the first comment - get assigned method for assignments. Instead, we will provide 3 days to consider all individuals interested before assigning any bounty task.

Deadline

To maintain accountability and ensure the timely completion of the deadline for this task will be 6 - 8 weeks from the date of assignment. If a contributor requires an extension on their task, it should be communicated and approved by the maintainer.

Issue Tracking and Updates

Contributors must provide weekly updates on the task they are working on to help maintainers stay informed of progress. If a contributor fails to provide an update, they will be reminded via a ping. If a contributor fails to provide an update after three pings over three weeks, we will assume they have silently dropped the issue, and it will be reassigned to someone else.

Issue Drop-outs

Any contributor who drops an assigned issue will be penalized and will not be eligible to participate in the bounty program for 6 months. We understand that unforeseen circumstances can arise, and dropping an assigned issue may be unavoidable in some cases. However, we believe that enforcing this penalty is necessary to ensure the effectiveness of the bounty program, respect maintainer time, and honor the efforts of other contributors who could have solved the issue but were unable to do so due to the drop-out.

We encourage all contributors to follow these guidelines to ensure a fair and timely completion of tasks assigned through our bounty program.

thulieblack avatar Apr 19 '23 11:04 thulieblack

more context for the issue:

for now context are a β€œglobal” thing, like bash profile or git config -> os.homedir()

the idea is that this approach should not be default, but a fallback

by default, CLI should search for .asyncapi (probably we should rename to .asyncapi_cli πŸ€” ) in the CWD and then cascading search for it up to the root of the repository - then if not found, look for the global one

so for example you have context file only for given repository, keep it in git with rest of the code, or have few context files in one repo in case you have mono repo

derberg avatar Apr 25 '23 11:04 derberg

I would like to work on this issue.

aeworxet avatar Apr 26 '23 08:04 aeworxet

@aeworxet perfect, please go ahead and ask questions whenever help is needed.

derberg avatar Apr 26 '23 11:04 derberg

Some questions.

1

What should happen in this situation?

/home/userhomedir/web_development/personal/foss/asyncapi/cli/fork/src/models/.asyncapi
/home/userhomedir/web_development/personal/foss/asyncapi/cli/fork/src/.asyncapi
/home/userhomedir/web_development/personal/foss/asyncapi/cli/fork/.asyncapi
/home/userhomedir/.asyncapi

Should the search stop on first found .asyncapi file?

2

Is there a real .asyncapi file with real data so I could test not only its existence or whether it can be simply read, but whether it can be IMPORTED and whether it satisfies all requirements of interface IContextFile {}?

aeworxet avatar May 01 '23 09:05 aeworxet

image

aeworxet avatar May 05 '23 13:05 aeworxet

1

if you run asyncapi in /home/userhomedir/web_development/personal/foss/asyncapi/cli/fork/src/models it should pick /home/userhomedir/web_development/personal/foss/asyncapi/cli/fork/src/models/.asyncapi

not sure it answers your question? cwd basically

2

you can create it yourself, just do asyncapi context add for example

and here is an example with complex project structure and multiple documents https://github.com/asyncapi/spec/tree/master/examples/social-media

derberg avatar May 09 '23 14:05 derberg

Hey @aeworxet how is it going so far?

thulieblack avatar May 16 '23 08:05 thulieblack

Working closely with @derberg to ensure the development is going in right direction. Thought last week I'm ready for a draft PR but no.

aeworxet avatar May 16 '23 09:05 aeworxet

Bounty Program Timeline

Category Assigned on (by GitHub) Started on (by BP rules) Due (by BP rules) Draft PR submission Final PR submission Final PR merge
Advanced Level 2023-04-26 2023-01-05 2023-06-23 (Friday of eighth week) 2023-05-19 (Friday of third week and updated on every Friday) 2023-06-09 (Friday of sixth week) 2023-06-23 (Friday of eighth week)

Please note that dates represent deadlines, not specific dates, so if the goal is reached sooner, it's better.

aeworxet avatar May 19 '23 08:05 aeworxet

Should CLI context file's name be changed from .asyncapi to .asyncapi-cli, by analogy with .asyncapi-tool?

aeworxet avatar Jun 01 '23 11:06 aeworxet

no strong opinion from my side, both are ok I think, I do not see scenario where in one repo someone would have .asyncapi-tool and .asyncapi. So .asyncapi is pretty ok I think

derberg avatar Jun 01 '23 12:06 derberg

If there's no strong opinion, I'd rather make it .asyncapi-cli. Just in case there appears a Big Universal AsyncAPI Framework at some moment which will proudly utilize filename .asyncapi. And while this context functionality is not much in use, because the more users use it, the harder it is to migrate to a new name in case of a need.

aeworxet avatar Jun 01 '23 12:06 aeworxet

Big Universal AsyncAPI Framework at some moment which will proudly utilize filename .asyncapi

I like that! πŸ˜ƒ

derberg avatar Jun 01 '23 13:06 derberg

image

PR update postponed until Executive Director returns from vacation.

aeworxet avatar Jun 06 '23 14:06 aeworxet

A break for you 😊

thulieblack avatar Jun 06 '23 15:06 thulieblack

Executive Director πŸ‘€

next time please do not feel blocked by me, there is also @Souvikns that maintains CLI and also the request for shared context came from @fmvilas

but I also understand that you preferred to wait as we discusses some technical details before my holidays.

PR is in Draft mode, so please lemme know if ready for review

derberg avatar Jun 19 '23 15:06 derberg

This was at the same time a Bounty Program usecase. If your vacation would INDEED be a blocking issue, how would the Bounty Program timeline change? I would propose to increase any stage the issue is at that moment in, by duration of absence of the person in charge from the AsyncAPI side + 1 week, because if such person (Core Developer?) was absent for a month or two (for any reason), the bounty hunter would then have to spend some time getting back to the insides of the issue and nearly unfamiliar at that time his own code.

aeworxet avatar Jun 20 '23 05:06 aeworxet

Executive Director

As a giggly alternative I also have Chief Merging Officer.

aeworxet avatar Jun 20 '23 05:06 aeworxet