aboutsummaryrefslogtreecommitdiffstats
path: root/jdisc-security-filters/src/main/java/com/yahoo/jdisc/http/filter/security/cloud/ClientPrincipal.java
blob: bfb9bb920db947e70b3614cc7963d0e72567529f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.

package com.yahoo.jdisc.http.filter.security.cloud;

import com.yahoo.jdisc.http.filter.DiscFilterRequest;

import java.security.Principal;
import java.util.Set;
import java.util.logging.Logger;

/**
 * @author bjorncs
 */
record ClientPrincipal(Set<String> ids, Set<Permission> permissions) implements Principal {

    private static final Logger log = Logger.getLogger(ClientPrincipal.class.getName());

    ClientPrincipal { ids = Set.copyOf(ids); permissions = Set.copyOf(permissions); }
    @Override public String getName() {
        return "ids=%s,permissions=%s".formatted(ids, permissions.stream().map(Permission::asString).toList());
    }

    static void attachToRequest(DiscFilterRequest req, Set<String> ids, Set<Permission> permissions) {
        var p = new ClientPrincipal(ids, permissions);
        req.setUserPrincipal(p);
        log.fine(() -> "Client with ids=%s, permissions=%s"
                .formatted(ids, permissions.stream().map(Permission::asString).toList()));
    }
}