-
Notifications
You must be signed in to change notification settings - Fork 29.8k
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
Explore user data sync API #78966
Comments
From @shanalikhan Okay, its great to see UX provided by VSCode itself and allow extensions to wrap their own system. I would suggest you to provide some of the API alongwith the UX when we talk about "Settings Synch" in general. I have few questions in general for some of which there are already seperate issues opened. I'm merging all of them here to allow us to see bigger picture.
These are the some improvement i see from the API side to allow Settings Sync extension to fully utilize its power and increase productivity. Now talking about adding UX. I would like to see the following things in the UX
Settings Sync has these configuration of its own, i would like to see this a part of Code so extension authors wont have to manage this.
At the end, how you guys will enforce the newly made API. I would suggest you to send PR to allow Settings Sync to integrate complely with the new UX. It would take time from my side to integrate the new UX. I have recenly added new UX in Settings Sync that integrates the Github. This UI needs to be integrated with your UX to let Settings Sync only manage the external storage part and keep the permissions and configurations to Code UI. These are the initial things that comes to my mind. |
@shanalikhan Sorry for not providing the complete details. Following is our approach to support user data sync in VS Code. CoreVS Code will completely control what data to sync. Currently following data is being considered
VS Code will provide the UI for the user to configure what to sync and also provide options to auto sync or not. VS Code also provide a special view in extensions to show already user installed extension in other machines and allow user to install them locally. VS Code will not have a database or cloud to store user data, but will provide an API so that extensions can do this. VS Code will use this API to sync (read/write) user data. APIVS Code will provide an API for extensions to provide a backend data service to store user data thereby enabling user data sync. For example export function registerUserDataProvider(account: string, userDataProvider: FileSystemProvider): Disposable;
Extensions can implement this API and provide VS Code a way to read and write user data which can be used to sync across machines. SummaryExtensions will provide just a back end service to read and write user data and VS Code will drive the synchronisation from UI to what to sync. So, it means extensions do not need to worry about how to read user data which can be at different locations and also an implementation detail of VS Code. Also all the requirements you have mentioned above will be handled by VS Code by using just above API. Hope it is clear. Please let me know if you have any questions. |
Yes this is being considered.
Assuming you are not mentioning about workspace settings which is already shareable. If it is about custom files we can discuss about it.
Regarding adopting, It is needed to provide a User Data Provider by the extension to provide access to the user data it is storing. In case of I do not think there is any adoption needed for UX.
Log in and permissions is not part of user data sync and VS Code core does not drive it as of now. So extension can still provide the UI like you have now for log in and permissions. |
Here is the api proposal for supporting user data synchronisation. export namespace window {
/**
* Register an [UserDataSyncProvider](#UserDataSyncProvider) to read and write user data.
* @param name Name of the user data sync provider
* @param userDataSyncProvider [UserDataSyncProvider](#UserDataSyncProvider) to read and write user data
*/
export function registerUserDataSyncProvider(name: string, userDataSyncProvider: UserDataSyncProvider): Disposable;
}
export class UserDataError extends Error {
/**
* Create an error to signal that writing user data with given ref is rejected, becase of new ref.
*/
static Rejected(): FileSystemError;
/**
* Creates a new userData error.
*/
constructor();
}
/**
* User data sync provider to read and write user data.
*/
export interface UserDataSyncProvider {
/**
* Reads the content and its ref for the given key.
* Return <code>null</code> if key does not exists.
*
* @param key key of the content to read
* @returns the content and its ref for the given key. Return <code>null</code> if key does not exists.
*/
read(key: string): Promise<{ content: string, ref: string } | null>;
/**
* Writes the new content based on the given ref for the given key.
*
* @param key key of the content to write
* @param content new content to write
* @param ref ref of the content on which the content to write is based on
* @throws [Rejected](#UserDataError.Rejected) if the ref is not the latest.
* @returns the latest ref of the content.
*/
write(key: string, content: string, ref: string | null): Promise<string>;
} This will allow extension to provide an user data sync store from which VS Code can read and write user data to sync. |
Two questions about the current API suggestion:
|
Selective Sync is supported by VS Code. There will be a way for the user to select/unselect settings from sync. I am still thinking how to be provide this feature from VS Code. One idea is to expose a setting to ignore settings from sync.
Handling conflicts and merging settings is supported. It is nothing to do with the API. API just provides the Currently I am planning to show a textual merge editor when there are conflicts in settings while syncing. |
Thanks, that sounds great. Especially seeing diffs / merges inside VSCode is awesome! BTW, is there another issue for UX around data sync? This one seems to be mainly about the API, the UX one was #78869 but there's a note that the discussion will happen here: #78869 (comment). If there are early UI/UX prototypes, I'd like to provide early feedback, so if I should watch this issue or some other one. Thanks! |
Update: To begin with, there are no plans to expose an API like above and hence I am closing this. Settings Sync feature work #2743 is still in progress and we are currently investigating and working on a different approach to read and write settings data. It can be a rest service end point or anything. |
This is to explore an API proposal for synchronising user data.
An API that extensions can register the user data and login providers for synchronising user data in VS Code
The text was updated successfully, but these errors were encountered: