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

[Bug]: nextcloud client failed to parse netrc #7177

Closed
5 of 8 tasks
130e opened this issue Sep 21, 2024 · 12 comments · Fixed by #7698
Closed
5 of 8 tasks

[Bug]: nextcloud client failed to parse netrc #7177

130e opened this issue Sep 21, 2024 · 12 comments · Fixed by #7698
Labels
1. to develop confirmed bug approved by the team

Comments

@130e
Copy link

130e commented Sep 21, 2024

⚠️ Before submitting, please verify the following: ⚠️

Bug description

After upgrading to 3.14.0, nextcloud client commandline (nextcloudcmd) failed to parse netrc credential with -n option. As a result, nextcloud server prompt for credential.
On the other hand, using --user and --password options work.

Steps to reproduce

  1. Create the file ~/.netrc as:
default
login admin
password mypassword
  1. Run nextcloudcmd from bash.
nextcloudcmd -n --path /Documents /home/user/Nextcloud/Documents/ https://myserver.com
  1. nextcloudcmd failed to parse netrc and prompt for credentials.
09-20 17:27:56:193 [ debug default ]	[ OCC::NetrcParser::parse ]:	error fetching value for "default\nlogin admin\npassword mypassword\n"
Please enter username:

Expected behavior

nextcloudcmd should parsed netrc.

Which files are affected by this bug

netrc

Operating system

Linux

Which version of the operating system you are running.

NixOS 24.11.20240919.c04d565 (Vicuna) x86_64

Package

Distro package manager

Nextcloud Server version

29.0.4

Nextcloud Desktop Client version

3.14.0

Is this bug present after an update or on a fresh install?

Fresh desktop client install

Are you using the Nextcloud Server Encryption module?

Encryption is Disabled

Are you using an external user-backend?

  • Default internal user-backend
  • LDAP/ Active Directory
  • SSO - SAML
  • Other

Nextcloud Server logs

No response

Additional info

No response

@freundhein
Copy link

Same here, on:

  • Linux, Ubuntu 22.04.5 LTS
  • package version including nextcloudcmd is nextcloud-client 3.14.0-20240916.085658.d8fcb9273-1.0~jammy1
  • nextcloud server 29.0.6

I have evidence that it synced normally before the latest update of nextcloudcmd, i.e. before 2024-09-16

@mgallien mgallien added 1. to develop confirmed bug approved by the team and removed 0. Needs triage labels Sep 25, 2024
@pfassina
Copy link

pfassina commented Oct 3, 2024

I also had it working before, and now it is throwing an error.
I'm using a NixOS package.

Nextcloud version 3.14.0
Git revision d8fcb9273729c0e70f99d6f42ed7185c2bb69779
Using Qt 6.7.2, built against Qt 6.7.2
Using 'OpenSSL 3.0.14 4 Jun 2024'
Running on NixOS 24.11 (Vicuna), x86_64

@fatpat
Copy link

fatpat commented Oct 17, 2024

same here

Nextcloud version 3.14.1
Git revision 8b92fc33a289bf4fc7bc7cdd68d25a9ed1ae1782
Using Qt 6.7.2, built against Qt 6.7.2
Using 'OpenSSL 3.0.14 4 Jun 2024'
Running on Ubuntu 22.04.5 LTS, x86_64

@tarastella
Copy link

Same here, running FreeBSD:

Nextcloud version 3.14.1daily
Git revision 8b92fc33a289bf4fc7bc7cdd68d25a9ed1ae1782
Using Qt 6.7.3, built against Qt 6.7.3
Using 'OpenSSL 3.0.13 30 Jan 2024'
Running on FreeBSD 14.1-RELEASE-p5, x86_6

@ncartron
Copy link

ncartron commented Nov 6, 2024

I, too, have the same issue on FreeBSD 14.1-RELEASE-p5, following a Nextcloud upgrade.

@Rudiberto
Copy link

Rudiberto commented Nov 8, 2024

Do we have yet a solution for this Problem? Since that day my backup is not working!
:-(

Machine is Linux Ubuntu 22.04 - Nextcloud 3.14.3-20241107.180900
Server version 29.08

@tarastella
Copy link

@Rudiberto as temporary workaround, I am using something like "nextcloudcmd -u user -p $(cat $passwordfile)".

@Rudiberto
Copy link

[@Rudiberto] as temporary workaround, I am using something like "nextcloudcmd -u user -p $(cat $passwordfile)".

Thank You, very much. I will test that.
I'm passing temporarily user and password inside my script. Guess it makes not that much difference to your solution.
Hopefully it will work again soon. It's never a good sign, when something so essential is not working properly.

@Rudiberto
Copy link

Rudiberto commented Nov 8, 2024

const auto sanitisedTargetUrl = options.target_url.endsWith('/') || options.target_url.endsWith('\\') 
        ? options.target_url.chopped(1) 
        : options.target_url;
    QUrl hostUrl = QUrl::fromUserInput(sanitisedTargetUrl);

This is my main suspect in the Source code. The function seems to catch a misconfiguration, but is probably implemented incorrectly, because when parsing the '.netrc' it becomes an '\n' filled in after the password(s) for each end of line.

Formerly it was done this way:
QUrl hostUrl = QUrl::fromUserInput((options.target_url.endsWith(QLatin1Char('/')) || options.target_url.endsWith(QLatin1Char('\\'))) ? options.target_url.chopped(1) : options.target_url);

@Vagahbond
Copy link

Bump I also encountered the same problem, using nextcloudcmd
version : 3.14.3

fredrik-eriksson added a commit to fredrik-eriksson/desktop that referenced this issue Dec 28, 2024
fredrik-eriksson added a commit to fredrik-eriksson/desktop that referenced this issue Dec 28, 2024
Fixes: nextcloud#7177
Signed-off-by: Fredrik Eriksson <[email protected]>
fredrik-eriksson added a commit to fredrik-eriksson/desktop that referenced this issue Dec 28, 2024
Fixes: nextcloud#7177
Signed-off-by: Fredrik Eriksson <[email protected]>
@fredrik-eriksson
Copy link
Contributor

@Rudiberto as temporary workaround, I am using something like "nextcloudcmd -u user -p $(cat $passwordfile)".

Just a note that this will protect the password from being logged in shell history and such, but password will still be visible in clear text for anyone who can list the process tree on the machine (and it might still be logged in some audit logs). Maybe not a problem for everyone, but something to keep in mind.

As noted in my PR I think the problem is the tokenizing of the netrc content where it expects every field to be separated by " \n\t". I haven't tested but a "netrc-file" formated like this might actually work (space before newline and tab after):

machine 
	<host> 
	login 
	<username> 
	password 
	<userpassword>

@ncartron
Copy link

I have tried different variations of my ~/.netrc file with what @fredrik-eriksson suggested, but still no luck so far.

mgallien pushed a commit to fredrik-eriksson/desktop that referenced this issue Jan 2, 2025
Fixes: nextcloud#7177
Signed-off-by: Fredrik Eriksson <[email protected]>
mgallien pushed a commit to fredrik-eriksson/desktop that referenced this issue Jan 3, 2025
Fixes: nextcloud#7177
Signed-off-by: Fredrik Eriksson <[email protected]>
backportbot bot pushed a commit that referenced this issue Jan 3, 2025
Fixes: #7177
Signed-off-by: Fredrik Eriksson <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
1. to develop confirmed bug approved by the team
Projects
None yet
Development

Successfully merging a pull request may close this issue.

10 participants