Skip to content

Commit

Permalink
MWEB support and syncing issues fix for LTC
Browse files Browse the repository at this point in the history
  • Loading branch information
wombatlabs authored and xiaolin1579 committed Oct 20, 2023
1 parent a19e989 commit 08f08db
Show file tree
Hide file tree
Showing 10 changed files with 89 additions and 11 deletions.
3 changes: 2 additions & 1 deletion examples/litecoin_dash_pool.json
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,8 @@
"payoutSchemeConfig": {
"factor": 2.0
}
}
},
"addressType": "litecoin"
},
{
"id": "dash1",
Expand Down
3 changes: 2 additions & 1 deletion examples/litecoin_pool.json
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,7 @@
"payoutSchemeConfig": {
"factor": 2.0
}
}
},
"addressType": "litecoin"
}]
}
5 changes: 5 additions & 0 deletions src/Miningcore/Blockchain/Bitcoin/BitcoinConstants.cs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,11 @@ public enum BitcoinAddressType
/// Bitcoin Cash
/// </summary>
BCash,

/// <summary>
/// Litecoin
/// </summary>
Litecoin
}

public enum BitcoinTransactionCategory
Expand Down
14 changes: 13 additions & 1 deletion src/Miningcore/Blockchain/Bitcoin/BitcoinJob.cs
Original file line number Diff line number Diff line change
Expand Up @@ -255,7 +255,7 @@ protected virtual Transaction CreateOutputTransaction()
if (coin.HasCommunityAddress)
rewardToPool = CreateCommunityAddressOutputs(tx, rewardToPool);

if (coin.HasCoinbaseDevReward)
if(coin.HasCoinbaseDevReward)
rewardToPool = CreateCoinbaseDevRewardOutputs(tx, rewardToPool);

if(coin.HasFounderReward)
Expand Down Expand Up @@ -434,6 +434,18 @@ protected virtual byte[] SerializeBlock(byte[] header, byte[] coinbase)
// POS coins require a zero byte appended to block which the daemon replaces with the signature
if(isPoS)
bs.ReadWrite((byte) 0);

// if pool supports MWEB, we have to append the MWEB data to the block
// https://github.com/litecoin-project/litecoin/blob/0.21/doc/mweb/mining-changes.md
if(coin.HasMWEB)
{
var separator = new byte[] { 0x01 };
var mweb = BlockTemplate.Extra.SafeExtensionDataAs<MwebBlockTemplateExtra>();
var mwebRaw = mweb.Mweb.HexToByteArray();

bs.ReadWrite(ref separator);
bs.ReadWrite(ref mwebRaw);
}

return stream.ToArray();
}
Expand Down
49 changes: 47 additions & 2 deletions src/Miningcore/Blockchain/Bitcoin/BitcoinJobManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using NLog;
using Org.BouncyCastle.Crypto.Parameters;

namespace Miningcore.Blockchain.Bitcoin;

Expand All @@ -33,17 +34,61 @@ protected override object[] GetBlockTemplateParams()
{
var result = base.GetBlockTemplateParams();

if(coin.HasMWEB)
{
result = new object[]
{
new
{
rules = new[] {"segwit", "mweb"},
}
};
}

if(coin.BlockTemplateRpcExtraParams != null)
{
if(coin.BlockTemplateRpcExtraParams.Type == JTokenType.Array)
result = result.Concat(coin.BlockTemplateRpcExtraParams.ToObject<object[]>() ?? Array.Empty<object>()).ToArray();
else
result = result.Concat(new []{ coin.BlockTemplateRpcExtraParams.ToObject<object>()}).ToArray();
result = result.Concat(new[] { coin.BlockTemplateRpcExtraParams.ToObject<object>()}).ToArray();
}

return result;
}

protected override async Task EnsureDaemonsSynchedAsync(CancellationToken ct)
{
using var timer = new PeriodicTimer(TimeSpan.FromSeconds(5));

var syncPendingNotificationShown = false;

do
{
var response = await rpc.ExecuteAsync<BlockTemplate>(logger,
BitcoinCommands.GetBlockTemplate, ct, GetBlockTemplateParams());

var isSynched = response.Error == null;

if(isSynched)
{
logger.Info(() => "All daemons synched with blockchain");
break;
}
else
{
logger.Debug(() => $"Daemon reports error: {response.Error?.Message}");
}

if(!syncPendingNotificationShown)
{
logger.Info(() => "Daemon is still syncing with network. Manager will be started once synced.");
syncPendingNotificationShown = true;
}

await ShowDaemonSyncProgressAsync(ct);
} while(await timer.WaitForNextTickAsync(ct));
}

