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

App settings will not persist on macOS 14 #1924

Open
scottrobertson opened this issue Jun 7, 2023 · 92 comments
Open

App settings will not persist on macOS 14 #1924

scottrobertson opened this issue Jun 7, 2023 · 92 comments

Comments

@scottrobertson
Copy link

I have been trying to work out why my app settings are all resetting, and not persisting in macOS 14. This has been happening for apps such as Raycast, iTerm, Rectangle, Bartender etc. I just tried running mackup uninstall and everything is fixed. And then when i run mackup backup again, none of my settings will persist or save again. Any ideas?

@joshmedeski
Copy link
Contributor

Which files storage method are you using? Can you share your ~/.mackup.cfg with us?

@scottrobertson
Copy link
Author

[storage]
engine = icloud

[applications_to_ignore]
oh-my-zsh
espanso

iCloud

@joshmedeski
Copy link
Contributor

I've seen other mackup users using iCloud have has similar issues. Could you try turning off the feature to optimize mac storage and see if that helps? It will be under the iCloud settings.

Screenshot 2023-06-07 at 4 36 32 PM

My thinking is iCloud is removing these config files from your hard drive to save storage.

@scottrobertson
Copy link
Author

scottrobertson commented Jun 7, 2023

Hey. Just tried that, and it did not help, sadly.

I also did the following:

  • mackup uninstall
  • Open an app, all settings are fine
  • Rename/remove ~/Library/Mobile Documents/com~apple~CloudDocs/Mackup
  • Run mackup backup
  • Reopen the same app, and it has reset all settings
  • mackup uninstall
  • Reopen the app, and all the settings are back

@joshmedeski
Copy link
Contributor

Can you confirm the symbolic links that are generated are valid? The Rename/remove step you mentioned could be causing the symbolic links to break.

@lra any ideas?

@scottrobertson
Copy link
Author

To be clear, I had already run mackup uninstall before the rename/remove. I ran that earlier today to get things working. I did the rename/remove just to basically do a "fresh start" to rule out any old files causing issues etc.

@scottrobertson
Copy link
Author

Hey. Just an update here. I just tried this again using

[storage]
engine = file_system
path = Mackup/

And i get the same result. I run mackup backup, open iTerm2 for example, and all settings have wiped, run mackup uninstall and open it again, and settings are back. So i don't think iCloud is the issue.

@codechenx
Copy link

I have same issue

@ahmadawais
Copy link

Same issue. Started happening when I updated to Dropbox beta, and then tried moving to iCloud. Now it's a mess. Not sure what's wrong, unable to predict a pattern here but with latest macOS this happens:

  • All of a sudden some apps loose their config (have to reconfigure)
  • Some apps like iTerm2 or Terminal don't keep their configs no matter what I do (uninstall/install fresh doesn't help)

@Skowt
Copy link

Skowt commented Jun 26, 2023

+1 on this issue. I was going to say I wonder if this is related to the Apple update that basically made it harder for Cloud apps to work on mac. It also meant you had to change the location of your Dropbox drive.

https://help.dropbox.com/installs/macos-support-for-expected-changes

@scottrobertson
Copy link
Author

+1 on this issue. I was going to say I wonder if this is related to the Apple update that basically made it harder for Cloud apps to work on mac. It also meant you had to change the location of your Dropbox drive.

https://help.dropbox.com/installs/macos-support-for-expected-changes

I don’t think it’s that, no. It even stops working if I just use the file system storage method.

@Skowt
Copy link

Skowt commented Jun 26, 2023

Then I would say it's a recent Apple update. For me this started happening in the last week, which is when I updated to Ventura 13.4.1 (might've also been when I updated to 13.4).

It's possible that there's an unknown bug with the latest update or a "security improvement" that's messing with symlinks 🤔

@Skowt
Copy link

Skowt commented Jun 26, 2023

I've done mackup uninstall for now which has fixed everything but it would be interesting if mackup has any logs stored somewhere? To see exactly what was erroring out. Perhaps a permissions issue that was going undetected? Who knows at this point.

@luispedrofonseca
Copy link

Just lost a couple days on this exact issue because it took me a while to figure why a lot of my settings weren't saving and that mackup was the culprit. Hope this gets solved quickly.

@jagajaga
Copy link

