Application Registration
To register your application, go to the Application Registration Portal (https://apps.dev.microsoft.com/). Elect to sign in with your company credentials.
data:image/s3,"s3://crabby-images/ac2b4/ac2b44c4fde30db58a430ef3662f855a5177420e" alt=""
You will be redirected to the company’s authentication page
data:image/s3,"s3://crabby-images/9e8dc/9e8dc048d600548f4c242d9db4957e6506a54bec" alt=""
If ADSF finds a valid token for you, you will be directed to the application registration portal. Otherwise you’ll get the same logon page you see for many other MS cloud-hosted apps. Once you have authenticated, click “Add an app” in the upper right-hand corner of the page.
data:image/s3,"s3://crabby-images/32bec/32becf894efe38f2cda7dbe971f105a9a1b53d7f" alt=""
Provide a descriptive name for the application and click “Create”
data:image/s3,"s3://crabby-images/d701e/d701ea9e99fb89cf39ff4c0e232f58310ebe8f50" alt=""
Click “Generate New Password” to generate a new application secret. Copy it into a temporary document. Copy the “Application Id” into the same temporary document.
data:image/s3,"s3://crabby-images/d1924/d19245cc344f76ade7f5464d17511e340cf492fc" alt=""
Click “Add Platform” and select “Web”
data:image/s3,"s3://crabby-images/708ae/708ae042b3ecc17a1e07693f17af7d7d351c600a" alt=""
Enter the appropriate redirect/logout URLs (this will be application specific – in the pre-built examples, the post-authentication redirect URL is http://localhost:5000/login/authorized
data:image/s3,"s3://crabby-images/62929/629298aaee03f617ad0df65543fe7dd4f4803c54" alt=""
Delegated permissions impersonate the signed in user, application permissions use the application’s credentials to perform actions. I use delegated permissions, although there are use cases where application permissions would be appropriate (batch jobs, for instance).
Add any permissions your app requires – for simple authentication, the default delegated permission “User.Read” is sufficient. If you want to perform additional actions – write files, send mail, etc – then you will need to click “Add” and select the extra permissions.
data:image/s3,"s3://crabby-images/806ff/806ff0f1458543c1808d9b7a2d138599bae2634b" alt=""
Profile information does not need to be entered, but I have entered the “Home page URL” for all of my applications so I am confident that I know which registered app corresponds with which deployed application (i.e. eighteen months from now, I can still figure out site is using the registered “ADSF Graph Sample” app and don’t accidentally delete it when it is still in use).
data:image/s3,"s3://crabby-images/5b669/5b669bec63b1d410b1f9a001bec6bbc5563bde11" alt=""
Click Save. You can return to your “My Applications” listing to verify the app was created successfully.
data:image/s3,"s3://crabby-images/25d59/25d599d664183de00e355c08579b14a6dea43f4c" alt=""
Application Implementation:
To use an example app from Microsoft’s repository, clone it.
git clone https://github.com/microsoftgraph/python-sample-auth.git
Edit the config.py file and update the “CLIENT_ID” variable with your Application Id and update the “CLIENT_SECRET” variable with your Application Secret password. (As they note, in a production implementation you would hash this out and store it somewhere else, not just drop it in clear text in your code … also if you publish a screen shot of your app ID & secret somewhere, generate a new password or delete the app registration and create a new one. Which is to say, do not retype the info in my example, I’ve already deleted the registration used herein.)
data:image/s3,"s3://crabby-images/9afab/9afabf334df88045e0b204f7821076aee899b0ab" alt=""
Install the prerequisites using “pip install -r requirements.txt”
data:image/s3,"s3://crabby-images/26422/26422136bca94cc94c5e1ccafc8a889195b35259" alt=""
Then run the application – in the authentication example, there are multiple web applications that use different interfaces. I am running “python sample_flask.py”
data:image/s3,"s3://crabby-images/09b47/09b4728909843efff16bdf199ca79c69789fe19f" alt=""
Once it is running, access your site at http://localhost:5000
data:image/s3,"s3://crabby-images/876f6/876f66176d6980368a1a7e430ce42993b3d2f333" alt=""
The initial page will load; click on “Connect”
data:image/s3,"s3://crabby-images/3ebc9/3ebc9bfdfd2ae75e009d8784278c0050d7b3df5b" alt=""
Enter your company user ID and click “Next”
data:image/s3,"s3://crabby-images/ac2b4/ac2b44c4fde30db58a430ef3662f855a5177420e" alt=""
This will redirect to the company’s sign-on page. For in-domain computers or computers that have already authenticated to ADSF, you won’t have to enter credentials. Otherwise, you’ll be asked to logon (and possibly perform the two-factor authentication verification).
Voila, the user is authenticated and you’ve got access to some basic directory info about the individual.
data:image/s3,"s3://crabby-images/e6b0b/e6b0b0a7fd4fdeec8d34ee1d631690f9226f338f" alt=""
|