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

FLIP 270: FCL ServiceProvider v1.1.0 #271

Closed
wants to merge 4 commits into from
Closed
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
94 changes: 94 additions & 0 deletions application/20240515-fcl-service-provider-1-1-0.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
---
status: draft
flip: 270
authors: Jordan Ribbink ([email protected])
jribbink marked this conversation as resolved.
Show resolved Hide resolved
sponsor: Jordan Ribbink ([email protected])
jribbink marked this conversation as resolved.
Show resolved Hide resolved
updated: 2023-05-15
---

# FLIP 270: FCL `ServiceProvider` v1.1.0

## Objective

The objective of this FLIP is to introduce a new optional metadata field into the FCL `ServiceProvider` data structure to allow for more descriptive wallet provider identification, and ultimately empowering FCL clients to offer more complete user experiences. In particular, this proposal aims to enahance FCL's integration with WalletConnect-compatible wallets by including identifying information in the `ServiceProvider` data structure.

## Motivation

In recent years, WalletConnect has become an integral part of not only the Flow wallet ecosystem but also the broader Web3 ecosystem. Especially in the context of mobile wallets, WalletConnect significantly reduces the infrastructure requirements for wallet providers to offer a secure and user-friendly experience.

The current integration with WalletConnect in the FCL protocol is less streamlined than others seen throughout Web3 (e.g., Web3Modal). Specifically, `WC/RPC` authentication do not identify which WalletConnect-compatible wallet it is that they correspond to. In practice, this creates an unnecessary hurdle where users must complete WalletConnect's wallet selection process, in addition to already selecting a particular wallet provider in FCL Discovery.

## User Benefit

Users will tangibly benefit from the streamlined UI enabled by this proposal. WalletConnect-compatible wallets (e.g. Flow Wallet) are at the forefront of Flow's self-custodial ecosystem, and this proposal will allow users to more easily interact with their preferred FCL wallet provider.

## Design Proposal

This proposal adds an optional field to the `ServiceProvider` data structure, adding a new optional field `walletConnectId`. This should be a string equivalent to the 32-byte hex-identifier used by WalletConnect to identify wallets.

The new `ServiceProvider` data structure will look as follows:

```typescript
interface ServiceProvider {
f_vsn: "1.1.0"
f_type: "ServiceProvider"
address: string
name?: string
description?: string
icon?: string
website?: string
supportUrl?: string
supportEmail?: string
walletConnectId?: string // NEW FIELD
}
```

### Drawbacks

Minimal drawbacks are expected from this proposal. The `ServiceProvider` change is non-breaking, so it will not impact existing FCL clients.

Possible hesitations for including this change could be complicating the `ServiceProvider` data structure, or unnecessary coupling with WalletConnect within the FCL protocol. However, given the minimal and optional nature of this change, these drawbacks are expected to be negligible.

### Alternatives Considered

Do not make this change and do not link FCL authentication services to their accompanying WalletConnect identifiers. This would maintain the status quo, but would not offer the user experience benefits of this proposal.

### Performance Implications

N/A

### Dependencies

This

### Engineering Impact

Negligible impact, optional inclusion for FCL service providers & optional consumption for FCL clients.

### Best Practices

N/A

### Tutorials and Examples

N/A

### Compatibility

Non-breaking

### User Impact

No action required for end users. Application developers will need to update to the latest version of FCL-WC to realize these benefits.

## Related Issues

N/A

## Prior Art

[Web3Modal](https://web3modal.com/) - once a user selects a wallet, they a brought to a connection view specific to the wallet they have chosen and do not need to re-select their wallet.

## Questions and Discussion

Discussion can take place on this FLIP's pull request.
Loading