Python ADAL acquire_token_with_client_credentials refresh token? The Next CEO of Stack OverflowCalling an external command in PythonWhat are metaclasses in Python?Is there a way to run Python on Android?Finding the index of an item given a list containing it in PythonDifference between append vs. extend list methods in PythonHow can I safely create a nested directory in Python?Does Python have a ternary conditional operator?How to get the current time in PythonHow can I make a time delay in Python?Does Python have a string 'contains' substring method?
Physiological effects of huge anime eyes
What flight has the highest ratio of timezone difference to flight time?
Is there an equivalent of cd - for cp or mv
Which one is the true statement?
Are the names of these months realistic?
Decide between Polyglossia and Babel for LuaLaTeX in 2019
Easy to read palindrome checker
Spaces in which all closed sets are regular closed
New carbon wheel brake pads after use on aluminum wheel?
What CSS properties can the br tag have?
Can you teleport closer to a creature you are Frightened of?
Redefining symbol midway through a document
How to find image of a complex function with given constraints?
Defamation due to breach of confidentiality
Does Germany produce more waste than the US?
Can this note be analyzed as a non-chord tone?
How to explain the utility of binomial logistic regression when the predictors are purely categorical
Computationally populating tables with probability data
Reshaping json / reparing json inside shell script (remove trailing comma)
Expressing the idea of having a very busy time
From jafe to El-Guest
Is there such a thing as a proper verb, like a proper noun?
Can I use the word “Senior” as part of a job title directly in German?
Is dried pee considered dirt?
Python ADAL acquire_token_with_client_credentials refresh token?
The Next CEO of Stack OverflowCalling an external command in PythonWhat are metaclasses in Python?Is there a way to run Python on Android?Finding the index of an item given a list containing it in PythonDifference between append vs. extend list methods in PythonHow can I safely create a nested directory in Python?Does Python have a ternary conditional operator?How to get the current time in PythonHow can I make a time delay in Python?Does Python have a string 'contains' substring method?
Is there a reason why the Python ADAL library's authentication method acquire_token_with_client_credentials does not return a refresh token? I suppose Daemon apps do not need to use a refresh token each time they run but it seemed odd to me that the other authentication methods do return one.
Code sample:
class AzureActiveDirectory_Helper:
_config = Configuration()
_resource = _config.Resource
_graph_api_endpoint = _config.Graph_API_Endpoint
_authority = _config.Authority
def __init__(self):
self.Context = adal.AuthenticationContext(self._authority)
self.Token = self.Context.acquire_token_with_client_credentials(
resource=self._resource,
client_id=self._config.Client_ID,
client_secret="thisIsASuperSecretKey!!"
)
self.Headers =
'Authorization' : f'Bearer self.Token["accessToken"]',
'Accept' : 'application/json',
'Content-Type' : 'application/json'
The values in self.Token do have a accessToken value and that token does allow me to do what I need against the Azure AD app but isn't it best practice to use a refresh token instead of acquiring a fresh Token every run?
python adal
add a comment |
Is there a reason why the Python ADAL library's authentication method acquire_token_with_client_credentials does not return a refresh token? I suppose Daemon apps do not need to use a refresh token each time they run but it seemed odd to me that the other authentication methods do return one.
Code sample:
class AzureActiveDirectory_Helper:
_config = Configuration()
_resource = _config.Resource
_graph_api_endpoint = _config.Graph_API_Endpoint
_authority = _config.Authority
def __init__(self):
self.Context = adal.AuthenticationContext(self._authority)
self.Token = self.Context.acquire_token_with_client_credentials(
resource=self._resource,
client_id=self._config.Client_ID,
client_secret="thisIsASuperSecretKey!!"
)
self.Headers =
'Authorization' : f'Bearer self.Token["accessToken"]',
'Accept' : 'application/json',
'Content-Type' : 'application/json'
The values in self.Token do have a accessToken value and that token does allow me to do what I need against the Azure AD app but isn't it best practice to use a refresh token instead of acquiring a fresh Token every run?
python adal
add a comment |
Is there a reason why the Python ADAL library's authentication method acquire_token_with_client_credentials does not return a refresh token? I suppose Daemon apps do not need to use a refresh token each time they run but it seemed odd to me that the other authentication methods do return one.
Code sample:
class AzureActiveDirectory_Helper:
_config = Configuration()
_resource = _config.Resource
_graph_api_endpoint = _config.Graph_API_Endpoint
_authority = _config.Authority
def __init__(self):
self.Context = adal.AuthenticationContext(self._authority)
self.Token = self.Context.acquire_token_with_client_credentials(
resource=self._resource,
client_id=self._config.Client_ID,
client_secret="thisIsASuperSecretKey!!"
)
self.Headers =
'Authorization' : f'Bearer self.Token["accessToken"]',
'Accept' : 'application/json',
'Content-Type' : 'application/json'
The values in self.Token do have a accessToken value and that token does allow me to do what I need against the Azure AD app but isn't it best practice to use a refresh token instead of acquiring a fresh Token every run?
python adal
Is there a reason why the Python ADAL library's authentication method acquire_token_with_client_credentials does not return a refresh token? I suppose Daemon apps do not need to use a refresh token each time they run but it seemed odd to me that the other authentication methods do return one.
Code sample:
class AzureActiveDirectory_Helper:
_config = Configuration()
_resource = _config.Resource
_graph_api_endpoint = _config.Graph_API_Endpoint
_authority = _config.Authority
def __init__(self):
self.Context = adal.AuthenticationContext(self._authority)
self.Token = self.Context.acquire_token_with_client_credentials(
resource=self._resource,
client_id=self._config.Client_ID,
client_secret="thisIsASuperSecretKey!!"
)
self.Headers =
'Authorization' : f'Bearer self.Token["accessToken"]',
'Accept' : 'application/json',
'Content-Type' : 'application/json'
The values in self.Token do have a accessToken value and that token does allow me to do what I need against the Azure AD app but isn't it best practice to use a refresh token instead of acquiring a fresh Token every run?
python adal
python adal
asked Mar 8 at 17:15
general-goudageneral-gouda
82
82
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
Yes, I agree that it's a best practice to use a refresh token instead of acquiring a new fresh token every time.
The issuance of a refresh token with the client credential grant has no benefit. That is why the RFC6749 section 4.4.3 indicates A refresh token SHOULD NOT be included.
As per the document,"acquire_token_with_client_credentials" returns only access token.
So to use refresh token, python adal library supports other authentication method like:
"acquire_token", "acquire_token_with_refresh_token" etc. You can check the documentation.
Below are the documentation links:
https://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client-id--client-secret-
https://adal-python.readthedocs.io/en/latest/
add a comment |
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55067990%2fpython-adal-acquire-token-with-client-credentials-refresh-token%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
Yes, I agree that it's a best practice to use a refresh token instead of acquiring a new fresh token every time.
The issuance of a refresh token with the client credential grant has no benefit. That is why the RFC6749 section 4.4.3 indicates A refresh token SHOULD NOT be included.
As per the document,"acquire_token_with_client_credentials" returns only access token.
So to use refresh token, python adal library supports other authentication method like:
"acquire_token", "acquire_token_with_refresh_token" etc. You can check the documentation.
Below are the documentation links:
https://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client-id--client-secret-
https://adal-python.readthedocs.io/en/latest/
add a comment |
Yes, I agree that it's a best practice to use a refresh token instead of acquiring a new fresh token every time.
The issuance of a refresh token with the client credential grant has no benefit. That is why the RFC6749 section 4.4.3 indicates A refresh token SHOULD NOT be included.
As per the document,"acquire_token_with_client_credentials" returns only access token.
So to use refresh token, python adal library supports other authentication method like:
"acquire_token", "acquire_token_with_refresh_token" etc. You can check the documentation.
Below are the documentation links:
https://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client-id--client-secret-
https://adal-python.readthedocs.io/en/latest/
add a comment |
Yes, I agree that it's a best practice to use a refresh token instead of acquiring a new fresh token every time.
The issuance of a refresh token with the client credential grant has no benefit. That is why the RFC6749 section 4.4.3 indicates A refresh token SHOULD NOT be included.
As per the document,"acquire_token_with_client_credentials" returns only access token.
So to use refresh token, python adal library supports other authentication method like:
"acquire_token", "acquire_token_with_refresh_token" etc. You can check the documentation.
Below are the documentation links:
https://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client-id--client-secret-
https://adal-python.readthedocs.io/en/latest/
Yes, I agree that it's a best practice to use a refresh token instead of acquiring a new fresh token every time.
The issuance of a refresh token with the client credential grant has no benefit. That is why the RFC6749 section 4.4.3 indicates A refresh token SHOULD NOT be included.
As per the document,"acquire_token_with_client_credentials" returns only access token.
So to use refresh token, python adal library supports other authentication method like:
"acquire_token", "acquire_token_with_refresh_token" etc. You can check the documentation.
Below are the documentation links:
https://docs.microsoft.com/en-us/python/api/adal/adal.authentication_context.authenticationcontext?view=azure-python#acquire-token-with-client-credentials-resource--client-id--client-secret-
https://adal-python.readthedocs.io/en/latest/
edited Mar 11 at 7:57
answered Mar 11 at 7:30
MohitDhingra-MSFTMohitDhingra-MSFT
263
263
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55067990%2fpython-adal-acquire-token-with-client-credentials-refresh-token%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
