mirror of
				https://source.quilibrium.com/quilibrium/ceremonyclient.git
				synced 2025-04-04 19:36:54 +00:00 
			
		
		
		
	v1.0.1
This commit is contained in:
		
							parent
							
								
									8276e0d1c3
								
							
						
					
					
						commit
						ec7ea35a2d
					
				
							
								
								
									
										123
									
								
								bootstrap.go
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								bootstrap.go
									
									
									
									
									
								
							| @ -11,6 +11,7 @@ import ( | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 
 | ||||
| 	"github.com/cloudflare/circl/sign/ed448" | ||||
| 	bls48581 "source.quilibrium.com/quilibrium/ceremonyclient/ec/bls48581" | ||||
| @ -112,100 +113,98 @@ func GetSequencerState() string { | ||||
| 	return string(sequencerState) | ||||
| } | ||||
| 
 | ||||
| func Bootstrap(batch uint, batchSize uint) { | ||||
| 	if batch == 65536/batchSize { | ||||
| 		return | ||||
| func Bootstrap() { | ||||
| 	secretBytes := make([]byte, (8 * int(bls48581.MODBYTES))) | ||||
| 	rand.Read(secretBytes) | ||||
| 	secret = bls48581.FromBytes(secretBytes) | ||||
| 	secret.Mod(bls48581.NewBIGints(bls48581.CURVE_Order)) | ||||
| 
 | ||||
| 	bcjRes, err := http.DefaultClient.Post(HOST+"current_state", "application/json", bytes.NewBufferString("{}")) | ||||
| 	if err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 
 | ||||
| 	if batch == 0 { | ||||
| 		secretBytes := make([]byte, (8 * int(bls48581.MODBYTES))) | ||||
| 		rand.Read(secretBytes) | ||||
| 		secret = bls48581.FromBytes(secretBytes) | ||||
| 	defer bcjRes.Body.Close() | ||||
| 
 | ||||
| 		bcjRes, err := http.DefaultClient.Post(HOST+"current_state", "application/json", bytes.NewBufferString("{}")) | ||||
| 		if err != nil { | ||||
| 			panic(err) | ||||
| 		} | ||||
| 
 | ||||
| 		defer bcjRes.Body.Close() | ||||
| 
 | ||||
| 		bcjBytes, err := io.ReadAll(bcjRes.Body) | ||||
| 		if err != nil { | ||||
| 			panic(err) | ||||
| 		} | ||||
| 
 | ||||
| 		if err := json.Unmarshal(bcjBytes, bcj); err != nil { | ||||
| 			// message is not conformant, we are in validating phase
 | ||||
| 			panic(err) | ||||
| 		} | ||||
| 	bcjBytes, err := io.ReadAll(bcjRes.Body) | ||||
| 	if err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 
 | ||||
| 	contributeWithSecrets(batch, batchSize, secret) | ||||
| 	if err := json.Unmarshal(bcjBytes, bcj); err != nil { | ||||
| 		// message is not conformant, we are in validating phase
 | ||||
| 		panic(err) | ||||
| 	} | ||||
| 
 | ||||
| 	fmt.Printf("Participating... %f%% Complete\n", float32(batch*batchSize)/655.36) | ||||
| 	contributeWithSecrets(secret) | ||||
| } | ||||
| 
 | ||||
| func contributeWithSecrets(batch uint, batchSize uint, secret *bls48581.BIG) error { | ||||
| 	updatePowersOfTau(batch, batchSize, secret) | ||||
| 
 | ||||
| 	if batch == 0 { | ||||
| 		updateWitness(secret) | ||||
| 	} | ||||
| func contributeWithSecrets(secret *bls48581.BIG) error { | ||||
| 	updatePowersOfTau(secret) | ||||
| 	updateWitness(secret) | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| var xi *bls48581.BIG | ||||
| var xi2 *bls48581.BIG | ||||
| var xi []*bls48581.BIG | ||||
| 
 | ||||
| func updatePowersOfTau(batch uint, batchSize uint, secret *bls48581.BIG) { | ||||
| 	if batch == 0 { | ||||
| 		xi = bls48581.NewBIGint(1) | ||||
| 		xi2 = bls48581.NewBIGint(1) | ||||
| func updatePowersOfTau(secret *bls48581.BIG) { | ||||
| 	xi = append(xi, bls48581.NewBIGint(1)) | ||||
| 
 | ||||
| 	for i := 0; i < 65536; i++ { | ||||
| 		xi = append(xi, bls48581.Modmul(xi[i], secret, bls48581.NewBIGints(bls48581.CURVE_Order))) | ||||
| 	} | ||||
| 
 | ||||
| 	for i := batchSize * batch; i < batchSize*(batch+1); i++ { | ||||
| 		g1PowersString := strings.TrimPrefix(bcj.PowersOfTau.G1Affines[i], "0x") | ||||
| 		g1PowersHex, _ := hex.DecodeString(g1PowersString) | ||||
| 		g1Power := bls48581.ECP_fromBytes(g1PowersHex) | ||||
| 	wg := sync.WaitGroup{} | ||||
| 	wg.Add(65536) | ||||
| 
 | ||||
| 		if g1Power.Equals(bls48581.NewECP()) { | ||||
| 			panic("invalid g1Power") | ||||
| 		} | ||||
| 	for i := 0; i < 65536; i++ { | ||||
| 		i := i | ||||
| 		go func() { | ||||
| 			g1PowersString := strings.TrimPrefix(bcj.PowersOfTau.G1Affines[i], "0x") | ||||
| 			g1PowersHex, _ := hex.DecodeString(g1PowersString) | ||||
| 			g1Power := bls48581.ECP_fromBytes(g1PowersHex) | ||||
| 
 | ||||
| 		g1Power = g1Power.Mul(xi) | ||||
| 		g1Power.ToBytes(g1PowersHex, true) | ||||
| 		bcj.PowersOfTau.G1Affines[i] = "0x" + hex.EncodeToString(g1PowersHex) | ||||
| 
 | ||||
| 		if (i%batchSize == 0) && i < uint(257*batchSize) { | ||||
| 			g2PowersString := strings.TrimPrefix(bcj.PowersOfTau.G2Affines[i/batchSize], "0x") | ||||
| 			g2PowersHex, _ := hex.DecodeString(g2PowersString) | ||||
| 			g2Power := bls48581.ECP8_fromBytes(g2PowersHex) | ||||
| 
 | ||||
| 			if g2Power.Equals(bls48581.NewECP8()) { | ||||
| 			if g1Power.Equals(bls48581.NewECP()) { | ||||
| 				panic("invalid g1Power") | ||||
| 			} | ||||
| 
 | ||||
| 			g2Power = g2Power.Mul(xi2) | ||||
| 			g2Power.ToBytes(g2PowersHex, true) | ||||
| 			bcj.PowersOfTau.G2Affines[i/batchSize] = "0x" + hex.EncodeToString(g2PowersHex) | ||||
| 			xi2 = bls48581.Modmul(xi2, secret, bls48581.NewBIGints(bls48581.Modulus)) | ||||
| 		} | ||||
| 		xi = bls48581.Modmul(xi, secret, bls48581.NewBIGints(bls48581.Modulus)) | ||||
| 			g1Power = g1Power.Mul(xi[i]) | ||||
| 			g1Power.ToBytes(g1PowersHex, true) | ||||
| 			bcj.PowersOfTau.G1Affines[i] = "0x" + hex.EncodeToString(g1PowersHex) | ||||
| 
 | ||||
| 			if i < 257 { | ||||
| 				g2PowersString := strings.TrimPrefix(bcj.PowersOfTau.G2Affines[i], "0x") | ||||
| 				g2PowersHex, _ := hex.DecodeString(g2PowersString) | ||||
| 				g2Power := bls48581.ECP8_fromBytes(g2PowersHex) | ||||
| 
 | ||||
| 				if g2Power.Equals(bls48581.NewECP8()) { | ||||
| 					panic("invalid g2Power") | ||||
| 				} | ||||
| 
 | ||||
| 				g2Power = g2Power.Mul(xi[i]) | ||||
| 				g2Power.ToBytes(g2PowersHex, true) | ||||
| 				bcj.PowersOfTau.G2Affines[i] = "0x" + hex.EncodeToString(g2PowersHex) | ||||
| 			} | ||||
| 			wg.Done() | ||||
| 		}() | ||||
| 	} | ||||
| 
 | ||||
| 	wg.Wait() | ||||
| } | ||||
| 
 | ||||
| func updateWitness(secret *bls48581.BIG) { | ||||
| 	g2PowersString := strings.TrimPrefix(bcj.PotPubKey, "0x") | ||||
| 	g2PowersHex, _ := hex.DecodeString(g2PowersString) | ||||
| 	g2Power := bls48581.ECP8_fromBytes(g2PowersHex) | ||||
| 	x := bls48581.Modmul(bls48581.NewBIGint(1), secret, bls48581.NewBIGints(bls48581.CURVE_Order)) | ||||
| 
 | ||||
| 	if g2Power.Equals(bls48581.NewECP8()) { | ||||
| 		panic("invalid g2Power") | ||||
| 	} | ||||
| 
 | ||||
| 	newPotPubKey := g2Power.Mul(secret) | ||||
| 	newPotPubKey.ToBytes(g2PowersHex, true) | ||||
| 	g2Power = g2Power.Mul(x) | ||||
| 	g2Power.ToBytes(g2PowersHex, true) | ||||
| 	bcj.PotPubKey = "0x" + hex.EncodeToString(g2PowersHex) | ||||
| 	bcj.VoucherPubKey = "0x" + hex.EncodeToString(voucherPubKey) | ||||
| } | ||||
|  | ||||
							
								
								
									
										10
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								main.go
									
									
									
									
									
								
							| @ -15,16 +15,12 @@ func main() { | ||||
| 	state := GetSequencerState() | ||||
| 	for state != SEQUENCER_ACCEPTING { | ||||
| 		fmt.Println("Sequencer currently not accepting new contributions, waiting...") | ||||
| 		time.Sleep(30 * time.Second) | ||||
| 		time.Sleep(1 * time.Second) | ||||
| 		state = GetSequencerState() | ||||
| 	} | ||||
| 
 | ||||
| 	JoinLobby() | ||||
| 	batchSize := uint(32) | ||||
| 	for batch := uint(0); batch < 65536/batchSize; batch++ { | ||||
| 		Bootstrap(batch, batchSize) | ||||
| 		fmt.Printf("batch: %d\n", batch) | ||||
| 	} | ||||
| 	Bootstrap() | ||||
| 	fmt.Println("New Pubkey: ") | ||||
| 	fmt.Println(bcj.PotPubKey) | ||||
| 	ContributeAndGetVoucher() | ||||
| @ -67,5 +63,5 @@ func PrintLogo() { | ||||
| 
 | ||||
| func PrintVersion() { | ||||
| 	fmt.Println(" ") | ||||
| 	fmt.Println("                    Quilibrium Ceremony Client - CLI - v1.0.0") | ||||
| 	fmt.Println("                    Quilibrium Ceremony Client - CLI - v1.0.1") | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Cassandra Heart
						Cassandra Heart