mirror of
https://github.com/status-im/status-go.git
synced 2025-01-20 19:52:42 +00:00
14dcd29eee
author shashankshampi <shashank.sanket1995@gmail.com> 1729780155 +0530 committer shashankshampi <shashank.sanket1995@gmail.com> 1730274350 +0530 test: Code Migration from status-cli-tests fix_: functional tests (#5979) * fix_: generate on test-functional * chore(test)_: fix functional test assertion --------- Co-authored-by: Siddarth Kumar <siddarthkay@gmail.com> feat(accounts)_: cherry-pick Persist acceptance of Terms of Use & Privacy policy (#5766) (#5977) * feat(accounts)_: Persist acceptance of Terms of Use & Privacy policy (#5766) The original GH issue https://github.com/status-im/status-mobile/issues/21113 came from a request from the Legal team. We must show to Status v1 users the new terms (Terms of Use & Privacy Policy) right after they upgrade to Status v2 from the stores. The solution we use is to create a flag in the accounts table, named hasAcceptedTerms. The flag will be set to true on the first account ever created in v2 and we provide a native call in mobile/status.go#AcceptTerms, which allows the client to persist the user's choice in case they are upgrading (from v1 -> v2, or from a v2 older than this PR). This solution is not the best because we should store the setting in a separate table, not in the accounts table. Related Mobile PR https://github.com/status-im/status-mobile/pull/21124 * fix(test)_: Compare addresses using uppercased strings --------- Co-authored-by: Icaro Motta <icaro.ldm@gmail.com> test_: restore account (#5960) feat_: `LogOnPanic` linter (#5969) * feat_: LogOnPanic linter * fix_: add missing defer LogOnPanic * chore_: make vendor * fix_: tests, address pr comments * fix_: address pr comments fix(ci)_: remove workspace and tmp dir This ensures we do not encounter weird errors like: ``` + ln -s /home/jenkins/workspace/go_prs_linux_x86_64_main_PR-5907 /home/jenkins/workspace/go_prs_linux_x86_64_main_PR-5907@tmp/go/src/github.com/status-im/status-go ln: failed to create symbolic link '/home/jenkins/workspace/go_prs_linux_x86_64_main_PR-5907@tmp/go/src/github.com/status-im/status-go': File exists script returned exit code 1 ``` Signed-off-by: Jakub Sokołowski <jakub@status.im> chore_: enable windows and macos CI build (#5840) - Added support for Windows and macOS in CI pipelines - Added missing dependencies for Windows and x86-64-darwin - Resolved macOS SDK version compatibility for darwin-x86_64 The `mkShell` override was necessary to ensure compatibility with the newer macOS SDK (version 11.0) for x86_64. The default SDK (10.12) was causing build failures because of the missing libs and frameworks. OverrideSDK creates a mapping from the default SDK in all package categories to the requested SDK (11.0). fix(contacts)_: fix trust status not being saved to cache when changed (#5965) Fixes https://github.com/status-im/status-desktop/issues/16392 cleanup added logger and cleanup review comments changes fix_: functional tests (#5979) * fix_: generate on test-functional * chore(test)_: fix functional test assertion --------- Co-authored-by: Siddarth Kumar <siddarthkay@gmail.com> feat(accounts)_: cherry-pick Persist acceptance of Terms of Use & Privacy policy (#5766) (#5977) * feat(accounts)_: Persist acceptance of Terms of Use & Privacy policy (#5766) The original GH issue https://github.com/status-im/status-mobile/issues/21113 came from a request from the Legal team. We must show to Status v1 users the new terms (Terms of Use & Privacy Policy) right after they upgrade to Status v2 from the stores. The solution we use is to create a flag in the accounts table, named hasAcceptedTerms. The flag will be set to true on the first account ever created in v2 and we provide a native call in mobile/status.go#AcceptTerms, which allows the client to persist the user's choice in case they are upgrading (from v1 -> v2, or from a v2 older than this PR). This solution is not the best because we should store the setting in a separate table, not in the accounts table. Related Mobile PR https://github.com/status-im/status-mobile/pull/21124 * fix(test)_: Compare addresses using uppercased strings --------- Co-authored-by: Icaro Motta <icaro.ldm@gmail.com> test_: restore account (#5960) feat_: `LogOnPanic` linter (#5969) * feat_: LogOnPanic linter * fix_: add missing defer LogOnPanic * chore_: make vendor * fix_: tests, address pr comments * fix_: address pr comments chore_: enable windows and macos CI build (#5840) - Added support for Windows and macOS in CI pipelines - Added missing dependencies for Windows and x86-64-darwin - Resolved macOS SDK version compatibility for darwin-x86_64 The `mkShell` override was necessary to ensure compatibility with the newer macOS SDK (version 11.0) for x86_64. The default SDK (10.12) was causing build failures because of the missing libs and frameworks. OverrideSDK creates a mapping from the default SDK in all package categories to the requested SDK (11.0). fix(contacts)_: fix trust status not being saved to cache when changed (#5965) Fixes https://github.com/status-im/status-desktop/issues/16392 test_: remove port bind chore(wallet)_: move route execution code to separate module chore_: replace geth logger with zap logger (#5962) closes: #6002 feat(telemetry)_: add metrics for message reliability (#5899) * feat(telemetry)_: track message reliability Add metrics for dial errors, missed messages, missed relevant messages, and confirmed delivery. * fix_: handle error from json marshal chore_: use zap logger as request logger iterates: status-im/status-desktop#16536 test_: unique project per run test_: use docker compose v2, more concrete project name fix(codecov)_: ignore folders without tests Otherwise Codecov reports incorrect numbers when making changes. https://docs.codecov.com/docs/ignoring-paths Signed-off-by: Jakub Sokołowski <jakub@status.im> test_: verify schema of signals during init; fix schema verification warnings (#5947) fix_: update defaultGorushURL (#6011) fix(tests)_: use non-standard port to avoid conflicts We have observed `nimbus-eth2` build failures reporting this port: ```json { "lvl": "NTC", "ts": "2024-10-28 13:51:32.308+00:00", "msg": "REST HTTP server could not be started", "topics": "beacnde", "address": "127.0.0.1:5432", "reason": "(98) Address already in use" } ``` https://ci.status.im/job/nimbus-eth2/job/platforms/job/linux/job/x86_64/job/main/job/PR-6683/3/ Signed-off-by: Jakub Sokołowski <jakub@status.im> fix_: create request logger ad-hoc in tests Fixes `TestCall` failing when run concurrently. chore_: configure codecov (#6005) * chore_: configure codecov * fix_: after_n_builds
214 lines
7.3 KiB
Go
214 lines
7.3 KiB
Go
// SPDX-FileCopyrightText: 2019 The Go Language Server Authors
|
||
// SPDX-License-Identifier: BSD-3-Clause
|
||
|
||
package protocol
|
||
|
||
import (
|
||
"strconv"
|
||
|
||
"go.lsp.dev/uri"
|
||
)
|
||
|
||
// WorkspaceFolder response of Workspace folders request.
|
||
type WorkspaceFolder struct {
|
||
// URI is the associated URI for this workspace folder.
|
||
URI string `json:"uri"`
|
||
|
||
// Name is the name of the workspace folder. Used to refer to this
|
||
// workspace folder in the user interface.
|
||
Name string `json:"name"`
|
||
}
|
||
|
||
// DidChangeWorkspaceFoldersParams params of DidChangeWorkspaceFolders notification.
|
||
type DidChangeWorkspaceFoldersParams struct {
|
||
// Event is the actual workspace folder change event.
|
||
Event WorkspaceFoldersChangeEvent `json:"event"`
|
||
}
|
||
|
||
// WorkspaceFoldersChangeEvent is the workspace folder change event.
|
||
type WorkspaceFoldersChangeEvent struct {
|
||
// Added is the array of added workspace folders
|
||
Added []WorkspaceFolder `json:"added"`
|
||
|
||
// Removed is the array of the removed workspace folders
|
||
Removed []WorkspaceFolder `json:"removed"`
|
||
}
|
||
|
||
// DidChangeConfigurationParams params of DidChangeConfiguration notification.
|
||
type DidChangeConfigurationParams struct {
|
||
// Settings is the actual changed settings
|
||
Settings interface{} `json:"settings,omitempty"`
|
||
}
|
||
|
||
// ConfigurationParams params of Configuration request.
|
||
type ConfigurationParams struct {
|
||
Items []ConfigurationItem `json:"items"`
|
||
}
|
||
|
||
// ConfigurationItem a ConfigurationItem consists of the configuration section to ask for and an additional scope URI.
|
||
// The configuration section ask for is defined by the server and doesn’t necessarily need to correspond to the configuration store used be the client.
|
||
// So a server might ask for a configuration cpp.formatterOptions but the client stores the configuration in a XML store layout differently.
|
||
// It is up to the client to do the necessary conversion. If a scope URI is provided the client should return the setting scoped to the provided resource.
|
||
// If the client for example uses EditorConfig to manage its settings the configuration should be returned for the passed resource URI. If the client can’t provide a configuration setting for a given scope then null need to be present in the returned array.
|
||
type ConfigurationItem struct {
|
||
// ScopeURI is the scope to get the configuration section for.
|
||
ScopeURI uri.URI `json:"scopeUri,omitempty"`
|
||
|
||
// Section is the configuration section asked for.
|
||
Section string `json:"section,omitempty"`
|
||
}
|
||
|
||
// DidChangeWatchedFilesParams params of DidChangeWatchedFiles notification.
|
||
type DidChangeWatchedFilesParams struct {
|
||
// Changes is the actual file events.
|
||
Changes []*FileEvent `json:"changes,omitempty"`
|
||
}
|
||
|
||
// FileEvent an event describing a file change.
|
||
type FileEvent struct {
|
||
// Type is the change type.
|
||
Type FileChangeType `json:"type"`
|
||
|
||
// URI is the file's URI.
|
||
URI uri.URI `json:"uri"`
|
||
}
|
||
|
||
// FileChangeType is the file event type.
|
||
type FileChangeType float64
|
||
|
||
const (
|
||
// FileChangeTypeCreated is the file got created.
|
||
FileChangeTypeCreated FileChangeType = 1
|
||
// FileChangeTypeChanged is the file got changed.
|
||
FileChangeTypeChanged FileChangeType = 2
|
||
// FileChangeTypeDeleted is the file got deleted.
|
||
FileChangeTypeDeleted FileChangeType = 3
|
||
)
|
||
|
||
// String implements fmt.Stringer.
|
||
func (t FileChangeType) String() string {
|
||
switch t {
|
||
case FileChangeTypeCreated:
|
||
return "Created"
|
||
case FileChangeTypeChanged:
|
||
return "Changed"
|
||
case FileChangeTypeDeleted:
|
||
return "Deleted"
|
||
default:
|
||
return strconv.FormatFloat(float64(t), 'f', -10, 64)
|
||
}
|
||
}
|
||
|
||
// DidChangeWatchedFilesRegistrationOptions describe options to be used when registering for file system change events.
|
||
type DidChangeWatchedFilesRegistrationOptions struct {
|
||
// Watchers is the watchers to register.
|
||
Watchers []FileSystemWatcher `json:"watchers"`
|
||
}
|
||
|
||
// FileSystemWatcher watchers of DidChangeWatchedFiles Registration options.
|
||
type FileSystemWatcher struct {
|
||
// GlobPattern is the glob pattern to watch.
|
||
//
|
||
// Glob patterns can have the following syntax:
|
||
// - `*` to match one or more characters in a path segment
|
||
// - `?` to match on one character in a path segment
|
||
// - `**` to match any number of path segments, including none
|
||
// - `{}` to group conditions (e.g. `**/*.{ts,js}` matches all TypeScript and JavaScript files)
|
||
// - `[]` to declare a range of characters to match in a path segment (e.g., `example.[0-9]` to match on `example.0`, `example.1`, …)
|
||
// - `[!...]` to negate a range of characters to match in a path segment (e.g., `example.[!0-9]` to match on `example.a`, `example.b`, but not `example.0`)
|
||
GlobPattern string `json:"globPattern"`
|
||
|
||
// Kind is the kind of events of interest. If omitted it defaults
|
||
// to WatchKind.Create | WatchKind.Change | WatchKind.Delete
|
||
// which is 7.
|
||
Kind WatchKind `json:"kind,omitempty"`
|
||
}
|
||
|
||
// WatchKind kind of FileSystemWatcher kind.
|
||
type WatchKind float64
|
||
|
||
const (
|
||
// WatchKindCreate interested in create events.
|
||
WatchKindCreate WatchKind = 1
|
||
|
||
// WatchKindChange interested in change events.
|
||
WatchKindChange WatchKind = 2
|
||
|
||
// WatchKindDelete interested in delete events.
|
||
WatchKindDelete WatchKind = 4
|
||
)
|
||
|
||
// String implements fmt.Stringer.
|
||
func (k WatchKind) String() string {
|
||
switch k {
|
||
case WatchKindCreate:
|
||
return "Create"
|
||
case WatchKindChange:
|
||
return "Change"
|
||
case WatchKindDelete:
|
||
return "Delete"
|
||
default:
|
||
return strconv.FormatFloat(float64(k), 'f', -10, 64)
|
||
}
|
||
}
|
||
|
||
// WorkspaceSymbolParams is the parameters of a Workspace Symbol request.
|
||
type WorkspaceSymbolParams struct {
|
||
WorkDoneProgressParams
|
||
PartialResultParams
|
||
|
||
// Query a query string to filter symbols by.
|
||
//
|
||
// Clients may send an empty string here to request all symbols.
|
||
Query string `json:"query"`
|
||
}
|
||
|
||
// ExecuteCommandParams params of Execute a command.
|
||
type ExecuteCommandParams struct {
|
||
WorkDoneProgressParams
|
||
|
||
// Command is the identifier of the actual command handler.
|
||
Command string `json:"command"`
|
||
|
||
// Arguments that the command should be invoked with.
|
||
Arguments []interface{} `json:"arguments,omitempty"`
|
||
}
|
||
|
||
// ExecuteCommandRegistrationOptions execute command registration options.
|
||
type ExecuteCommandRegistrationOptions struct {
|
||
// Commands is the commands to be executed on the server
|
||
Commands []string `json:"commands"`
|
||
}
|
||
|
||
// ApplyWorkspaceEditParams params of Applies a WorkspaceEdit.
|
||
type ApplyWorkspaceEditParams struct {
|
||
// Label an optional label of the workspace edit. This label is
|
||
// presented in the user interface for example on an undo
|
||
// stack to undo the workspace edit.
|
||
Label string `json:"label,omitempty"`
|
||
|
||
// Edit is the edits to apply.
|
||
Edit WorkspaceEdit `json:"edit"`
|
||
}
|
||
|
||
// ApplyWorkspaceEditResponse response of Applies a WorkspaceEdit.
|
||
type ApplyWorkspaceEditResponse struct {
|
||
// Applied indicates whether the edit was applied or not.
|
||
Applied bool `json:"applied"`
|
||
|
||
// FailureReason an optional textual description for why the edit was not applied.
|
||
// This may be used by the server for diagnostic logging or to provide
|
||
// a suitable error for a request that triggered the edit.
|
||
//
|
||
// @since 3.16.0.
|
||
FailureReason string `json:"failureReason,omitempty"`
|
||
|
||
// FailedChange depending on the client's failure handling strategy "failedChange"
|
||
// might contain the index of the change that failed. This property is
|
||
// only available if the client signals a "failureHandlingStrategy"
|
||
// in its client capabilities.
|
||
//
|
||
// @since 3.16.0.
|
||
FailedChange uint32 `json:"failedChange,omitempty"`
|
||
}
|