2023-12-14 22:00:10 +00:00
|
|
|
package SlotMashine
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/contract"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/runtime"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/storage"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
zaCoinHashKey = "zaCoinHash"
|
|
|
|
)
|
|
|
|
|
|
|
|
func _deploy(data interface{}, isUpdate bool) {
|
|
|
|
if isUpdate {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
args := data.(struct {
|
|
|
|
zaCoinHash interop.Hash160
|
|
|
|
})
|
|
|
|
|
|
|
|
if len(args.zaCoinHash) != interop.Hash160Len {
|
2024-01-07 13:58:37 +00:00
|
|
|
panic("Invalid hash of zaCoin contract")
|
2023-12-14 22:00:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ctx := storage.GetContext()
|
|
|
|
storage.Put(ctx, zaCoinHashKey, args.zaCoinHash)
|
|
|
|
}
|
|
|
|
|
|
|
|
func RollSlot(bet int) {
|
|
|
|
ctx := storage.GetContext()
|
|
|
|
playerOwner := runtime.GetScriptContainer().Sender
|
2024-01-16 13:59:15 +00:00
|
|
|
playerContract := runtime.GetExecutingScriptHash()
|
2024-01-03 12:29:52 +00:00
|
|
|
|
|
|
|
if bet <= 0 {
|
|
|
|
panic("Invalid bet amount")
|
|
|
|
}
|
|
|
|
zaCoinHash := storage.Get(ctx, zaCoinHashKey).(interop.Hash160)
|
|
|
|
playerBalance := contract.Call(zaCoinHash, "balanceOf", contract.ReadStates, playerOwner).(int)
|
|
|
|
|
|
|
|
if playerBalance < bet {
|
|
|
|
panic("Insufficient funds")
|
|
|
|
}
|
|
|
|
|
2023-12-16 17:26:51 +00:00
|
|
|
res := roll()
|
2023-12-14 22:00:10 +00:00
|
|
|
if (res == 0){
|
2024-01-16 17:45:30 +00:00
|
|
|
changePlayerBalance(playerOwner, playerContract, bet)
|
2024-01-16 13:59:15 +00:00
|
|
|
runtime.Notify("gameResult", int(0))
|
2023-12-14 22:00:10 +00:00
|
|
|
} else {
|
|
|
|
win := res * bet
|
2024-01-16 17:45:30 +00:00
|
|
|
changePlayerBalance(playerContract, playerOwner, win)
|
2024-01-16 13:59:15 +00:00
|
|
|
runtime.Notify("gameResult", int(1))
|
2023-12-14 22:00:10 +00:00
|
|
|
}
|
2024-01-07 13:58:37 +00:00
|
|
|
playerBalance = contract.Call(zaCoinHash, "balanceOf", contract.ReadStates, playerOwner).(int)
|
|
|
|
runtime.Notify("playerBalance", playerBalance)
|
2023-12-14 22:00:10 +00:00
|
|
|
}
|
|
|
|
|
2023-12-16 17:26:51 +00:00
|
|
|
func roll() int {
|
2024-01-09 11:11:13 +00:00
|
|
|
var result []int
|
2024-01-07 13:58:37 +00:00
|
|
|
for i:=0; i<3; i++ {
|
|
|
|
wheel := (runtime.GetRandom() % 8) + 1
|
2024-01-09 11:11:13 +00:00
|
|
|
result = append(result, wheel)
|
2024-01-07 13:58:37 +00:00
|
|
|
runtime.Log("WheelNumber=" + string(i + 1) +", value="+string(wheel))
|
|
|
|
}
|
|
|
|
runtime.Notify("SlotResult", result)
|
2023-12-16 17:26:51 +00:00
|
|
|
|
2023-12-14 22:00:10 +00:00
|
|
|
|
2024-01-07 13:58:37 +00:00
|
|
|
if (result[0] == result[1] && result[0] == result[2]){
|
|
|
|
return result[0]
|
2023-12-14 22:00:10 +00:00
|
|
|
} else {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func OnNEP17Payment(from interop.Hash160, amount int, data any) {
|
|
|
|
ctx := storage.GetContext()
|
|
|
|
zaCoinHash := storage.Get(ctx, zaCoinHashKey).(interop.Hash160)
|
|
|
|
|
|
|
|
callingHash := runtime.GetCallingScriptHash()
|
|
|
|
if !callingHash.Equals(zaCoinHash) {
|
2024-01-07 13:58:37 +00:00
|
|
|
panic("Only ZC is accepted")
|
2023-12-14 22:00:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-16 17:45:30 +00:00
|
|
|
func changePlayerBalance(sender interop.Hash160, recipient interop.Hash160, balanceChange int) {
|
|
|
|
ctx := storage.GetContext()
|
|
|
|
zaCoinHash := storage.Get(ctx, zaCoinHashKey).(interop.Hash160)
|
2023-12-14 22:00:10 +00:00
|
|
|
|
2024-01-16 13:59:15 +00:00
|
|
|
transferred := contract.Call(zaCoinHash, "transfer", contract.All, sender, recipient, balanceChange, nil).(bool)
|
|
|
|
if !transferred {
|
|
|
|
panic("failed to transfer zaCoins")
|
|
|
|
}
|
2023-12-14 22:00:10 +00:00
|
|
|
}
|