Source Code

;; application registry for applications  wishing to sell NFTs throug the marketplace
(define-data-var administrator principal tx-sender)
;; (define-data-var administrator principal 'ST1NXBK3K5YYMD6FD41MVNP3JS1GABZ8TRVX023PT)
;; (define-data-var administrator principal 'SP3QSAJQ4EA8WXEDSRRKMZZ29NH91VZ6C5X88FGZQ)
(define-map app-map {index: int} {owner: principal, app-contract-id: (buff 100), storage-model: int, status: int})
(define-map app-map-reverse {app-contract-id: (buff 100)} {index: int})
(define-data-var app-counter int 0)

(define-constant not-found (err u100))
(define-constant illegal-storage (err u102))
(define-constant not-allowed (err u101))

;; -- writers --
(define-public (transfer-administrator (new-administrator principal))
    (begin
        (asserts! (is-eq (var-get administrator) contract-caller) not-allowed)
        (var-set administrator new-administrator)
        (ok true)))

;; Insert new app at current index - can't have two apps with the same contract id here!
(define-public (register-app (owner principal) (app-contract-id (buff 100)) (storage-model int))
  (let
      (
          (appIndex (get index (map-get? app-map-reverse {app-contract-id: app-contract-id})))
      )
      (if (is-none appIndex)
        (begin
          (if (is-storage-allowed storage-model)
            (begin
              (map-insert app-map {index: (var-get app-counter)} {owner: owner, app-contract-id: app-contract-id, storage-model: storage-model, status: 0})
              (map-insert app-map-reverse {app-contract-id: app-contract-id} {index: (var-get app-counter)})
              (var-set app-counter (+ (var-get app-counter) 1))
              (print (var-get app-counter))
              (ok (var-get app-counter))
            )
            illegal-storage
          )
        )
        not-allowed
      )
  )
)

(define-public (update-app (index int) (owner principal) (app-contract-id (buff 100)) (storage-model int) (status int))
  (begin
      (asserts! (is-ok (is-update-allowed index)) not-allowed)
      (ok (map-set app-map {index: index} {owner: owner, app-contract-id: app-contract-id, storage-model: storage-model, status: status}))
  )
)

;; Make app live - set status to 1
(define-public (set-app-status (index int) (status int))
  (let
      (
          (owner (unwrap! (get owner (map-get? app-map {index: index})) not-allowed))
          (app-contract-id (unwrap! (get app-contract-id (map-get? app-map {index: index})) not-allowed))
          (storage-model (unwrap! (get storage-model (map-get? app-map {index: index})) not-allowed))
      )
      (asserts! (is-ok (is-update-allowed index)) not-allowed)
      (ok (map-set app-map {index: index} {owner: owner, app-contract-id: app-contract-id, storage-model: storage-model, status: status}))
  )
)

;; -- read only --
;; Get app by index
(define-read-only (get-app (index int))
    (match (map-get? app-map {index: index})
        myProject (ok myProject) not-found
    )
)
(define-read-only (get-app-index (app-contract-id (buff 100)))
    (let
        (
            (index (unwrap! (get index (map-get? app-map-reverse {app-contract-id: app-contract-id})) not-found))
        )
        (ok index)
    )
)

(define-read-only (get-app-counter)
    (ok (var-get app-counter))
)
;; Get current administrator
(define-read-only (get-administrator)
    (ok (var-get administrator))
)
(define-read-only (get-contract-data)
    (let
        (
            (the-app-counter    (var-get app-counter))
            (the-administrator  (var-get administrator))
        )
        (ok (tuple 
                (appCounter the-app-counter)
                (administrator the-administrator)
            )
        )
    )
)

;; -- private --
(define-private (is-update-allowed (index int))
    (let
        (
          (owner (unwrap! (get owner (map-get? app-map {index: index})) not-allowed))
        )
        (if (or (is-eq (var-get administrator) contract-caller) (is-eq owner contract-caller)) 
          (ok true)
          not-allowed
        )
    )
)

(define-private (is-storage-allowed (storage int))
  (<= storage 10)
)

Functions (11)

FunctionAccessArgs
transfer-administratorpublicnew-administrator: principal
register-apppublicowner: principal, app-contract-id: (buff 100
update-apppublicindex: int, owner: principal, app-contract-id: (buff 100
set-app-statuspublicindex: int, status: int
get-appread-onlyindex: int
get-app-indexread-onlyapp-contract-id: (buff 100
get-app-counterread-only
get-administratorread-only
get-contract-dataread-only
is-update-allowedprivateindex: int
is-storage-allowedprivatestorage: int