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

Migrate workbench to getAgent #1485

Open
wants to merge 34 commits into
base: fdc3-for-web-impl-getAgent-refactor
Choose a base branch
from

Conversation

Roaders
Copy link
Contributor

@Roaders Roaders commented Jan 2, 2025

Describe your change

Related Issue

resolves #1484

Contributor License Agreement

  • I acknowledge that a contributor license agreement is required and that I have one in place or will seek to put one in place ASAP.

Review Checklist

  • Issue: If a change was made to the FDC3 Standard, was an issue linked above?
  • CHANGELOG: Is a CHANGELOG.md entry included?
  • API changes: Does this PR include changes to any of the FDC3 APIs (DesktopAgent, Channel, PrivateChannel, Listener, Bridging)?
    • Docs & Sources: If yes, were both documentation (/docs) and sources updated?

      JSDoc comments on interfaces and types should be matched to the main documentation in /docs
    • Conformance tests: If yes, are conformance test definitions (/toolbox/fdc3-conformance) still correct and complete?

      Conformance test definitions should cover all required aspects of an FDC3 Desktop Agent implementation, which are usually marked with a MUST keyword, and optional features (SHOULD or MAY) where the format of those features is defined
    • Schemas: If yes, were changes applied to the Bridging and FDC3 for Web protocol schemas?

      The Web Connection protocol and Desktop Agent Communication Protocol schemas must be able to support all necessary aspects of the Desktop Agent API, while Bridging must support those aspects necessary for Desktop Agents to communicate with each other
      • If yes, was code generation (npm run build) run and the results checked in?

        Generated code will be found at /src/api/BrowserTypes.ts and/or /src/bridging/BridgingTypes.ts
  • Context types: Were new Context type schemas created or modified in this PR?
    • Were the field type conventions adhered to?
    • Was the BaseContext schema applied via allOf (as it is in existing types)?
    • Was a title and description provided for all properties defined in the schema?
    • Was at least one example provided?
    • Was code generation (npm run build) run and the results checked in?

      Generated code will be found at /src/context/ContextTypes.ts
  • Intents: Were new Intents created in this PR?

THIS SOFTWARE IS CONTRIBUTED SUBJECT TO THE TERMS OF THE FINOS CORPORATE CONTRIBUTOR LICENSE AGREEMENT.

THIS SOFTWARE IS LICENSED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE AND ANY WARRANTY OF NON-INFRINGEMENT, ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. THIS SOFTWARE MAY BE REDISTRIBUTED TO OTHERS ONLY BY EFFECTIVELY USING THIS OR ANOTHER EQUIVALENT DISCLAIMER IN ADDITION TO ANY OTHER REQUIRED LICENSE TERMS.

@Roaders Roaders requested a review from a team as a code owner January 2, 2025 11:49
@Roaders
Copy link
Contributor Author

Roaders commented Jan 2, 2025

Not sure if I need to include a CHANGELOG.MD as I've not changed the spec. I can add one if needed

@Roaders
Copy link
Contributor Author

Roaders commented Jan 2, 2025

I think that this is good. The workbench works at least! I don't really know how the backwards compatiible stuff withj older FDC3 implementations is supposed to work. I am hoping it will "just work" as getAgent() will find the agent at window.fdc3.

@kriswest
Copy link
Contributor

kriswest commented Jan 2, 2025

Happy New Year @Roaders

Not sure if I need to include a CHANGELOG.MD as I've not changed the spec. I can add one if needed

You do, the changelog does double duty for both standard and software changes.

@kriswest
Copy link
Contributor

kriswest commented Jan 2, 2025

I think that this is good. The workbench works at least! I don't really know how the backwards compatiible stuff withj older FDC3 implementations is supposed to work. I am hoping it will "just work" as getAgent() will find the agent at window.fdc3.

It should indeed 'just work'TM. All that's happening is that different types are used for different versions (with minor associated UI differences based on available calls), they are still being used over the injected FDC3 implementation (now discovered by getAgent).

@Roaders
Copy link
Contributor Author

Roaders commented Jan 4, 2025

Happy New Year @kriswest 😄

PR updated. Sorry it took a few days. Still in holiday mode!

@kriswest kriswest added this to the 2.2 milestone Jan 7, 2025
@kriswest kriswest added toolbox Apps or code that isn't part of the standard but supports it use FDC3 for Web Browsers labels Jan 7, 2025
@Roaders Roaders force-pushed the fdc3-for-web-impl-getAgent-refactor branch from 8243db5 to f232a10 Compare January 17, 2025 10:11
@Roaders
Copy link
Contributor Author

Roaders commented Jan 17, 2025

Rebased onto fdc3-for-web-impl to get import changes for @finos/fdc3

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
FDC3 for Web Browsers toolbox Apps or code that isn't part of the standard but supports it use
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants