The createViewPermissionsToken() GraphQL
mutation field will create a view permission token to use with
LogScale. The permissions will take effect across all of the views.
For more information on access tokens of various types, see the
Ingest Tokens documentation page. For
information on user authorization, see the
Manage users & permissions documentation page. You may
also want to look at the Creating a Repository or View page
for related information.
Below is the syntax for the
createViewPermissionsToken() mutation
field:
createViewPermissionsToken(
input : CreateViewPermissionsTokenInput!
) : string!
Below is an example of how this mutation field might be used:
Show:
Raw Mac OS or Linux (curl) Mac OS or Linux (curl) One-line Windows Cmd and curl Windows Powershell and curl Perl Python Node.js
Raw mutation {
createViewPermissionsToken( input :
{ name : "reader-token" ,
expireAt : null ,
viewIds : [ "aK9GKAsTnMXfRxT8Fpecx3fX" ,
"N7t1bAn6xWMsWjVptueeNR16" ] ,
permissions : [ ReadAccess ]
} )
}
Mac OS or Linux (curl) curl -v -X POST $YOUR_LOGSCALE_URL/graphql \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d @- << EOF
{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}
EOF
Mac OS or Linux (curl) One-line curl -v -X POST $YOUR_LOGSCALE_URL/graphql \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d @- << EOF
{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}
EOF
Windows Cmd and curl curl -v -X POST $YOUR_LOGSCALE_URL/graphql ^
-H "Authorization: Bearer $TOKEN" ^
-H "Content-Type: application/json" ^
-d @'{"query" : "mutation { ^
createViewPermissionsToken(input: ^
{ name: \"reader-token\", ^
expireAt: null, ^
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\", ^
\"N7t1bAn6xWMsWjVptueeNR16\" ], ^
permissions: [ ReadAccess ] ^
} ) ^
}" ^
} '
Windows Powershell and curl curl.exe -X POST
-H "Authorization: Bearer $TOKEN "
-H "Content-Type: application/json"
-d '{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}'
"$YOUR_LOGSCALE_URL /graphql"
Perl
use HTTP::Request;
use LWP;
my $INGEST_TOKEN = "TOKEN" ;
my $uri = '$YOUR_LOGSCALE_URL/graphql' ;
my $json = '{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}' ;
my $req = HTTP::Request->new("POST" , $uri );
$req->header("Authorization" => "Bearer $TOKEN" );
$req->header("Content-Type" => "application/json" );
$req->content( $json );
my $lwp = LWP::UserAgent->new;
my $result = $lwp->request( $req );
print $result->{"_content" },"\n" ;
Python
import requests
url = '$YOUR_LOGSCALE_URL/graphql'
mydata = r'''{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}'''
resp = requests.post(url,
data = mydata,
headers = {
"Authorization" : "Bearer $TOKEN" ,
"Content-Type" : "application/json"
}
)
print (resp.text)
Node.js const https = require ('https' );
const data = JSON .stringify (
{"query" : "mutation {
createViewPermissionsToken(input:
{ name: \"reader-token\",
expireAt: null,
viewIds: [ \"aK9GKAsTnMXfRxT8Fpecx3fX\",
\"N7t1bAn6xWMsWjVptueeNR16\" ],
permissions: [ ReadAccess ]
} )
}"
}
);
const options = {
hostname : '$YOUR_LOGSCALE_URL/graphql' ,
path : '/graphql' ,
port : 443 ,
method : 'POST' ,
headers : {
'Content-Type' : 'application/json' ,
'Content-Length' : data.length ,
Authorization : 'BEARER ' + process.env .TOKEN ,
'User-Agent' : 'Node' ,
},
};
const req = https.request (options, (res ) => {
let data = '' ;
console .log (`statusCode: ${res.statusCode} ` );
res.on ('data' , (d ) => {
data += d;
});
res.on ('end' , () => {
console .log (JSON .parse (data).data );
});
});
req.on ('error' , (error ) => {
console .error (error);
});
req.write (data);
req.end ();
Example Responses Show:
Success (HTTP Response Code 200 OK)
Success (HTTP Response Code 200 OK) {
"data" : {
"createViewPermissionsToken" : "ciQrkii7NJtUmtr6N8JQRoLCyuE4nKdT~06PKerqjTkLt6cITyDEvIHnYk82BgOOkof6NrMQMkFOX"
}
}
CreateViewPermissionsTokenInput
has a few parameters that may be given. Below is a list of them
along with descriptions of each: