
Chivo Wallet
App StoreOur wallet review process
We examine wallets starting at the code level and continue all the way up to the finished app that lives on your device. Provided below is an outline of each of these steps along with security tips for you and general test results.
Released
7th September 2021
Custody
Self-custodial: The user holds the keys
As part of our Methodology, we ask: Does the product allow self-custody?
The answer is "yes". The user has control of their own keys.
Read more
Source code
Application build
Build cannot be done because the source code is not publicly available.Passed 7 of 8 tests
We answered the following questions in this order:
We stopped asking questions after we encountered a failed answer.
The answer is "yes".
If the answer were "no", we would mark it as "Fake" and the following would apply:
The answer is "no". We marked it as "Fake".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "Fake" and the following would apply:
The bigger wallets often get imitated by scammers that abuse the reputation of the product by imitating its name, logo or both.
Imitating a competitor is a huge red flag and we urge you to not put any money into this product!
The answer is "yes".
If the answer were "no", we would mark it as "Not a wallet" and the following would apply:
The answer is "no". We marked it as "Not a wallet".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "Not a wallet" and the following would apply:
If it’s called “wallet” but is actually only a portfolio tracker, we don’t look any deeper, assuming it is not meant to control funds. What has no funds, can’t lose your coins. It might still leak your financial history!
If you can buy Bitcoins with this app but only into another wallet, it’s not a wallet itself.
The answer is "yes".
If the answer were "no", we would mark it as "A wallet but not for Bitcoin" and the following would apply:
The answer is "no". We marked it as "A wallet but not for Bitcoin".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "A wallet but not for Bitcoin" and the following would apply:
At this point we only look into wallets that at least also support BTC.
The answer is "yes".
If the answer were "no", we would mark it as "Can't send or receive bitcoins" and the following would apply:
The answer is "no". We marked it as "Can't send or receive bitcoins".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "Can't send or receive bitcoins" and the following would apply:
If it is for holding BTC but you can’t actually send or receive them with this product then it doesn’t function like a wallet for BTC but you might still be using it to hold your bitcoins with the intention to convert back to fiat when you “cash out”.
All products in this category are custodial and thus funds are at the mercy of the provider.
The product cannot be independently verified. If the provider puts your funds at risk on purpose or by accident, you will probably not know about the issue before people start losing money. If the provider is more criminally inclined he might have collected all the backups of all the wallets, ready to be emptied at the press of a button. The product might have a formidable track record but out of distress or change in management turns out to be evil from some point on, with nobody outside ever knowing before it is too late.
The answer is "no".
If the answer were "yes", we would mark it as "Uses Chaumian eCash" and the following would apply:
The answer is "yes". We marked it as "Uses Chaumian eCash".
We did not ask this question because we failed at a previous question.
If the answer were "yes", we would mark it as "Uses Chaumian eCash" and the following would apply:
Chaumian eCash is a form of electronic token system that provides some privacy benefits over custodial services, but requires trust in mint operators. While the technology itself is promising, wallets implementing it effectively connect to custodial services. There are currently two main incompatible protocols for Chaumian eCash:
- Cashu
- Fedimint While these systems aim to enable what could be called “fist-reach custody” (where users have physical access to their custodians, like a trusted family member), wallets cannot enforce this model. We are seeing users gravitate towards popular mints rather than local ones, which defeats the intended trust model. Even in an ideal “Uncle Jim” scenario where users know their mint operator personally:
- The mint operator can still lose or steal the funds
- The mint could be compromised by hackers
- The mint operator could face regulatory pressure
- Technical issues could result in loss of funds
While Chaumian eCash may serve valid use cases, users should understand that:
- They are trusting the mint operator with custody of their funds
- They should ideally use local mints operated by people they know and can reach
- The privacy benefits come at the cost of giving up self-custody
- The tokens are only as good as the mint operator’s promise to redeem them
The answer is "yes".
If the answer were "no", we would mark it as "Custodial: The provider holds the keys" and the following would apply:
The answer is "no". We marked it as "Custodial: The provider holds the keys".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "Custodial: The provider holds the keys" and the following would apply:
A custodial service is a service where the funds are held by a third party like the provider. The custodial service can at any point steal all the funds of all the users at their discretion. Our investigations stop there.
Some services might claim their setup is super secure, that they don’t actually have access to the funds, or that the access is shared between multiple parties. For our evaluation of it being a wallet, these details are irrelevant. They might be a trustworthy Bitcoin bank and they might be a better fit for certain users than being your own bank but our investigation still stops there as we are only interested in wallets.
Products that claim to be non-custodial but feature custodial accounts without very clearly marking those as custodial are also considered “custodial” as a whole to avoid misguiding users that follow our assessment.
We have to acknowledge that a huge majority of Bitcoiners are currently using custodial Bitcoin banks. If you do, please:
- Do your own research if the provider is trust-worthy!
- Check if you know at least enough about them so you can sue them when you have to!
- Check if the provider is under a jurisdiction that will allow them to release your funds when you need them?
- Check if the provider is taking security measures proportional to the amount of funds secured? If they have a million users and don’t use cold storage, that hot wallet is a million times more valuable for hackers to attack. A million times more effort will be taken by hackers to infiltrate their security systems.
The answer is "yes".
If the answer were "no", we would mark it as "No source for current release found" and the following would apply:
The answer is "no". We marked it as "No source for current release found".
We did not ask this question because we failed at a previous question.
If the answer were "no", we would mark it as "No source for current release found" and the following would apply:
A wallet that claims to not give the provider the means to steal the users’ funds might actually be lying. In the spirit of “Don’t trust - verify!” you don’t want to take the provider at his word, but trust that people hunting for fame and bug bounties could actually find flaws and back-doors in the wallet so the provider doesn’t dare to put these in.
Back-doors and flaws are frequently found in closed source products but some remain hidden for years. And even in open source security software there might be catastrophic flaws undiscovered for years.
An evil wallet provider would certainly prefer not to publish the code, as hiding it makes audits orders of magnitude harder.
For your security, you thus want the code to be available for review.
If the wallet provider doesn’t share up to date code, our analysis stops there as the wallet could steal your funds at any time, and there is no protection except the provider’s word.
“Up to date” strictly means that any instance of the product being updated without the source code being updated counts as closed source. This puts the burden on the provider to always first release the source code before releasing the product’s update. This paragraph is a clarification to our rules following a little poll.
We are not concerned about the license as long as it allows us to perform our analysis. For a security audit, it is not necessary that the provider allows others to use their code for a competing wallet. You should still prefer actual open source licenses as a competing wallet won’t use the code without giving it careful scrutiny.
The product cannot be independently verified. If the provider puts your funds at risk on purpose or by accident, you will probably not know about the issue before people start losing money. If the provider is more criminally inclined he might have collected all the backups of all the wallets, ready to be emptied at the press of a button. The product might have a formidable track record but out of distress or change in management turns out to be evil from some point on, with nobody outside ever knowing before it is too late.Application information
(Analysis from Android review)
Update 2021-10-29: This Tweet:
mke
@structerer
No, it’s around 200k of obfuscated JS code. So I limited my research to a simple text search in the project code and documented what URLs I found. Where possible, I tried to detect the purpose by looking at the code - here it wasn’t, at least not with reasonable effort.
claims the app contains obfuscated code. We downloaded it from apk.support ourselves and threw it into jadx-gui and indeed, we get lots of code like this:
package n.b.b.p0;
import n.b.b.b0;
import n.b.b.i;
import n.b.b.r;
import n.b.b.t;
import n.b.b.u0.a1;
import n.b.b.u0.e1;
public class v extends b0 {
private r a;
private int b;
/* renamed from: c reason: collision with root package name */
private int f16277c;
public v(r rVar) {
this.a = rVar;
if (rVar instanceof t) {
this.b = rVar.getDigestSize();
this.f16277c = ((t) rVar).getByteLength();
return;
}
throw new IllegalArgumentException("Digest " + rVar.getAlgorithmName() + " unsupported");
}
private void adjust(byte[] bArr, int i2, byte[] bArr2) {
int i3 = (bArr2[bArr2.length - 1] & 255) + (bArr[(bArr2.length + i2) - 1] & 255) + 1;
bArr[(bArr2.length + i2) - 1] = (byte) i3;
int i4 = i3 >>> 8;
for (int length = bArr2.length - 2; length >= 0; length--) {
int i5 = i2 + length;
int i6 = i4 + (bArr2[length] & 255) + (bArr[i5] & 255);
bArr[i5] = (byte) i6;
i4 = i6 >>> 8;
}
}
private byte[] generateDerivedKey(int i2, int i3) {
byte[] bArr;
byte[] bArr2;
int i4 = this.f16277c;
byte[] bArr3 = new byte[i4];
byte[] bArr4 = new byte[i3];
int i5 = 0;
for (int i6 = 0; i6 != i4; i6++) {
bArr3[i6] = (byte) i2;
}
byte[] bArr5 = this.salt;
if (bArr5 == null || bArr5.length == 0) {
bArr = new byte[0];
} else {
int i7 = this.f16277c;
int length = i7 * (((bArr5.length + i7) - 1) / i7);
bArr = new byte[length];
for (int i8 = 0; i8 != length; i8++) {
byte[] bArr6 = this.salt;
bArr[i8] = bArr6[i8 % bArr6.length];
}
}
byte[] bArr7 = this.password;
if (bArr7 == null || bArr7.length == 0) {
bArr2 = new byte[0];
} else {
int i9 = this.f16277c;
int length2 = i9 * (((bArr7.length + i9) - 1) / i9);
bArr2 = new byte[length2];
for (int i10 = 0; i10 != length2; i10++) {
byte[] bArr8 = this.password;
bArr2[i10] = bArr8[i10 % bArr8.length];
}
}
int length3 = bArr.length + bArr2.length;
byte[] bArr9 = new byte[length3];
System.arraycopy(bArr, 0, bArr9, 0, bArr.length);
System.arraycopy(bArr2, 0, bArr9, bArr.length, bArr2.length);
int i11 = this.f16277c;
byte[] bArr10 = new byte[i11];
int i12 = this.b;
int i13 = ((i3 + i12) - 1) / i12;
byte[] bArr11 = new byte[i12];
int i14 = 1;
while (i14 <= i13) {
this.a.update(bArr3, i5, i4);
this.a.update(bArr9, i5, length3);
this.a.doFinal(bArr11, i5);
for (int i15 = 1; i15 < this.iterationCount; i15++) {
this.a.update(bArr11, i5, i12);
this.a.doFinal(bArr11, i5);
}
for (int i16 = 0; i16 != i11; i16++) {
bArr10[i16] = bArr11[i16 % i12];
}
int i17 = 0;
while (true) {
int i18 = this.f16277c;
if (i17 == length3 / i18) {
break;
}
adjust(bArr9, i18 * i17, bArr10);
i17++;
}
if (i14 == i13) {
int i19 = i14 - 1;
int i20 = this.b;
System.arraycopy(bArr11, 0, bArr4, i19 * i20, i3 - (i19 * i20));
} else {
System.arraycopy(bArr11, 0, bArr4, (i14 - 1) * this.b, i12);
}
i14++;
i5 = 0;
}
return bArr4;
}
@Override // n.b.b.b0
public i generateDerivedMacParameters(int i2) {
int i3 = i2 / 8;
return new a1(generateDerivedKey(3, i3), 0, i3);
}
@Override // n.b.b.b0
public i generateDerivedParameters(int i2) {
int i3 = i2 / 8;
return new a1(generateDerivedKey(1, i3), 0, i3);
}
@Override // n.b.b.b0
public i generateDerivedParameters(int i2, int i3) {
int i4 = i2 / 8;
int i5 = i3 / 8;
byte[] generateDerivedKey = generateDerivedKey(1, i4);
return new e1(new a1(generateDerivedKey, 0, i4), generateDerivedKey(2, i5), 0, i5);
}
}
The same researcher found more reasons why not to use this app.
App Description
Chivo Wallet is the official Bitcoin and Dollar wallet of the Government of El Salvador. Chivo Wallet allows you to send and receive Bitcoin and / or Dollar between Salvadorans without commission, in the same way it allows users to exchange Bitcoin for Dollar or vice versa without commission. Additionally Chivo is compatible with other Bitcoin on-chain and Lightning wallets. Finally, Chivo connects with the banking system of El Salvador to deposit or withdraw dollars from the platform, and with a network of Chivo ATMs to deposit and withdraw dollars in cash. Chivo has a company version that allows you to charge, assign payment terminals for employees, and pay taxes quickly and easily.
According to Reuters, Bitso is the core partner in the development of Chivo. In Google Play, Gobierno de El Salvador (Government of El Salvador) is the listed developer.
Google Play Reviews
KoolKid Tv
★☆☆☆☆ October 2, 2021
“SUPER BAD” Registration was easy, unfortunately the app stop working (it keep logging but didn’t logging)the second day. After a week I decided to Uninstall the app, thinking that it may solve the logging problems; now when I try to login, it tells me that the password is wrong; in other words I can’t login. I was going to star sending money using this app, but I don’t trust it at this point.
David Llanes
★☆☆☆☆ September 18, 2021
Hard to register if your able to get to the registration process if it doesnt give an error or a conection problem, once your inside and you get the bonus Bitcoin you cant use them unless you put some money on it or someone sends you some. Aside from that its a government run wallet so no open source get what you will from it. There a better wallets out there.
Note The app is only downloadable in select locations which includes the US, El Salvador and some South American countries.
The Site
The official website for the wallet cannot be accessed from certain locations. Using a VPN with a US location allowed us to glean some insight.
4.2 When an Account is closed: (i) Your right to use it to gain access to the Services immediately ceases, (ii) the data or content associated with the Account is deleted and the User and the Account are disconnected (unless the applicable legislation requires them to be kept, returned or transmitted to the User) and (iii) if there is any value in the Account, they will be withdrawn from the destination that the user has informed, if never has informed an Account for this purpose, the balance of your Account will remain blocked until the User proceeds to comply with the process of withdrawal of the balance of your Account.
We get a glimpse of what will happen when a government entity has custody and control over user’s funds:
Finally, the User accepts and agrees that CHIVO SA DE CV may, without prior notice, limit, suspend or terminate the Services and Accounts, prohibit access to the Site, its content, services and tools, restrict or remove stored content , and take technical and legal actions to keep Users out of Chivo Wallet if it considers that they are violating the T&C. Likewise, when creating an Account, the User accepts that the decision to cancel or block it may be based on confidential criteria essential for the Compliance and risk protocols of CHIVO SA DE CV, therefore, the User understands and accepts that the latter has no obligation to disclose details of these internal protocols.
The App
The app can only be installed with the following requirements:
- El Salvadoran DUI (Documento Único de Identidad)
- US, El Salvadora and some South American phone numbers for verification
Verdict
El Salvador’s Chivo wallet is the tip of the spear in President Nayib Bukele’s Bitcoin law recognizing Bitcoin as legal tender. By all indications it is certainly custodial and particularly concerning since a government has a lot of powers to control not just the wallet as the developer, but as an entity with the power to coerce intermediaries by force and by law.
As a custodial app, it is not verifiable.
Tests performed by Daniel Andrei R. Garcia
Do your own research
In addition to reading our analysis, it is important to do your own checks. Before transferring any bitcoin to your wallet, look up reviews for the wallet you want to use. They should be easy to find. If they aren't, that itself is a reason to be extra careful.