permission

package
v3.3.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 11, 2023 License: Apache-2.0 Imports: 8 Imported by: 0

Documentation

Overview

Permission constants and helper functions for defining routes. These should match the permissions defined in Auth0 JWT tokens that come in with requests

Index

Constants

View Source
const PermBlessQuantification = "write:bless-quant"

Quantification "blessing" - marking it as the correct one to use

View Source
const PermCreateQuantification = "write:quantification"

Quantification creation

View Source
const PermDownloadPiquant = "download:piquant"

Downloading PIQUANT builds - not fully finished, likely only serving linux binaries if our build system still creates them

View Source
const PermEditDiffractionPeaks = "write:diffraction-peaks"

Editing diffraction peaks (manually creating new ones, or marking detected ones as deleted)

View Source
const PermExportMap = "export:map"

Ability to export various data

View Source
const PermPublic = "public"

Public endpoints, mainly for getting the API version

View Source
const PermPublishQuantification = "write:publish-quant"

Quantification publishing - to PDS

View Source
const PermReadDataAnalysis = "read:data-analysis"

Reading ROI, element set, annotation, expressions, modules, tags, quantifications, RGB mixes

View Source
const PermReadDiffractionPeaks = "read:diffraction-peaks"

Reading diffraction peaks DB that's created along with a dataset

View Source
const PermReadLogs = "read:logs"

Reading logs and log level of API

View Source
const PermReadPIXLISESettings = "read:pixlise-settings"

Reading current view state, collections, workspaces

View Source
const PermReadPiquantConfig = "read:piquant-config"

Reading piquant detector config and piquant config files

View Source
const PermReadPiquantJobs = "read:piquant-jobs"

Reads all piquant jobs - admin level

View Source
const PermReadUserRoles = "read:user-roles"

User role access - reading user listing, role listing and user/role individual gets

View Source
const PermReadUserSettings = "read:user-settings"

Get users own config and data collection agreement

View Source
const PermTestEndpoints = "write:test-endpoints"

Ability to call test endpoints (admin feature)

View Source
const PermWriteDataAnalysis = "write:data-analysis"

Write/delete/edit ROI, element set, annotation, expressions, modules, tags, quantifications, RGB mixes

View Source
const PermWriteDataset = "write:dataset"

Allows editing custom fields/images on dataset, or creating new ones (using zipped MSA files, etc)

View Source
const PermWriteLogLevel = "write:log-level"

Changing API log level (admin feature really!)

View Source
const PermWriteMetrics = "write:metrics"

For saving metrics - aka user tracking info, UI behaviours, for research purposes

View Source
const PermWritePIXLISESettings = "write:pixlise-settings"

Writing current view state, collections, workspaces

View Source
const PermWritePiquantConfig = "write:piquant-config"

Writing piquant config (for spectroscopists who know what they're doing with piquant)

View Source
const PermWriteSharedAnnotation = "write:shared-annotation"

Sharing annotations (of spectrum chart)

View Source
const PermWriteSharedElementSet = "write:shared-element-set"

Sharing element sets

View Source
const PermWriteSharedExpression = "write:shared-expression"

Sharing expressions

View Source
const PermWriteSharedQuantification = "write:shared-quantification"

Sharing quantifications

View Source
const PermWriteSharedROI = "write:shared-roi"

Sharing ROI

View Source
const PermWriteUserRoles = "write:user-roles"

Writing/deleting user roles, and editing users in bulk

View Source
const PermWriteUserSettings = "write:user-settings"

Writing users own config and data collection agreement

Variables

This section is empty.

Functions

func GetAccessibleGroups

func GetAccessibleGroups(permissions map[string]bool) map[string]bool

Get all groups that are accessible by the list of permissions provided. This means basically returning what's after access: in each permission

func UserCanAccessDataset

func UserCanAccessDataset(userInfo pixlUser.UserInfo, summary datasetModel.SummaryFileData) error

Returns nil if user CAN access it, otherwise a api.StatusError with the right HTTP error code

func UserCanAccessDatasetWithSummaryDownload

func UserCanAccessDatasetWithSummaryDownload(fs fileaccess.FileAccess, userInfo pixlUser.UserInfo, dataBucket string, datasetID string) (datasetModel.SummaryFileData, error)

Checking if the user can access a given dataset - use this if you don't already have summary info downloaded

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL