-
Notifications
You must be signed in to change notification settings - Fork 1.8k
/
faq.md
304 lines (221 loc) · 13.9 KB
/
faq.md
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
# Frequently asked questions
## Authentication problems
### Q: I got an error trying to push/pull/clone. What do I do now?
Please follow these steps to diagnose or resolve the problem:
1. Check if you can access the remote repository in a web browser. If you
cannot, this is probably a permission problem and you should follow up with the
repository administrator for access. Execute `git remote -v` from a terminal to
show the remote URL.
1. If you are experiencing a Git authentication problem using an editor, IDE or
other tool, try performing the same operation from the terminal. Does this still
fail? If the operation succeeds from the terminal please include details of the
specific tool and version in any issue reports.
1. Set the environment variable `GCM_TRACE` and run the Git operation again.
Find instructions in the [environment doc][env-trace].
1. If all else fails, create an issue [here][create-issue], making sure to
include the trace log.
### Q: I got an error saying unsecure HTTP is not supported
To keep your data secure, Git Credential Manager will not send credentials for
Azure Repos, Azure DevOps Server (TFS), GitHub, and Bitbucket, over HTTP
connections that are not secured using TLS (HTTPS).
Please make sure your remote URLs use "https://" rather than "http://".
### Q: I got an authentication error and I am behind a network proxy
You probably need to configure Git and GCM to use a proxy. Please see detailed
information in the [network config doc][netconfig-http-proxy].
### Q: I'm getting errors about picking a credential store on Linux
On Linux you must [select and configure a credential store][credstores], as due
to the varied nature of distributions and installations, we cannot guarantee a
suitable storage solution is available.
## About the project
### Q: How does this project relate to [Git Credential Manager for Windows][gcm-windows] and [Git Credential Manager for Mac and Linux][gcm-linux]?
Git Credential Manager for Windows (GCM Windows) is a .NET Framework-based Git
credential helper which runs on Windows. Likewise the Git Credential Manager for
Mac and Linux (Java GCM) is a Java-based Git credential helper that runs only on
macOS and Linux. Although both of these projects aim to solve the same problem
(providing seamless multi-factor HTTPS authentication with Git), they are based
on different codebases and languages which is becoming hard to manage to ensure
feature parity.
Git Credential Manager (GCM; this project) aims to replace both GCM Windows and
Java GCM with a unified codebase which should be easier to maintain and enhance
in the future.
### Q: Does this mean GCM for Windows (.NET Framework-based) is deprecated?
Yes. Git Credential Manager for Windows (GCM Windows) is no longer receiving
updates and fixes. All development effort has now been directed to GCM. GCM is
available as an credential helper option in Git for Windows 2.28, and will be
made the default helper in 2.29.
### Q: Does this mean the Java-based GCM for Mac/Linux is deprecated?
Yes. Usage of Git Credential Manager for Mac and Linux (Java GCM) should be
replaced with GCM or SSH keys. If you wish to install GCM on macOS or Linux,
please follow the [download and installation instructions][download-and-install].
### Q: I want to use SSH
GCM is only useful for HTTP(S)-based remotes. Git supports SSH out-of-the box so
you shouldn't need to install anything else.
To use SSH please follow the below links:
- [Azure DevOps][azure-ssh]
- [GitHub][github-ssh]
- [Bitbucket][bitbucket-ssh]
### Q: Are HTTP(S) remotes preferred over SSH?
No, neither are "preferred". SSH isn't going away, and is supported "natively"
in Git.
### Q: Why did you not just port the existing GCM Windows codebase from .NET Framework to .NET Core?
GCM Windows was not designed with a cross-platform architecture.
### What level of support does GCM have?
Support will be best-effort. We would really appreciate your feedback to make
this a great experience across each platform we support.
### Q: Why does GCM not support operating system/distribution 'X', or Git hosting provider 'Y'?
The likely answer is we haven't gotten around to that yet! 🙂
We are working on ensuring support for the Windows, macOS, and Ubuntu operating
system, as well as the following Git hosting providers: Azure Repos, Azure
DevOps Server (TFS), GitHub, and Bitbucket.
We are happy to accept proposals and/or contributions to enable GCM to run on
other platforms and Git host providers. Thank you!
## Technical
### Why is the `credential.useHttpPath` setting required for `dev.azure.com`?
Due to the design of Git and credential helpers such as GCM, we need this
setting to make Git use the full remote URL (including the path component) when
communicating with GCM. The new `dev.azure.com` format of Azure DevOps URLs
means the account name is now part of the path component (for example:
`https://dev.azure.com/contoso/...`). The Azure DevOps account name is required
in order to resolve the correct authority for authentication (which Azure AD
tenant backs this account, or if it is backed by Microsoft personal accounts).
In the older GCM for Windows product, the solution to the same problem was a
"hack". GCM for Windows would walk the process tree looking for the
`git-remote-https.exe` process, and attempt to read/parse the process
environment block looking for the command line arguments (that contained the
full remote URL). This is fragile and not a cross-platform solution, hence the
need for the `credential.useHttpPath` setting with GCM.
### Why does GCM take so long at startup the first time?
GCM will [autodetect][autodetect] what kind of Git host it's talking to. GitHub,
Bitbucket, and Azure DevOps each have their own form(s) of authentication, plus
there's a "generic" username and password option.
For the hosted versions of these services, GCM can guess from the URL which
service to use. But for on-premises versions which would have unique URLs, GCM
will probe with a network call. GCM caches the results of the probe, so it
should be faster on the second and later invocations.
If you know which provider you're talking to and want to avoid the probe, that's
possible. You can explicitly tell GCM which provider to use for a URL
"example.com" like this:
Provider|Command
-|-
GitHub|`git config --global credential.https://example.com.provider github`
Bitbucket|`git config --global credential.https://example.com.provider bitbucket`
Azure DevOps|`git config --global credential.https://example.com.provider azure-repos`
Generic|`git config --global credential.https://example.com.provider generic`
### How do I fix "Could not create SSL/TLS secure channel" errors on Windows 7?
This likely indicates that you don't have newer TLS versions available. Please
[follow Microsoft's guide][enable-windows-ssh] for enabling TLS 1.1 and 1.2 on
your machine, specifically the **SChannel** instructions. You'll need to be on
at least Windows 7 SP1, and in the end you should have a `TLS 1.2` key with
`DisabledByDefault` set to `0`. You can also read
[more from Microsoft][windows-server-tls] on this change.
### How do I use GCM with Windows Subsystem for Linux (WSL)?
Follow the instructions in [our WSL guide][wsl] carefully. Especially note the
need to run `git config --global credential.https://dev.azure.com.useHttpPath true`
_within_ WSL if you're using Azure DevOps.
### Does GCM work with multiple users? If so, how?
That's a fairly complicated question to answer, but in short, yes. See
[our document on multiple users][multiple-users] for details.
### How can I disable GUI dialogs and prompts?
There are various environment variables and configuration options available to
customize how GCM will prompt you (or not) for input. Please see the following:
- [`GCM_INTERACTIVE`][env-interactive] / [`credential.interactive`][config-interactive]
- [`GCM_GUI_PROMPT`][env-gui-prompt] / [`credential.guiPrompt`][config-gui-prompt]
- [`GIT_TERMINAL_PROMPT`][git-term-prompt] (note this is a _Git setting_ that
will affect Git as well as GCM)
### How can I extend GUI prompts/integrate prompts with my application?
Application developers who use Git - think Visual Studio, GitKraken, etc. - may
want to replace the GCM default UI with prompts styled to look like their
application. This isn't complicated (though it is a bit of work).
You can replace the GUI prompts of the Bitbucket and GitHub host providers
specifically by using the `credential.gitHubHelper`/`credential.bitbucketHelper`
settings or `GCM_GITHUB_HELPER`/`GCM_BITBUCKET_HELPER` environment variables.
Set these variables to the path of an external helper executable that responds
to the requests as the bundled UI helpers do. See the current `--help` documents
for the bundled UI helpers (`GitHub.UI`/`Atlassian.Bitbucket.UI`) for more
information.
You may also set these variables to the empty string `""` to force terminal/
text-based prompts instead.
### How do I revoke consent for GCM for GitHub.com?
In your GitHub user settings, navigate to
[Integrations > Applications > Authorized OAuth Apps > Git Credential Manager][github-connected-apps]
and pick "Revoke access".
![Revoke GCM OAuth app access][github-oauthapp-revoke]
After revoking access, any tokens created by GCM will be invalidated and can no
longer be used to access your repositories. The next time GCM attempts to access
GitHub.com you will be prompted to consent again.
### I used the install from source script to install GCM on my Linux distribution. Now how can I uninstall GCM and its dependencies?
Please see full instructions [here][linux-uninstall-from-src].
### How do I revoke access for a GitLab OAuth application?
There are some scenarios (e.g. updated scopes) for which you will need to
manually revoke and re-authorize access for a GitLab OAuth application. You can
do so by:
1. Navigating to [the **Applications** page within your **User Settings**][gitlab-apps].
2. Scrolling to **Authorized applications**.
3. Clicking the **Revoke** button next to the name of the application for which
you would like to revoke access (Git Credential Manager is used here for
demonstration purposes).
![Button to revoke GitLab OAuth Application access][gitlab-oauthapp-revoke]
4. Waiting for a notification stating **The application was revoked access**.
![Notifaction of successful revocation][gitlab-oauthapp-revoked]
5. Re-authorizing the application with the new scope (GCM should automatically
initiate this flow for you next time access is requested).
### Q: What do the `configure` and `unconfigure` commands do?
#### `configure`
The `configure` command will set up Git to use GCM exclusively as the credential
helper. The `configure` command is automatically called by the installers for
Windows and macOS, but you can also run it manually.
It will also set Git to provide the full remote URL (including path) to
credential helpers for Azure Repos remotes using the `dev.azure.com` URL format.
This is required in order to be to able to correctly identify the correct
authority for that Azure DevOps organization.
Specifically, the `configure` command will modify your user Git configuration to
include the following lines:
```ini
[credential]
helper =
helper = <path-to-gcm>
[credential "https://dev.azure.com"]
useHttpPath = true
```
..where `<path-to-gcm>` is the absolute path to the GCM executable.
The empty `helper =` line makes sure that existing credential helpers that may
be set in the system Git configuration are not used. For more details see the
[credential.helper][helper-config-docs].
If you pass the `--system` option, the `configure` command will instead modify
the system Git configuration. This is useful if you want to set up GCM for all
users on a machine.
#### `unconfigure`
This command essentially undoes what the `configure` command does. It will check
your Git configuration for the lines added by the `configure` command and remove
them. The `unconfigure` command is run by the uninstaller for Windows and the
uninstall script on macOS.
On Windows, if run with the `--system` option, the `unconfigure` command will
also ensure that the `credential.helper` setting in the system Git configuration
is not removed and is left as `manager`, the default set by Git for Windows.
[autodetect]: autodetect.md
[azure-ssh]: https://docs.microsoft.com/en-us/azure/devops/repos/git/use-ssh-keys-to-authenticate?view=azure-devops
[bitbucket-ssh]: https://confluence.atlassian.com/bitbucket/ssh-keys-935365775.html
[config-gui-prompt]: configuration.md#credentialguiprompt
[config-interactive]: configuration.md#credentialinteractive
[create-issue]: https://github.com/git-ecosystem/git-credential-manager/issues/create
[credstores]: credstores.md
[download-and-install]: ../README.md#download-and-install
[enable-windows-ssh]: https://support.microsoft.com/topic/update-to-enable-tls-1-1-and-tls-1-2-as-default-secure-protocols-in-winhttp-in-windows-c4bd73d2-31d7-761e-0178-11268bb10392
[env-gui-prompt]: environment.md#GCM_GUI_PROMPT
[env-interactive]: environment.md#GCM_INTERACTIVE
[env-trace]: environment.md#GCM_TRACE
[gcm-linux]: https://github.com/Microsoft/Git-Credential-Manager-for-Mac-and-Linux
[gcm-windows]: https://github.com/Microsoft/Git-Credential-Manager-for-Windows
[git-term-prompt]: https://git-scm.com/docs/git#Documentation/git.txt-codeGITTERMINALPROMPTcode
[github-connected-apps]: https://github.com/settings/connections/applications/0120e057bd645470c1ed
[github-oauthapp-revoke]: img/github-oauthapp-revoke.png
[github-ssh]: https://help.github.com/en/articles/connecting-to-github-with-ssh
[gitlab-apps]: https://gitlab.com/-/profile/applications
[gitlab-oauthapp-revoke]: ./img/gitlab-oauthapp-revoke.png
[gitlab-oauthapp-revoked]: ./img/gitlab-oauthapp-revoked.png
[helper-config-docs]: https://git-scm.com/docs/gitcredentials#Documentation/gitcredentials.txt-helper
[multiple-users]: multiple-users.md
[netconfig-http-proxy]: netconfig.md#http-proxy
[linux-uninstall-from-src]: ./linux-fromsrc-uninstall.md
[windows-server-tls]: https://docs.microsoft.com/previous-versions/windows/it-pro/windows-server-2012-R2-and-2012/dn786418(v=ws.11)#tls-12
[wsl]: wsl.md