stacksbridge-satoshibles-v3

SP6P4EJF0VG8V0RB3TQQKJBHDQKEF6NVRD1KZE3C

Source Code

;; StacksBridge - Satoshibles v3
(use-trait nft-trait .nft-trait.nft-trait)
(use-trait ft-trait .ft-trait.ft-trait)

;; Define Constants
(define-constant CONTRACT-DEPLOYER tx-sender)
(define-constant ERR-INVALID-ID (err u400))
(define-constant ERR-NOT-AUTHORIZED (err u401))
(define-constant ERR-NOT-FOUND (err u404))
(define-constant ERR-BRIDGE-CLOSED (err u503))

(define-data-var contract-owner principal tx-sender)
(define-data-var contract-worker principal tx-sender)
(define-data-var bridge-closed bool false)
(define-data-var escrow-fee uint u20000000)

(define-public (lock (id uint) (address (string-ascii 42)))
    (let (
        (nft-owner (unwrap-panic (unwrap! (contract-call? .satoshibles get-owner id) ERR-NOT-FOUND)))
        (free-pass (not (contract-call? .bridge-pass bridge-pass-is-used id)))
        )
        (asserts! (not (var-get bridge-closed)) ERR-BRIDGE-CLOSED)
        (asserts! (is-eq tx-sender nft-owner) ERR-NOT-AUTHORIZED)       
        (if (is-eq free-pass true) 
          (begin 
            (try! (contract-call? .bridge-pass bridge-pass-set-used id))
            (print {action: "bridge-pass"})
          ) 
          (begin 
            (try! (stx-transfer? (var-get escrow-fee) tx-sender (as-contract tx-sender)))
            (print {action: "no-bridge-pass"})
          )
        )
        (try! (contract-call? .satoshibles transfer id tx-sender (as-contract tx-sender)))
        (print {a: "lock", id: id, address: address})
        (ok true)
    )
)

(define-public (release (id uint) (address principal))
    (begin
        (asserts! (not (var-get bridge-closed)) ERR-BRIDGE-CLOSED)
        (asserts! (is-eq tx-sender (var-get contract-worker)) ERR-NOT-AUTHORIZED)
        (try! (as-contract (contract-call? .satoshibles transfer id tx-sender address)))
        (print {a: "release", id: id, address: address})
        (ok true)
    )
)

;; Lock Many
(define-public (lock-many (nfts-to-lock (list 50 { id: uint, address: (string-ascii 42) })))
  (fold check-err
    (map receive-token nfts-to-lock)
    (ok true)
  )
)
(define-private (check-err (result (response bool uint)) (prior (response bool uint)))
  (match prior ok-value result
               err-value (err err-value)
  )
)
(define-private (receive-token (nft-to-lock { id: uint, address: (string-ascii 42) }))
  (lock-token (get id nft-to-lock) (get address nft-to-lock))
)
(define-private (lock-token (id uint) (address (string-ascii 42)))
  (let
    (
      (lockOk (try! (lock id address)))
    )
    (ok lockOk)
  )
)

;; Release Many
(define-public (release-many (nfts-to-release (list 50 { id: uint, address: principal })))
  (fold check-err
    (map send-token nfts-to-release)
    (ok true)
  )
)
(define-private (send-token (nft-to-release { id: uint, address: principal }))
  (release-token (get id nft-to-release) (get address nft-to-release))
)
(define-private (release-token (id uint) (address principal))
  (let
    (
      (releaseOk (try! (release id address)))
    )
    (ok releaseOk)
  )
)

;; Bridge Maintenance
(define-public (set-bridge-closed (state bool))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (var-set bridge-closed state)
    (ok true)))

;; Safety Functions
(define-public (transfer-stx (address principal) (amount uint))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (unwrap-panic (as-contract (stx-transfer? amount (as-contract tx-sender) address)))
    (ok true))
)

(define-public (transfer-ft-token (address principal) (amount uint) (token <ft-trait>))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (try! (as-contract (contract-call? token transfer amount tx-sender address none)))
    (ok true))
)

(define-public (transfer-nft-token (address principal) (id uint) (token <nft-trait>))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (try! (as-contract (contract-call? token transfer id tx-sender address)))
    (ok true))
)

(define-public (set-owner (new-owner principal))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (var-set contract-owner new-owner)
    (ok true))
)

(define-public (set-worker (new-worker principal))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (var-set contract-worker new-worker)
    (ok true))
)

(define-read-only (get-escrow-fee)
  (ok (var-get escrow-fee))
)

(define-public (set-escrow-fee (fee uint))
  (begin
    (asserts! (is-eq tx-sender (var-get contract-owner)) ERR-NOT-AUTHORIZED)
    (var-set escrow-fee fee)
    (ok true)))

Functions (15)

FunctionAccessArgs
lockpublicid: uint, address: (string-ascii 42
releasepublicid: uint, address: principal
check-errprivateresult: (response bool uint
lock-tokenprivateid: uint, address: (string-ascii 42
release-manypublicnfts-to-release: (list 50 { id: uint, address: principal }
send-tokenprivatenft-to-release: { id: uint, address: principal }
release-tokenprivateid: uint, address: principal
set-bridge-closedpublicstate: bool
transfer-stxpublicaddress: principal, amount: uint
transfer-ft-tokenpublicaddress: principal, amount: uint, token: <ft-trait>
transfer-nft-tokenpublicaddress: principal, id: uint, token: <nft-trait>
set-ownerpublicnew-owner: principal
set-workerpublicnew-worker: principal
get-escrow-feeread-only
set-escrow-feepublicfee: uint