Table of Contents
- ABOUT THE PROJECT
- GENERAL QUESTIONS
- How safe is the app to use?
- What's the difference between Specter-desktop and Specter-DIY?
- Is a full node necessary for using Specter-desktop?
- *I get this message: "This is a development server. Do not use it in a production deployment.". Should i worry?
- I'm not sure I want the Bitcoin-Core wallet functionality to be used, is that mandatory? If so, is it considered secure?
- How many addresses does an HD wallet have, and are they all the same?
- If the Bitcoin Core instance we are connecting to already has a wallet, is it possible to load it via the UI if we know the name, and could we import a .dat file?
- Why when I export a multisig wallet from specter-desktop (settings > export > copy wallet data) created from devices with only segwit ZPUBs, do I get a data structure with expected segwit derivation paths but XPUBs instead?
- Does Specter have coin control?
- USAGE
- How do I run the app?
- How do i verify the signatures of the binaries?
- Where do i find the logs?
- What types of ways can I run specter-desktop?
- Devices? Wallets? What is the difference?
- What do I need to do in order to create a multisig wallet?
- Is my understanding correct that specter-desktop does not hold any keys and you need to create a multisig wallet in order to sign transactions and send funds?
- How would one sign with Electrum? Do I need to create multisig wallet in Electrum first or can I create it with specter-desktop?
- Can I use Ledger and ColdCard multisig while CC remains air-gapped?
- Can I use Bluewallet with Specter DIY?
- Which hardware wallets are supported?
- Can this also work with external nodes like Casa, MyNode, and Raspilitz?
- Can I use Tor?
- I forgot my password, how can I reset it?
- BACKING UP FUNDS
- If something happens to the
~/.specter
folder, is it still possible to restore access to multisigs created there (assuming there is no backup of the~/.specter
folder)? - To recover a multisig that was built on specter (eg: 2 of 3 with ColdCard), is having the seeds of all 3 signing wallets sufficient or do we need to backup more info?
- If something happens to the
- SPECTER-DIY
- What does the Specter-DIY consist of?
- Is specter-DIY safe to use?
- I'm wondering what if someone takes the device? How does Specter-DIY approach this scenario?
- Currently there is a
specter_hwi.py
file, which implements the HWIClient for Specter-DIY. Is there any reason you didn't add that directly to HWI? - Do you have a physical security design?
- Is there a simulator I can try the Specter-DIY with?
- Is there a goal to get Specter-DIY loading firmware updates from the SD card?
- Can Specter-DIY register cosigner xpubs like ColdCard? I know you wipe private keys on shutdown, but do you save stuff like that?
- Once you add the javacard (secure element) you'll save the private keys, too?
- TROUBLESHOOT
- The AppImage is not starting on Debian 10
- I have issues connecting my Hardware-Wallet via USB?!
- How to upgrade Specter-desktop?
- Laptop/Desktop
- Raspiblitz
- umbrel
- How can I access the web interface if it's hosted on a headless computer?
- How can I access the Specter Desktop web interface with my phone?
- Keep getting: No matching distribution found for cryptoadvance.specter
- Even after upgrading to python3 it's still looking at 2.7 version. I uninstalled 2.7, so not sure where to go next?
- I created an existing wallets but even after rescanning, specter couldn't find any (or not enough) funds?
- How to delete a wallet using a remote full node?
- Trying to connect specter-desktop to my remote Bitcoin Core node on my LAN few times but no success.
bitcoin.conf
has theserver=1
option, should there be something else since I get this errorProcess finished with code -1Error message: Failed to connect
message? - Backup files not showing when trying to load backups
- DIY TROUBLESHOOT
- HWW TROUBLESHOOT
- TECHNICAL QUESTIONS (not dev related)
- FUTURE FEATURES
- VIDEOS
- 1 Getting started with Specter-DIY and Specter-Desktop
- 2 Assembling Specter-DIY
- 3 Specter-DIY air-gapped open source bitcoin hardware wallet overview
- 4 Build your own bitcoin hardware-wallet YT series
- What is the difference between that project (DIYbitcoinhardware) & Specter? Is DIYbitcoinhardware sort of a prerequisite for Specter?
The goal of this project is to make a convenient and user-friendly GUI with a focus on multisignature setup with air-gapped (offline) hardware wallets. We first wanted to make a new hardware wallet (HWW), but after we understood that everything can be hacked, we decided to build a user-friendly multisig Desktop App and nice DIY Hardware Wallet.
"A specter is haunting the modern world, the specter of crypto anarchy."
The Crypto Anarchist Manifesto - Timothy C. May - Sun, 22 Nov 92 12:11:24 PST
Specter is that little ghost helping the sovereign cypherpunk to protect his property rights. We are aware of the vulnerability (Spectre) and know there is an infinite game against vulnerabilities. https://en.wikipedia.org/wiki/Spectre_(security_vulnerability) In Bitcoin Cold storage we can use multisig setups and different hardware wallets to mitigate these risks, while protecting our privacy by verifying transactions on our own node.
It is watch-only (private keys are protected by HWW) and compatible with multisig in Electrum, so even if something breaks you always have a fallback option while we fix the bug. So go for it :)
We try to use default descriptors and derivation paths exactly for this reason: to be compatible with other wallets. Even if we add advanced features such as miniscript, you will always have Bitcoin Core to fall back to.
Specter-desktop is a watch-only GUI software wallet running on Bitcoin Core or Electrum using its wallet and full node functionality. Bitcoin Core tracks addresses, UTXO (unspent transaction outputs) and composes PSBT (partially-signed bitcoin transactions).
Whereas, Specter-DIY is a do-it-yourself hardware wallet from off the shelf-components, that signs transactions (mainly) using QR codes. You can configure it to forget your private keys when powering off or to store them (even on secure elements of smart cards).
No, with Specter 2.0, a Bitcoin node is no longer needed. It's encouraged that you use your own Bitcoin Core node or your own Electrum server but you can also use a public Electrum server. Since version 2.0 we no longer support a Bitcoin Core node managed by the Specter app. You could use the external Electrum option instead or manage the Bitcoin Core node yourself.
*I get this message: "This is a development server. Do not use it in a production deployment.". Should i worry?
No you don't have to worry unless you plan to run specter as a public service on the internet with a growing number of people using it. That was traditionally the use-case for web-apps: Run in the open public internet getting accessed by MANY people. However, that's not how specter is meant to be used. If people get performance issues, it's most likely not because the user-base is growing on their specter but because their Raspberry Pi is too weak for that one user who is doing all sorts of other stuff on that Pi on top.
I'm not sure I want the Bitcoin-Core wallet functionality to be used, is that mandatory? If so, is it considered secure?
If you use your own Bitcoin Core node, you don't need any private keys in Bitcoin Core, but you need wallets to be enabled (disablewallet=0
) in your bitcoin.conf
file.
By default the gap limit is 20, but you can go to the wallet settings and import as many addresses as you want. If you know the wallet is old you may want to try importing many addresses (~1000), and then rescanning. The order is the same, and the addresses are also the same as the address derivation process is deterministic for a wallet. Address index is a derivation index of the wallet, so the index and the address itself are connected. Be aware that the number of addresses is impacting the sync-time.
If the Bitcoin Core instance we are connecting to already has a wallet, is it possible to load it via the UI if we know the name, and could we import a .dat file?
Currently, you can create a hot wallet from within the specter-desktop UI, but at the moment it's not possible to extract XPUBs from the existing Core wallet, and without XPUBs change verification will break in all hardware wallets. Change address verification in multisig on a hardware wallet requires ability to check that change and inputs were derived from the same XPUBs. Without XPUBs all hardware wallets will show two outputs so you never know if the change output is actually change or not.
With that being said, wallets created by Bitcoin Core always use hardened derivations, so they don't have useful XPUBs - this breaks multisig address verification on hardware wallets and thus can't verify change addresses. Therefore specter-desktop is creating a Bitcoin Core hot wallet differently - it generates a BIP39 recovery phrase, loads XPRVs to Core and XPUBs to specter-desktop. Then it can be used as a part of multisig setup as usual.
The seed is generated by specter-desktop and then it's imported in a Bitcoin Core wallet, but instead of watch-only it's an XPRV imported using descriptors. More info on descriptors can be found here.
Why when I export a multisig wallet from specter-desktop (settings > export > copy wallet data) created from devices with only segwit ZPUBs, do I get a data structure with expected segwit derivation paths but XPUBs instead?
XPUB is a canonical representation that is supported by Bitcoin Core, whereas ZPUB is an invention of SatoshiLabs that got adopted by the industry, but not by Bitcoin Core. In wallet export file we export Bitcoin Core's descriptor, so it contains master keys in the format that Bitcoin Core understands. More info on descriptors can be found here.
Yes, Specter supports coin control. Go to "Send". Below "Advanced", you can find "Coin selection", click on this. You can then choose UTXOs in the list manually and use them for creating a transaction.
See the documentation: here
There is a great tutorial here explaining it for specter-desktop. A more generic video from kryptokids is here.
If you use a binary-installation (a platform specific download-package) there is a log-file called specterApp.log
in the SPECTER_DATA_FOLDER in your user-directory. So for different platforms, default places are:
- Windows:
C:\Users\YourUser\.specter\specterApp.log
- Linux:
/home/yourUser/.specter/specterApp.log
- MacOS:
/Users/yourUser/.specter/specterApp.log
For pip installations, you need to look into the filespecter.log
in the same directory. If you still have trouble finding that file on your harddrive, have a look at the tooltip in the settings/general/Loglevel item.
There are many ways how to run Specter:
- Specter on local computer, node on remote
- Specter on a remote node, web interface in local network or over Tor (but hardware wallets need to be connected to the node where Specter is running)
- Specter on a remote node, another Specter on your computer in "hwibridge" mode that gives access to your hardware wallets from the remote node (configurable whitelist)
Also you can run it via a platform-specific binary, pip-installation or via a Docker-container. It depends on your needs, and can be customized accordingly.
Specter makes many requests to the Bitcoin Core RPC interface (or Spectrum), so it works better from the same machine where Core is running, but remote is also possible. With that being said, by default requests to the Bitcoin Core RPC are via HTTP, so everything including your RPC login and password are flying around as plaintext. You can use HTTPS and a self-signed certificate to fix that.
If you use hardware wallets and they are usb-connected to specter-desktop then you need to use the hwibridge in the remote cases. However if your HWW is air-gapped (ColdCard, specter-diy, cobo) - then you can use remote web interface.
The logic is that devices store keys, and you can combine these keys in different wallets like multisig or singlesig. So the same device can be used for a nested segwit wallet, native segwit, and many multisig wallets. The only requirement is that all cosigners in multisig wallets should be different devices. For some devices it makes sense to import keys, for example for another passphrase. However it's also possible (and recommended) to create a new device if you want to use a different passphrase for the same device.
XPUBs are needed (from HWW's, laptop with Electrum desktop wallet, Specter-DIY, etc.) in order to create a multisig setup, but don't worry it's in watch-only mode! First you need to “add devices” that store keys for the wallet. After creating the devices, you have to create the type of wallet you want (2-of-2, 3-of-5, etc.) and select the corresponding devices/keys - you need at least two devices to create a multisig wallet.
Is my understanding correct that specter-desktop does not hold any keys and you need to create a multisig wallet in order to sign transactions and send funds?
Yes, especially if you use Spectrum. However, if you use Core as backend, there is a hot wallet-feature which we mainly use for testing/development and trouble shooting.
How would one sign with Electrum? Do I need to create multisig wallet in Electrum first or can I create it with specter-desktop?
You need to create it in both wallets. When you start creating multisig wallet in Electrum it will give you the bech32 extended public key (ZPUB) where you can then add it to specter-desktop as well as other ZPUBS from other devices, and then add them to Electrum. After that you can start using Electrum as a signer. Electrum support got much better lately. We now have a dedicated electrum device with a specific explanation. If you're running into trouble, this video might still help a lot and gives more details.
Yes you can use the ColdCard with its SD card without connecting it to the computer via USB. You just need to import the ColdCard public keys with SD card. Just after creating the multisig wallet, you should go to the wallet page, click on the Settings tab, then scroll down to the Export and click on the export to ColdCard option. It will download a file you can import with the SD card to ColdCard and show you a notification with the instructions on how to do this. This will allow the ColdCard to be “aware” of the multisig and sign transactions for it.
Yes you can use BlueWallet in watch-only mode and sign with Specter DIY. See it in action here
All major once! Checkout the list when you add a new device.
Absolutely, as well as any other DIY bitcoin full, or pruned, node!
Currently Raspiblitz (https://github.com/rootzoll/raspiblitz), has explicit support and you can automatically install it as bonus-software. Also umbrel has it in the app store. Mynode has it on Mynode premium. Start9 has it as well. There are differences mainly on update policy and frequency.
Yes there is Tor support. People are using Tor in two ways:
- To increase privacy by routing external calls through Tor
- Use Tor hidden services to get access from the outside
In Specter version 1.0, we have supported both. In version 2.0, running Specter as a hidden service is currently not supported and we'll might never support it. If you want that, please use a node in the box-project like Raspiblitz which will make Specter available as a Tor hidden service by default. With that being said, beware that it's not practical yet to sign transactions via Tor:
- Specter-DIY needs the camera which is not available in the Tor-browser (yet)
- You could use HWI-wallets, but you would need to plug the wallet into the machine where specter-desktop is running on, but this is usually not the use-case you're looking for when using Tor.
Progress on Tor Support for QR-code scanning is tracked in this issue
Check the .specter-folder in your home folder (or on your mynode/raspiblitz/...). There is a file called config.json
in there which has a line like this:
"auth": {
"method": "somethingInHere",
...
},
Depending on "what's written in somethingInHere
:
- If it's
rpcpasswordaspin
, you can lookup the password in yourbitcoin.conf
-file in a line likerpcpassword=YourPasswordHere
- If it's
usernamepassword
, you won't be able to recover the password but you can deactivate it by setting it tonone
and restart Specter. - If it's
none
(or you just set it tonone
) you can login without any password. So hurry up with setting it again within specter.
If something happens to the ~/.specter
folder, is it still possible to restore access to multisigs created there (assuming there is no backup of the ~/.specter
folder)?
Yes, it's a standard multisig. So you can recreate it as soon as you have master public keys of ALL the devices - either with Specter, or Electrum.
If your ~/.specter
folder is gone and only one of your devices is lost
without a backup, then all your funds are LOST, even if you have a 1/4-multisig-wallet.
When using Specter and importing an old wallet you would need to re-scan the blockchain in the wallet settings page.
The labeld which you set within Specter will only reappear if you restore a Specter-backup, though.
To recover a multisig that was built on specter (eg: 2 of 3 with ColdCard), is having the seeds of all 3 signing wallets sufficient or do we need to backup more info?
Having seeds is enough, but in case you lose one of the seeds it is also mandatory that you also backup your XPUBs. You can go to the wallet settings and export it as json file, this file has all the public key information needed. "Export to wallet" software should give you one json file with all information needed for the recovery of your watch only wallet later on.
It consists of:
- STM32F469 discovery board
- QR Code scanner from Waveshare
- Power Bank (small)
- miniUSB and microUSB cable
- Prototype Shield
- A few pin connectors
Shopping list link + assembly link Waveshare QR scanner is recommended as it has a good quality/price ratio.
It has been used by many people in production in multi- and singlesig setups. But, keep in mind: "Don't trust, verify!"
It supports passphrases as an additional security layer, but currently it has two modes of operation - agnostic when your secrets are not stored on the device and you need to enter recovery phrase every time you use the device, and reckless when it is stored on flash and can be extracted.
We are working on smart card support so you could store your keys on removable secure element in a credit card form factor, as well as an option to encrypt secrets with a key stored on the SD card. See this recently opened issue thanks to @Thomas1378 in the Telegram chat!
Currently there is a specter_hwi.py
file, which implements the HWIClient for Specter-DIY. Is there any reason you didn't add that directly to HWI?
Putting it into HWI means: "this is a hardware wallet people should consider using for real". Currently, we would strongly advice NOT to use USB with Specter-DIY, but to use QR codes instead.
We will make a pull request to HWI when we think it's safe enough. In particular when we will have a secure bootloader that verifies signatures of the firmware, and USB communication is more reliable.
There is physical security, if you use the smart cards, which is a similar setup to Coldcard's usage of secure elements (to store secrets).
Yes. Specter-DIY in simulator-mode simulates QR code scanner over TCP, see here
At the moment we don't have a proper bootloader and secure element integration yet, but we're moving in that direction! I think SD card is a good choice, also QR codes might be possible, but we need to experiment with them a bit.
Can Specter-DIY register cosigner xpubs like ColdCard? I know you wipe private keys on shutdown, but do you save stuff like that?
Yes, we keep wallet descriptors and other public info.
With the secure element you will have three options:
- agnostic mode, forgets key after shutdown
- store key on the smartcard but do all crypto on application MCU
- store key and do crypto on the secure element
Last seems to be the most secure, but then you trust proprietary crypto implementation. Second option saves private key on the secure element under pin protection, but also encrypted, so secure element never knows the private key.
This is a known issue. See here. A questionable workaround might be to start with --no-sandbox
. The security-implications are beyond this FAQ. Please check the issues for more information.
- Make sure to not use the Safari-Browser. Chrome is the best option, Firefox should work as well.
- Make sure that your USB-cable is working. Often enough they are not working anymore.
- Also, make sure to upgrade to the latest firmware, ledger but also others are known to not work with specific older versions.
- On Linux, there is also something called udev-rules which have to be installed.
- Then, there might be confusion about the computer to plug it in. Do you run specter locally or on some remote-computer? Without the hwi-bridge, you need to plug your hardware wallet in the USB-port of the computer you're running specter on. If you want to use your computer and not the remote one, checkout the HWIBridge
- Also unplug other maybe exotic USB hardware like game-controllers, printers and basically everything, just for testing purposes.
- If you're using the hwi-bridge, skip it for testing purposes and use specter locally to let it connect to your local
This depends very much on how you've installed it in the first place. You might have it running on a node-implementation like nodl, RaspiBlitz or MyNode or you have it running on your desktop or laptop. MyNode doesn't support manual upgrade, but let's start with the laptop:
If you have downloaded a binary, simply do it again with the new version. If you have a pip-installation (and installed it as described), use this command:
pip3 install cryptoadvance.specter --upgrade
To check (before and/or afterwards) your installed version, you can use: pip3 show cryptoadvance.specter
You might want to wait until raspiblitz is providing an update. It takes longer but if you're not technically literate, that might be a better option. However, up from Version 1.6.1, Raspiblitz offers an update-possibility in the menu. Prior to that or as a part of troubleshooting-procedure, you can also do something like this:
sudo su - specter
. ./.env/bin/activate
pip3 list | grep specter
pip3 install cryptoadvance.specter --upgrade
pip3 list | grep specter
exit
sudo systemctl restart specter
unknown.
You can either set --host 0.0.0.0 python -m cryptoadvance.specter server --host 0.0.0.0
or configure nginx to forward connections from specific port to specter.
Alternatively, you can also define --port 80 if you want to have it on default http port of the computer.
One drawback though is that with http and external access you will not get camera scanning functionality. It is an issue if you are using specter-DIY as it's necessary to scan QR codes with signed transactions. To fix that you will need a self-signed certificate, we have a document on that here
Similar as above, add --host 0.0.0.0
when starting the Specter server (to bind the Specter server to the local IP of the machine that you are running Specter on), thus python -m cryptoadvance.specter server --host 0.0.0.0
. You can then access the Specter server with your phone by typing http://LOCAL_IP_OF_MACHINE_RUNNING_SPECTER:25441/
in the phone's browser.
Note: Your phone and the machine running Specter have to be connected to the same LAN for this simple approach to work. You might also need to adjust your firewall settings on the machine running Specter. For remote access of your Specter server check the Tor docs.
Try pip3 install cryptoadvance.specter
Specter only works with python3, so use pip3 to install it
brew install python3
Even after upgrading to python3 it's still looking at 2.7 version. I uninstalled 2.7, so not sure where to go next?
Run it with the
command python3 -m cryptoadvance.specter server
- then it will use python3
I created an existing wallets but even after rescanning, specter couldn't find any (or not enough) funds?
Make sure you're using the right type of wallet. Specter is only supporting "Nested Segwit" and "Native SegWit". If you have an older wallet, where addresses are starting with "1" or "3", those funds won't be able to show up in specter. So, make sure you know which type of wallet you want to choose. Also, it's relevant whether you're watching enough addresses. By default only 20 addresses are watched. Maybe your wallet needs more so increase them in the settings-menu of the wallet.
If you're running a pruned node, it's not possible to scan for the entire transaction history without doing a full re-download of the blockchain (IBD). Alternatively, we also support scanning for only the existing wallet balance (UTXO) which is very quick and supports both full and pruned nodes. However, for pruned nodes to support this feature, we must query some external data from an outside source (such as a block explorer, configurable by the user). This does not constitute a security risk, as the validity of the data can be verified against the hash existing on the pruned node itself, but can be a potential privacy risk, although it's possible to get the data over Tor to reduce the potential privacy leak. Yet, we still strongly recommend using a non-pruned-node (if possible) when dealing with older wallets.
Also be aware that if you've use more than one "account" in your old wallet-software, you'd need to create the corresponding key in the device first and create a new wallet based on that account/key. In Specter, one wallet is always tied to exactly one Bitcoin Account (other than e.g. trezor). Bitcoin accounts are actually specified at the device level. By default Specter imports the keys for just your first account. To import keys for additional accounts:
- click on your device to "Add more keys"
- click the "Edit" button at the top right
- click the "Add account" that will have now appeared
- Account 0 is the default that Specter imports on its own. Specify your target account number (accounts start at 0, so your second account is 1, your third account is 2, and so on).
- click "Add account"
- retrieve keys from your device as usual (over USB, airgapped SD card, or QR code)
Now that the other account's keys have been imported, create a new wallet using the new key. After scanning this new wallet for funds, you should see your expected balance.
Apart from that, your old wallet might have used non-standard derivation pathes or extended them in a non-standard-way. https://walletsrecovery.org/ is a good source for collecting such information about your old wallet.
You can't delete the wallet if you are using remote Bitcoin Core node - there is no RPC call to do it remotely. So, deleting wallet works only on the same computer. You can just delete the wallet manually. It's in a folder in the Bitcoin directory. Deleting the wallet in the Specter UI always deletes it from your Specter folder. If you use Spectrum as a backend, there is currently nothing in the UI to delete the wallet in the local database. But, we're working on that.
Trying to connect specter-desktop to my remote Bitcoin Core node on my LAN few times but no success. bitcoin.conf
has the server=1
option, should there be something else since I get this error Process finished with code -1Error message: Failed to connect
message?
rpcallowip
and rpcbind
parameters need to be set in bitcoin.conf
When trying to load backups you are required to select the backup folders for either devices or wallets, you are NOT trying to select the JSON files. You can also select the specter-backup folder itself which will allow both devices and wallets to be loaded together. If you have issues doing this on the Specter app then try in browser instead.
Does anyone have any tips on mounting the power bank and QR code scanner to the STM32 board in a somewhat ergonomic manner?
Use the smallest powerbank possible.
Got stuck for a second because I wasn't safely removing my SD card reader, so the files were 0 bytes.
With achow's HWI tool, input and output PSBT are the same. And with Electrum 4, I get a rawtransaction, not a base64 PSBT.
I solved my issue, it turns out my PSBT needed bip32 hints (whatever that means) included. I can now open lightning channels straight from hardware wallet!
No, but you need to enable wallets! disablewallet=0
It specifes -rpcwallet
with every call to bitcoin-cli
We haven't tested it yet. We will work on the bootloader soon and try different update mechanisms. QR codes is one of them. Also considering SD card - might be easier as firmware is 1Mb, so it would require 1000 QR codes.
Yes it will be, and especially effective in "forget after turn off" mode. Then one could use it to split a secret for wallets that don't support it.
When CoinJoin servers and hardware wallets support proof of ownership: https://github.com/satoshilabs/slips/blob/slips-19-20-coinjoin-proofs/slip-0019.md
Unfortunately, we currently only have videos for version 1.0. Version 2.0 videos are missing. Ping us, if you find any.
How to flash and set up an air-gapped hardware wallet that uses QR codes to communicate with the host.
In the video:
- Flashing the firmware
- Generating a new key
- Importing keys to Specter-Desktop software
- Using single-key wallets
- Creating a multisignature wallet and importing it to the device
- Signing multisig transactions
Specter-DIY hardware wallet:
- off-the-shelf components
- costs 100$ - assemble in 5 minutes
- no soldering
- forgets your private key when powered off
What is the difference between that project (DIYbitcoinhardware) & Specter? Is DIYbitcoinhardware sort of a prerequisite for Specter?
Specter is built on top of that micropython build. DIYbitcoinhardware is focusing more on the toolbox without actual application logic, Specter implements logic and GUI on top of it.
Yes, that's why the video was recorded - to give some introduction about the tools we use, and hardware wallets logic in general.