jagajaga commented Jul 13, 2023

cc me

@jacobgraf
Copy link

Any updates on this one? I am having the same issues and it's maddening. I will uninstall for now, but hope it gets fixed soon because I really love Mackup.

MacOS: 14.0 Public Beta (23A5286i)
Mackup: 0.8.37

[storage]
engine = file_system
path = SynologyDrive/Backups

[applications_to_ignore]
illustrator
mackup
zsh
path-finder
streamdeck

@davdroman
Copy link

davdroman commented Jul 20, 2023

If for some reason this issue is due to symlinks and effectively impossible to fix going forward, it might be a good idea to offer an alternate mode of backup by copying over files instead of symlinking them, so that at least the tool doesn't become fully obsolete. I wouldn't mind doing a manual export/import every once in a while as a compromise instead of ditching Mackup altogether.

@ahmadawais
Copy link

ahmadawais commented Jul 20, 2023

I'm quite frustrated with losing all the settings again and again. To a point where I'm planning on rewriting this project one way or the other. It's been mentally taxing. 😮‍💨

I understand life gets in a way and this free software. Appreciate all the hardwork.

@jacobgraf
Copy link

If for some reason this issue is due to symlinks and effectively impossible to fix going forward, it might be a good idea to offer an alternate mode of backup by copying over files instead of symlinking them, so that at least the tool doesn't become fully obsolete. I wouldn't mind doing a manual export/import every once in a while as a compromise instead of ditching Mackup altogether.

Exactly. Honestly, I wish this was a feature today. I don’t really need the symlinking anyway. I just want the peace of mind that when I run mackup backup, my settings are copied somewhere that is versioned and backed up.

@godbout
Copy link
Contributor

godbout commented Aug 1, 2023

I've seen other mackup users using iCloud have has similar issues. Could you try turning off the feature to optimize mac storage and see if that helps? It will be under the iCloud settings.

Screenshot 2023-06-07 at 4 36 32 PM My thinking is iCloud is removing these config files from your hard drive to save storage.

same with the new Dropbox in CloudStorage.

@jacobgraf
Copy link

I've seen other mackup users using iCloud have has similar issues. Could you try turning off the feature to optimize mac storage and see if that helps? It will be under the iCloud settings.
Screenshot 2023-06-07 at 4 36 32 PM
My thinking is iCloud is removing these config files from your hard drive to save storage.

same with the new Dropbox in CloudStorage.

I don't use either of these. I use SynologyDrive and have it set to sync everything. I don't think it has anything to do with the storage engine. I've had to temporarily remove Mackup to get things working, but like I said, I'm hoping they add a way to "copy" your prefs to another location instead of doing the whole symlink thing. That would be fine and preferable, for me.

@godbout
Copy link
Contributor

godbout commented Aug 1, 2023