protected async Task<RpcResponse<BlockTemplate>> GetBlockTemplateAsync(CancellationToken ct)
{
var result = await rpc.ExecuteAsync<BlockTemplate>(logger,
Expand Down Expand Up @@ -71,7 +116,7 @@ protected override void PostChainIdentifyConfigure()
if(poolConfig.EnableInternalStratum == true && coin.HeaderHasherValue is IHashAlgorithmInit hashInit)
{
if(!hashInit.DigestInit(poolConfig))
logger.Error(()=> $"{hashInit.GetType().Name} initialization failed");
logger.Error(() => $"{hashInit.GetType().Name} initialization failed");
}
}

Expand Down
7 changes: 6 additions & 1 deletion src/Miningcore/Blockchain/Bitcoin/BitcoinJobManagerBase.cs
Original file line number Diff line number Diff line change
Expand Up @@ -384,7 +384,12 @@ protected override async Task<bool> AreDaemonsHealthyAsync(CancellationToken ct)

var response = await rpc.ExecuteAsync<BlockchainInfo>(logger, BitcoinCommands.GetBlockchainInfo, ct);

return response.Error == null;
if(response.Error != null)
{
logger.Error(() => $"Daemon reports: {response.Error.Message}");
return false;
}
return true;
}

protected override async Task<bool> AreDaemonsConnectedAsync(CancellationToken ct)
Expand Down
1 change: 0 additions & 1 deletion src/Miningcore/Blockchain/Bitcoin/BitcoinUtils.cs
Original file line number Diff line number Diff line change
Expand Up @@ -53,5 +53,4 @@ public static IDestination LitecoinAddressToDestination(string address, Network
Debug.Assert(result.GetAddress(litecoin).ToString() == address);
return result;
}

}
6 changes: 6 additions & 0 deletions src/Miningcore/Blockchain/Bitcoin/DaemonResponses/Mweb.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
namespace Miningcore.Blockchain.Bitcoin.DaemonResponses;

public class MwebBlockTemplateExtra
{
public string Mweb { get; set; }
}
11 changes: 7 additions & 4 deletions src/Miningcore/Configuration/ClusterConfig.cs
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ public enum CoinFamily

[EnumMember(Value = "conceal")]
Conceal,

[EnumMember(Value = "cryptonote")]
Cryptonote,

Expand Down Expand Up @@ -261,6 +261,9 @@ public class BitcoinNetworkParams
[JsonProperty(DefaultValueHandling = DefaultValueHandling.Ignore)]
public JToken BlockTemplateRpcExtraParams { get; set; }

[JsonProperty(DefaultValueHandling = DefaultValueHandling.Ignore)]
public bool HasMWEB { get; set; }

[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
public Dictionary<string, BitcoinNetworkParams> Networks { get; set; }

Expand Down Expand Up @@ -501,13 +504,13 @@ public partial class ConcealCoinTemplate : CoinTemplate
/// </summary>
[JsonProperty(Order = -4, DefaultValueHandling = DefaultValueHandling.Include)]
public int HashVariant { get; set; }

/// <summary>
/// Conceal network hashrate = `Difficulty / DifficultyTarget`
/// See: parameter -> DIFFICULTY_TARGET in src/CryptoNoteConfig.h
/// </summary>
public ulong DifficultyTarget { get; set; }

/// <summary>
/// Smallest unit for Blockreward formatting
/// </summary>
Expand Down Expand Up @@ -898,7 +901,7 @@ public partial class ClusterPaymentProcessingConfig
/// <summary>
/// Indentifier used in coinbase transactions to identify the pool
/// </summary>
public string CoinbaseString { get; set; }
public string CoinbaseString { get; set; }
}

public partial class PersistenceConfig
Expand Down
1 change: 1 addition & 0 deletions src/Miningcore/coins.json
Original file line number Diff line number Diff line change
Expand Up @@ -1788,6 +1788,7 @@
}
]
},
"hasMWEB": true,
"shareMultiplier": 65536,
"explorerBlockLink": "https://chainz.cryptoid.info/ltc/block.dws?$height$.htm",
"explorerTxLink": "https://chainz.cryptoid.info/ltc/tx.dws?{0}.htm",
Expand Down

0 comments on commit 08f08db

Please sign in to comment.