~williewillus/public-inbox

r16: Admin check fix, object-based edition v2 PROPOSED

: 1
 Admin check fix, object-based edition

 1 files changed, 39 insertions(+), 6 deletions(-)
#738862 linux_buildtest.yml success
Export patchset (mbox)
How do I use this?

Copy & paste the following snippet into your terminal to import this patchset into git:

curl -s https://lists.sr.ht/~williewillus/public-inbox/patches/31236/mbox | git am -3
Learn more about email & git

[PATCH r16 v2] Admin check fix, object-based edition Export this patch

From: Alwinfy <20421383+Alwinfy@users.noreply.github.com>

---
 frontends/discord.rkt | 45 +++++++++++++++++++++++++++++++++++++------
 1 file changed, 39 insertions(+), 6 deletions(-)

diff --git a/frontends/discord.rkt b/frontends/discord.rkt
index fb2fefe..f3649c9 100644
--- a/frontends/discord.rkt
+++ b/frontends/discord.rkt
@@ -51,6 +51,33 @@
      (thread-send worker-thread (vector chan args ...))
      (async-channel-get chan))))

(define guild-perms-manager%
  (class object% 
    (super-new)

    (init _client guild)

    (define-values (_default-role _roles)
      (for/fold ([default-perms 0] [role-perms null]) ([role (hash-ref guild 'roles)])
        (define perms (string->number (hash-ref role 'permissions)))
        (if (string=? (hash-ref role 'name) "@everyone")
          (values perms role-perms)
          (values default-perms (cons (cons (hash-ref role 'id) perms) role-perms)))))

    (field
      [owner-id (hash-ref guild 'owner_id)]
      [roles (make-hash _roles)]
      [default-role _default-role])

    (define/public (check-perms message)
      (if (string=? owner-id (message-author-id message))
        -1
        (and~>> message
                (hash-ref _ 'member)
                (hash-ref _ 'roles)
                (map (lambda (r) (hash-ref roles r 0)))
                (foldl bitwise-ior default-role))))))

(define discord-frontend%
  (class* object% [r16-frontend<%>]
    (init-field client)
@@ -140,12 +167,9 @@
                                 rc:permission-manage-guild))
      (or
       (equal? (trick-author trick-obj) author-id)
       (and~> (current-message)
              (hash-ref _ 'member)
              (hash-ref _ 'permissions)
              string->number
              (bitwise-and perms)
              ((negate zero?)))))
       (not (zero? (bitwise-and
                     perms
                     (get-perms-for (current-message)))))))

    ;; context/guild id -> (emote name -> emote id)
    (define emote-name-lookup (make-hash))
@@ -300,10 +324,19 @@
      (log-r16-debug "Know of ~a emotes" (set-count new))
      (set-box! known-emotes new))

    (define guild-perms-managers (make-hash))

    (define (get-perms-for message)
      (define manager (hash-ref guild-perms-managers (hash-ref message 'guild_id)))
      (send manager check-perms message))

    (define (guild-create _ws-client _client guild)
      (hash-set! emote-name-lookup
                 (hash-ref guild 'id)
                 (extract-emojis guild))
      (hash-set! guild-perms-managers
                 (hash-ref guild 'id)
                 (make-object guild-perms-manager% _client guild))
      (recompute-known-emotes))

    (define (guild-delete _ws-client _client guild)
-- 
2.25.1
r16/patches/linux_buildtest.yml: SUCCESS in 1m50s

[Admin check fix, object-based edition][0] v2 from [][1]

[0]: https://lists.sr.ht/~williewillus/public-inbox/patches/31236
[1]: mailto:wenming.yi@gmail.com

✓ #738862 SUCCESS r16/patches/linux_buildtest.yml https://builds.sr.ht/~williewillus/job/738862