for me things started failing with Dropbox when they moved to the new CloudStorage shit. (see #1891.) now you can't be certain that Dropbox starts at a proper time. i think the whole symlink thing should be gone yeah. maybe there's something also related to macOS 14 itself, where now it seems we need Apple's approval to read and write our own UserDefaults 🤣️

@neoromantic
Copy link

I've been debugging same issue for past hour, and finally understood that it's due to mackup.

I'm running Sonoma beta.

Here's how it look:

rejecting write of key(s) mainWindowPositionCache in { com.raycast.macos, sergey.petrov, kCFPreferencesAnyHost, /Users/sergey.petrov/Library/Preferences/com.raycast.macos.plist, managed: 0 } from process 7061 (Raycast) because Path not accessible

@romancin
Copy link

Same problem here with Sonoma RC. Mackup is broken :(

@iarchean
Copy link
Contributor

I am experiencing a similar issue, but it is quite strange. My Intel iMac is functioning properly, while my M2 MacBook has stopped working.

@olssonm
Copy link

olssonm commented Sep 29, 2023

Can confirm, having major issues in Sonoma, both for app settings but also system plists; (com.apple.* for example). Discovered it when settings for Tower (the Git-client) and system-level keyboard shortcuts (Library/Preferences/com.apple.symbolichotkeys.plist) didn't persist between reboots.

mackup.cfg:

[storage]
engine = icloud

[applications_to_ignore]
zsh

@gabrielkoerich
Copy link

gabrielkoerich commented Oct 2, 2023

Same issue, settings are not persisted.

Only 'fix' for now is mackup uninstall

my backup workflow is now mackup backup --force && mackup uninstall

@reitermarkus
Copy link

Just as additional information, defaults also doesn't work if the preferences file is a symlink but works with a plain file. So definitely symlinks are the problem.

@ChrisChinchilla
Copy link

ChrisChinchilla commented Oct 5, 2023

Same here as soon as I installed Sonoma, damn… I have a lot of other "non-standard" setup with symlinks too, I really hope they're not all broken…

Edit… They still seem to work thankfully.

@victor-falcon
Copy link

It's possible, somehow, to just disable this files backups. Something like this?

[applications_to_ignore]
macos

@weeebdev
Copy link

weeebdev commented Jul 8, 2024

It's possible, somehow, to just disable this files backups. Something like this?

[applications_to_ignore]
macos

Would love to see that!

@sinewave
Copy link

I'm running into this issue on Sonoma and finally took the time to track it down and came across this issue.
After reading most of this thread, am I correct in assuming there is no current fix for iCloud sync? It seems the solution mentioned above is only for GitHub.
Is the current recommendation to uninstall Mackup?

@sinewave

I've been doing what's suggested above which is to mackup backup --force && mackup uninstall. This will overwrite your saved config with the files in place and it's good enough to generate a git diff which I then commit and push up. You'll have to edit your config files in place because they are no longer symlinked.

I really wish at least the README would get updated because right now this tool will basically break your system forcing you to

I'm doing this until another solution comes along because I don't think there will be any solution for symlinks to work with ~/Library anytime soon. Apple shut it down quietly perhaps due to an exploit and AFAIK don't recognize it as an issue to be resolved.

Thx @jhirn , assuming I'd need to switch from iCloud to Github as my storage system?

@tshu-w
Copy link

tshu-w commented Jul 13, 2024

I'm looking for an alternative to mackup, since soft links no longer work on macOS 14, and mackup temporarily doesn't support copying (the only solution is mackup backup --force && mackup uninstall).

I found unison to be a good alternative. It can perform two-way synchronization between directories with many advanced features (including watch, merge, backup, atomic directory, etc.).

The only thing needed to migrate from mackup to unison is to manually convert mackup's configuration to unison's profile. For example, this is my default profile.

Then we can use the unison -batch -repeat watch to synchronize our configurations. I hope this can help others with similar needs.

@victor-falcon
Copy link

I just discovered this is actually an option.

[applications_to_ignore]
macosx

I'm testing it right now.

@jhirn
Copy link

jhirn commented Aug 12, 2024

I just discovered this is actually an option.

[applications_to_ignore]
macosx

I'm testing it right now.

Results @victor-falcon. I'm so burnt out I don't even want to test it myself. I got bit the other day editing my .profile because I was editing the saved version which is no longer linked and really wish I never switched from my simple script to mackup.

@jussapaavo
Copy link

jussapaavo commented Aug 14, 2024

I just discovered this is actually an option.

[applications_to_ignore]
macosx

I'm testing it right now.

I don't think it makes any difference. MacOS doesn't seem to support symlinks in general in the Application Support directory, so just ignoring the OS preferences is not enough. There are so many other applications using that directory for storing plist files etc and they won't work either.

I didn't find any viable way to use mackup and I followed tshu-w's advice on migrating to unison. I also use dotfiles managers (like chezmoi) for managing my dev env and non-sensitive configs.

@jhirn
Copy link

jhirn commented Aug 14, 2024

I just discovered this is actually an option.

[applications_to_ignore]
macosx

I'm testing it right now.

I don't think it makes any difference. MacOS doesn't seem to support symlinks in general in the Application Support directory, so just ignoring the OS preferences is not enough. There are so many other applications using that directory for storing plist files etc and they won't work either.

I didn't find any viable way to use mackup and I followed tshu-w's advice on migrating to unison. I also use dotfiles managers (like chezmoi) for managing my dev env and non-sensitive configs.

Yeah I traded in my 9 year old ./install.sh 8 line script specifically because this worked with ios application settings. It's a shame that Apple killed it but was more concerning is nothing has been done to address this in mackup (to my knowledge).

Thanks for the recs. I will check out those out before going back to that.

chrisbloom7 added a commit to chrisbloom7/homebrew-core that referenced this issue Aug 19, 2024
`mackup` works by moving config files to an
off-disk backup location (usually a cloud storage
provider like iCloud or Dropbox, etc.) and then
replacing the original file with a symlink to the
backed up version. The intended use is to make
sure program configuration settings and
preferences can be restored if you need to replace
computers, factory reset, etc.

As documented
[here](lra/mackup#2035),
[here](lra/mackup#1924),
[here](lra/mackup#1969 (reply in thread)),
`mackup backup` no longer works on MacOS Sonoma
(likely due to [security
changes](lra/mackup#1924 (comment))
in the app sandbox in Sonoma) and running either
the backup or restore commands on MacOS Sonoma
will result in the loss of all preference files.
Users who backup to a storage provider that has
versioning or backup snapshots may be able to
restore preferences to an older version. For users
backing up to other storage providers that do not
have this feature, such as iCloud, the command
results in total data loss. This issue has been
known to the developer for over a year but there
is no fix, no mention of the issue in the project
README, no warning when running the command, and
no indication in the program output that the
backup process may not have completed properly -
neither in the dry-run mode nor in live mode.
chrisbloom7 added a commit to chrisbloom7/homebrew-core that referenced this issue Aug 19, 2024
`mackup` works by moving config files to an
off-disk backup location (usually a cloud storage
provider like iCloud or Dropbox, etc.) and then
replacing the original file with a symlink to the
backed up version. The intended use is to make
sure program configuration settings and
preferences can be restored if you need to replace
computers, factory reset, etc.

As documented
[here](lra/mackup#2035),
[here](lra/mackup#1924),
[here](lra/mackup#1969 (reply in thread)),
`mackup backup` no longer works on MacOS Sonoma
(likely due to [security
changes](lra/mackup#1924 (comment))
in the app sandbox in Sonoma) and running either
the backup or restore commands on MacOS Sonoma
will result in the loss of all preference files.
Users who backup to a storage provider that has
versioning or backup snapshots may be able to
restore preferences to an older version. For users
backing up to other storage providers that do not
have this feature, such as iCloud, the command
results in total data loss. This issue has been
known to the developer for over a year but there
is no fix, no mention of the issue in the project
README, no warning when running the command, and
no indication in the program output that the
backup process may not have completed properly -
neither in the dry-run mode nor in live mode.
andrewwestling added a commit to andrewwestling/dotfiles that referenced this issue Sep 8, 2024
Since macOS 14 (Sonoma), Mackup has been broken 😞

See here:
- lra/mackup#1924
- https://www.reddit.com/r/macapps/comments/1f1j41a/avoid_mackup_if_you_are_runing_sonoma_or_later/

There are some workarounds but I am taking this opportunity to just simplify my setup a bit

Most of my settings are not that precious that I rely on Mackup to perfectly replicate between machines; I can just do some manual configuration and get most of the way there

I'm removing references to Mackup and its configuration from this repo in this commit
andrewwestling added a commit to andrewwestling/dotfiles that referenced this issue Sep 8, 2024
* Deprecate Mackup in my setup

Since macOS 14 (Sonoma), Mackup has been broken 😞

See here:
- lra/mackup#1924
- https://www.reddit.com/r/macapps/comments/1f1j41a/avoid_mackup_if_you_are_runing_sonoma_or_later/

There are some workarounds but I am taking this opportunity to just simplify my setup a bit

Most of my settings are not that precious that I rely on Mackup to perfectly replicate between machines; I can just do some manual configuration and get most of the way there

I'm removing references to Mackup and its configuration from this repo in this commit

* Update brewfile

Added new things since last time
- 1password-cli
- Keycastr

* Add setup steps for `.zshrc` and `.gitconfig`/`.gitignore`

I still want a way to "sync" my zshrc and git configuration, so I made a little set of instructions and manual steps to perform for this

Between VS Code tasks and README steps, it's here

* Clean up README

Some little things that annoyed me:

- Minor copy edits
- No longer need Obsidian symlink; we're using Obsidian Sync so the iCloud setup is unneeded
hwartig added a commit to hwartig/dotfiles that referenced this issue Sep 16, 2024
@shelper
Copy link

shelper commented Oct 20, 2024

maybe add an option for mackup to globally ignore all files in the folder ~/Library/Preferences
or ignore file type: plist

@aboqasem
Copy link

aboqasem commented Oct 30, 2024

Might be helpful for the future of Mackup, or other tools:

I previously came across Mackup, but proceeded to implement a similar tool for syncing dotfiles, because I want to save them to a Git repo, to have version control, but also without committing unnecessary configurations or secrets.

For files/dirs, it will symlink the configuration.

For defaults, the tool will export only a subset of the keys (configurable) of the given defaults, compare it with the existing tracked configuration, then you decide to export it to tracked file or import from the tracked file to override existing.

Example output:

$ dotsync
DRY RUN...

Dotfiles              symlink   .editorconfig                                         > Already symlinked.
Dotfiles              symlink   .hushlogin                                            > Already symlinked.
Dotfiles              symlink   .zprofile                                             > Already symlinked.
Dotfiles              symlink   .zshrc                                                > Already symlinked.
Oh My Zsh             symlink   .oh-my-zsh                                            > Already symlinked.
LunarVim              symlink   .config/lvim                                          > Already symlinked.
Git                   symlink   .gitattributes_global                                 > Already symlinked.
Git                   symlink   .gitconfig                                            > Already symlinked.
Git                   symlink   .gitignore_global                                     > Already symlinked.
Atuin                 symlink   .config/atuin                                         > Already symlinked.
Zellij                symlink   .config/zellij                                        > Already symlinked.
lazygit               symlink   Library/Application Support/lazygit/config.yml        > Already symlinked.
powerlevel10k         symlink   .p10k.zsh                                             > Already symlinked.
iTerm                 defaults  com.googlecode.iterm2                                 > No change.
Macs Fan Control      defaults  com.crystalidea.MacsFanControl                        > No change.
Rectangle             defaults  com.knollsoft.Rectangle                               > Diff found but is tracked. Saving...
--- /dev/fd/63  2024-10-30 21:37:22
+++ /dev/fd/62  2024-10-30 21:37:22
@@ -9,7 +9,7 @@
                <key>SUHasLaunchedBefore</key>
                <true/>
                <key>SUUpdateRelaunchingMarker</key>
-               <true/>
+               <false/>
                <key>allowAnyShortcut</key>
                <true/>
                <key>almostMaximize</key>
@@ -30,6 +30,8 @@
                <key>footprintAnimationDurationMultiplier</key>
                <integer>0</integer>
                <key>hideMenubarIcon</key>
+               <true/>
+               <key>internalTilingNotified</key>
                <true/>
                <key>launchOnLogin</key>
                <true/>
AltTab                defaults  com.lwouis.alt-tab-macos                              > Diff found. Backing up existing and saving new...
--- /dev/fd/63  2024-10-30 21:37:22
+++ /dev/fd/62  2024-10-30 21:37:22
@@ -38,9 +38,8 @@
                <string>⌘</string>
                <key>holdShortcut3</key>
                <string>⌥</string>
-               IF I CHANGED THE FILE
                <key>menubarIcon</key>
-               <string>3</string>
+               <string>2</string>
                <key>mouseHoverEnabled</key>
                <string>false</string>
                <key>nextWindowShortcut</key>
CleanMyMac            defaults  com.macpaw.CleanMyMac4                                > Diff found but is tracked. Saving...
--- /dev/fd/63  2024-10-30 21:37:23
+++ /dev/fd/62  2024-10-30 21:37:23
@@ -5,9 +5,9 @@
                <key>MenubarAppEnabled</key>
                <true/>
                <key>SUAutomaticallyUpdate</key>
-               <true/>
+               <false/>
                <key>SUEnableAutomaticChecks</key>
-               <true/>
+               <false/>
                <key>SUHasLaunchedBefore</key>
                <true/>
                <key>SeenIntroVideo</key>

Backed up paths: ~/dev/dotfiles/synced/defaults/com.lwouis.alt-tab-macos.plist.1730295442743.bak
Review and commit.

Nothing was actually done. Use --do to apply changes.

This is how the config looks like as of now:

https://github.com/aboqasem/dotfiles/blob/44c1c1216844d08441b2a9bedea40750eb3d41d2/syncconf.toml#L1-L149

If any of the above files changes, it prints out the diff and I would have visibility of what exactly changed.

Was thinking of properly designing it and publishing it, but since it fits my usage and I'm not sure if it's useful to others, I haven't started yet.

I believe the ultimate goal would be to build something like lazygit but for dotfiles.

martimlobao added a commit to martimlobao/dotfiles that referenced this issue Nov 4, 2024
- use more straightforward logic for bootstrapping and unboostrapping
- mackup is broken and there are no signs of a fix
- see: lra/mackup#1924 lra/mackup#2035
martimlobao added a commit to martimlobao/dotfiles that referenced this issue Nov 4, 2024
- use more straightforward logic for bootstrapping and unboostrapping
- mackup is broken and there are no signs of a fix
- see: lra/mackup#1924 lra/mackup#2035

## Summary by Sourcery

Remove the mackup dependency and implement custom logic for managing
dotfiles and application settings using new functions 'dotlink' and
'dotunlink'. Update scripts to use rsync for copying files and managing
symbolic links.

New Features:
- Introduce new functions 'dotlink' and 'dotunlink' for managing
symbolic links in the home directory.

Enhancements:
- Replace mackup dependency with custom logic for managing dotfiles and
application settings.
@brandon-fryslie
Copy link

I haven't had a chance to read through this, but I implemented changes (I think) should basically resolve this issue in this PR here: #1947

I did it over the course of a night or two, and didn't write tests, and broke a bunch of backward compatibility, and simplified and refactored a decent amount of questionable code. So it's far from ready to go into this repo. But from what I can tell it completely solves the root problem of incompatibility with Sequoia. In case anyone feels like taking up the mantle, here it is. MIT license, use it as you wish.

I'd love to contribute these changes back, but the backward compatibility requirements increase the scope by a pretty decent multiple. I don't really care about maintaining compatibility with stuff that a) didn't work great even before Sequoia and b) doesn't work at all now. I use it myself, and I may rename the project to avoid confusion (obviously giving all due credit everywhere I possibly can) and set up a process by which others can more easily use it. If anyone would be interested in that, let me know. Otherwise if someone wants to use my PR to go thru and fix this project for sequoia, you have my warmest blessing.

I would be delighted if the code were useful to someone. Here is a general overview of what this PR implements:

  • Copy files rather than symlink them. Works for both backup and restore
  • Print a visual diff (in the terminal) of any differences in the preferences file(s), so you can make an informed decision when you might overwrite some data. Works with folders and stuff but I'm sure there are a few bugs in this part, like I said I wrote everything in 2 days
  • Scoping backup and restore to individual apps
  • LOTS of general refactoring and code deduplication / simplification (this is probably the biggest barrier to integrating it tbh)
  • Removed python2.7 compatibility
  • No tests, I'm sure I broke pretty much every existing test

Just FYI, I exclusively develop on Mac hardware, and use iCloud as a backend for this. Not familiar with the requirements on other systems / cloud providers / whatever.

There are some hurdles to getting this merged. But since the alternative is a project that irrevocably destroys all your preferences when you use it, maybe it makes sense to start fresh in a sense. If people are actually interested in this I can clean up the code and get it into a state for general release. Just do an @ mention or add a reaction to this comment. If the reactions are positive, I'd be happy to help get this situation fixed. If there is no reaction or people want to keep this repo as-is, no biggie at all.

Have a lovely evening, Brandon

@Wxh16144
Copy link
Contributor

The symlinking caused me to lose a configuration once, and after much hesitation, I wrote an alternative. It only has copy/restore operations. It will not create any soft links. And I generate a log each time I back up, establishing the corresponding relationships.

github: https://github.com/Wxh16144/backup-cli#wuxhbackup-cli

And it is fully compatible with mackup's configuration file. I need to thank him. I implemented it using the nodejs language I am familiar with.

@godbout
Copy link
Contributor

godbout commented Jan 16, 2025

The symlinking caused me to lose a configuration once, and after much hesitation, I wrote an alternative. It only has copy/restore operations. It will not create any soft links. And I generate a log each time I back up, establishing the corresponding relationships.

github: https://github.com/Wxh16144/backup-cli#wuxhbackup-cli

And it is fully compatible with mackup's configuration file. I need to thank him. I implemented it using the nodejs language I am familiar with.

辛苦了!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests