ducky/devices
18:b2fdf827758e
Go to Latest
ducky/devices/apiv1/scopes.go
Add endpoint for retrieving devices.
Add an endpoint for retrieving devices, either as a list or by ID.
Stub endpoints for updating and deleting devices., along with TODOs marking them
as things to still be completed. (Right now, accessing those endpoints is an
insta-panic.)
Simplify our handleCreateDevices by returning StatusUnauthorized if AuthUser
fails, so we can reserve StatusForbidden for when auth succeeds but access is
still denied. Also, delay the instantiation and allocation of a Response
variable until we're actually going to use it.
Create a handleGetDevices handler that authenticates the user, and if no ID is
set, returns a list of all their Devices. If one or more IDs are set, only those
Devices are returned. If ScopeViewPushToken is one of the scopes associated with
the request, the push tokens for each Device will be included in the response.
Otherwise, they will be omitted.
3 import "code.secondbit.org/scopes.hg/types"
6 // ScopeViewPushToken is a Scope that grants access to viewing pushTokens for
8 ScopeViewPushToken = scopeTypes.Scope{
9 ID: "https://scopes.useducky.com/devices/pushToken/view",
10 Name: "View device push tokens.",
11 Description: "View the push tokens that allow sending messages and notifications to your device. This can be used to force your device to open links, and should be granted with extreme caution.",
14 // ScopeViewDevices is a Scope that grants access to viewing the Devices
15 // that belong to a user.
16 ScopeViewDevices = scopeTypes.Scope{
17 ID: "https://scopes.useducky.com/devices/view",
18 Name: "View devices.",
19 Description: "View the devices that are associated with your account.",
22 // ScopeImport is a Scope that grants access to bulk importing Devices. It grants
23 // what equates to admin permissions, including the ability to create Devices for
24 // other users, and thus should be granted with extreme caution.
25 ScopeImport = scopeTypes.Scope{
26 ID: "https://scopes.useducky.com/devices/import",
27 Name: "Import devices.",
28 Description: "Import devices into the system, including creating devices for other users. This should only ever be granted to system resources.",
31 // ScopeCreateOtherUserDevices is a Scope that grants the user the ability to create
32 // Devices with an Owner property that doesn't match the authenticated user's ID.
33 ScopeCreateOtherUserDevices = scopeTypes.Scope{
34 ID: "https://scopes.useducky.com/devices/otherUser/create",
35 Name: "Create devices for other users.",
36 Description: "Create devices like usual, but make a different user the owner of the device.",