-
Notifications
You must be signed in to change notification settings - Fork 38
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 67b33b4
Showing
56 changed files
with
8,676 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
out | ||
node_modules | ||
.vscode-test/ | ||
*.vsix | ||
*.js | ||
*.log |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
// A launch configuration that compiles the extension and then opens it inside a new window | ||
// Use IntelliSense to learn about possible attributes. | ||
// Hover to view descriptions of existing attributes. | ||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 | ||
{ | ||
"version": "0.2.0", | ||
"configurations": [ | ||
{ | ||
"name": "Extension", | ||
"type": "extensionHost", | ||
"request": "launch", | ||
"runtimeExecutable": "${execPath}", | ||
"args": [ | ||
"--extensionDevelopmentPath=${workspaceFolder}" | ||
], | ||
"outFiles": [ | ||
"${workspaceFolder}/out/**/*.js" | ||
], | ||
"preLaunchTask": "npm: watch" | ||
}, | ||
{ | ||
"name": "Extension Tests", | ||
"type": "extensionHost", | ||
"request": "launch", | ||
"runtimeExecutable": "${execPath}", | ||
"args": [ | ||
"--extensionDevelopmentPath=${workspaceFolder}", | ||
"--extensionTestsPath=${workspaceFolder}/out/test" | ||
], | ||
"outFiles": [ | ||
"${workspaceFolder}/out/test/**/*.js" | ||
], | ||
"preLaunchTask": "npm: watch" | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
// Place your settings in this file to overwrite default and user settings. | ||
{ | ||
"files.exclude": { | ||
"out": false // set this to true to hide the "out" folder with the compiled JS files | ||
}, | ||
"search.exclude": { | ||
"out": true // set this to false to include "out" folder in search results | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
// See https://go.microsoft.com/fwlink/?LinkId=733558 | ||
// for the documentation about the tasks.json format | ||
{ | ||
"version": "2.0.0", | ||
"tasks": [ | ||
{ | ||
"type": "npm", | ||
"script": "watch", | ||
"problemMatcher": "$tsc-watch", | ||
"isBackground": true, | ||
"presentation": { | ||
"reveal": "never" | ||
}, | ||
"group": { | ||
"kind": "build", | ||
"isDefault": true | ||
} | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
.vscode/** | ||
.vscode-test/** | ||
out/test/** | ||
out/**/*.map | ||
src/** | ||
.gitignore | ||
tsconfig.json | ||
vsc-extension-quickstart.md | ||
tslint.json |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# Change Log | ||
|
||
## January 2019 | ||
- Adding Smart copy and pasted feature | ||
- Fixing the 'add claim type' to include the claim type element's parents | ||
- New string claim type | ||
- In the policy explorer, adding a link to the root elements such as ClaimsSchema, ClaimsProviders and UserJourneys | ||
- Go to definition now supports navigating to a base policy and link to ClaimsExchange | ||
- Adding autocomplete | ||
|
||
## October 2018 | ||
- Adding Azure Application Insights trace log integration. Learn more [here](https://github.com/yoelhor/aad-b2c-vs-code-extension/blob/master/src/help/app-insights.md) | ||
- Go definition - VS code extension searches the definitions in all files in the working directory | ||
- Go definition hierarchical search - VS code extension searches the definitions only in the parents policies | ||
- Mouse over with link to all references | ||
- Policy app settings. For more information, see the readme file. | ||
|
||
## May 2018 | ||
- **Go to definition** - If the element is not found in the selected file. Or if the selected element points to another file (the XML element is overwritten). The extension search the definition is all open files. | ||
- **Go to definition** - Always take precedence of editor open files, over the saved version from file system (workspace folder) | ||
- **Add claim type** - New Paragraph, String collection, Integer, Long, and Boolean claim types | ||
- XML schema quick help | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
MIT License | ||
|
||
Copyright (c) Microsoft Corporation | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,178 @@ | ||
# Azure AD B2C extension | ||
|
||
The Azure AD B2C extension for VS Code lets you quickly navigate through Azure AD B2C [custom policy](https://docs.microsoft.com/en-us/azure/active-directory-b2c/active-directory-b2c-overview-custom). Create elements, such as: technical profiles and claim definition. For more information, see [Get started with custom policies](https://docs.microsoft.com/en-us/azure/active-directory-b2c/active-directory-b2c-get-started-custom). | ||
|
||
## Having an issue? | ||
Please contact us at [email protected] | ||
|
||
## Get started | ||
To start working with your custom policy. Open you Visual Studio Code, and open your folder that containing the custom policy XML files. Or open the policy XML files directly from any folder. | ||
|
||
data:image/s3,"s3://crabby-images/607e3/607e3d12249fa2564359afb116989b71e56dcd3f" alt="Custom policy navigator" | ||
|
||
# Azure AD B2C Custom policy Features | ||
|
||
## Autocomplete | ||
With autocomplete feature, you can save your time customizing a B2C policy. B2C extension provides you the list of policy settings, claims, technical profiles, and claims transformation aggregated from your policy files. Select one of the following attributes and click **ctrl+space** (cmd+space), or start: | ||
|
||
|
||
data:image/s3,"s3://crabby-images/2f968/2f968c40a8dd97ef2acc7714e2657c3beb771719" alt="Autocomplete" | ||
|
||
## Custom policy explorer | ||
From **Custom policy explorer** click the XML element type and select the element you want to open. Note: custom policy explorer shows elements from selected file only. | ||
|
||
data:image/s3,"s3://crabby-images/6823b/6823b685c66c5f2e53b0fd95397f5de1388bee97" alt="Custom policy navigator" | ||
|
||
## Go to definition and find all references | ||
To go any XML element definition. Clt-Click, click F12 or right-click and select **Go to definition** or **Peak definition**. Note: Go to definition navigates you to the source element in the selected file only. | ||
|
||
To search for references in your **Open folder** XML files or any XML file you open with VS code, select **Find all references** or click Shift+F12. | ||
|
||
data:image/s3,"s3://crabby-images/3264b/3264bbdc1aebf9149179998f580dc9071120e40e" alt="Go to definition and find all references" | ||
|
||
## Adding XML elements | ||
You can add following elements to your policy. Note: make sure your cursor is located in the right place. | ||
* B2C Add Identity provider technical profile (shift+ctrl+1) | ||
* B2C Add REST API technical profile (shift+ctrl+2) | ||
* B2C Add Claim Type (shift+ctrl+3) | ||
* B2C Add Application Insights (debug mode) (shift+ctrl+4) | ||
|
||
data:image/s3,"s3://crabby-images/f2f21/f2f21f9bf42205f739abca2775a29d98cc96effc" alt="Adding XML elements" | ||
|
||
|
||
## Smart Copy & Paste | ||
When you customize an XML element in the extension policy, **Smart Copy** allows you copy the entire element with its parents elements from the base policy. For example, when you copy the AAD-UserWriteUsingAlternativeSecurityId technical profile, smart copy generates an XML containing the following elements, so you don't need to look for the parents element, such as the claim provider. | ||
|
||
```XML | ||
<ClaimsProviders> | ||
<ClaimsProvider> | ||
<DisplayName>Azure Active Directory</DisplayName> | ||
<TechnicalProfiles> | ||
<TechnicalProfile Id="AAD-UserWriteUsingAlternativeSecurityId"> | ||
... | ||
</TechnicalProfile> | ||
</TechnicalProfiles> | ||
</ClaimsProvider> | ||
<ClaimsProviders> | ||
``` | ||
|
||
On contrariety, the **Smart Paste**, pastes from the clipboard only the necessary elements. Given the above XML, and your extension policy already has a claims provider named `Azure Active Directory`, the smart paste will paste only the technical profile without the claims provider. But if there is no such claims provider, the smart paste will paste the entire XML (including the claims provider and the technical profile). | ||
|
||
data:image/s3,"s3://crabby-images/b1209/b1209cb6b423b4f378d9cdf6b441f5d422bd9fc9" alt="Smart copy and paste" | ||
|
||
>Note: In this version the samrt copy and paste is limited to a single XML node. | ||
|
||
## Help and more information | ||
After you run the commends, B2C extension shows you information message with a link to relevant article. | ||
|
||
data:image/s3,"s3://crabby-images/c824d/c824d069b534fb270ce244d359548f6bb2de7eaf" alt="InformationMessage" | ||
|
||
## XML Schema quick help | ||
|
||
Move your mouse over any XML tag name, to see the description | ||
|
||
data:image/s3,"s3://crabby-images/4f654/4f6545dd7b07d885fadd25265fb9b278c964e781" alt="XML Schema quick help" | ||
|
||
## Application Insights | ||
Collect logs from Azure AD B2C and diagnose problems with your Azure AD B2C vocode extension. Read more [here](https://github.com/yoelhor/aad-b2c-vs-code-extension/blob/master/src/help/app-insights.md). The logs are organized by the **policy name**, **correlation Id** (the application insights presents the first digit of the correlation Id), and the **log timestamp**. This allows you to find the relevant log based on the local timestamp and see the user journey as executed by Azure AD B2C. | ||
|
||
data:image/s3,"s3://crabby-images/26659/2665976c916c1529f60ae64af1dcc4b238da01f2" alt="Application Insights" | ||
|
||
## Policy Settings | ||
Allows you to manage the values of your Azure AD B2C environments. When you execute the **B2C Policy build** command, the VS code extension finds and replaces the values of your settings with the ones configure in the policy file, and creates a directory that contains all of your policy files (after the replacement). In the following example, the extension replaces the keys with the value configure in the `appsettings.json` file: | ||
- {Settings:Tenant} | ||
- {Settings:ProxyIdentityExperienceFrameworkAppId} | ||
- {Settings:FacebookAppId} | ||
|
||
data:image/s3,"s3://crabby-images/e8f5d/e8f5d18dc663861404b6d296fb6d7b098a4e534e" alt="App Settings" | ||
|
||
The configuration `appsettings.json` file contains the keys with their values for each environment. | ||
- **Name** contains the environment name which VS code extension uses to create the environment folder (under the environments parent folder). Use your operation system legal characters only. | ||
- **Tenant** specifies the tenant name, such as contoso.onmicrosoft.com. In the policy file, use the format of **Settings:Tenant**, for example `{Settings:Tenant}`. | ||
- **Production** (boolean) is preserved for future use, indicating whether the environment is a production one. | ||
- **PolicySettings** contains a collection of key-value pair with your settings. In the policy file, use the format of **Settings:** and the key name, for example `{Settings:FacebookAppId}`. | ||
|
||
|
||
To build your policy, type `Ctrl+Shift+P`, which brings up the Command Palette. From here, type `B2C` and select **B2C Policy Build**. You have access to all of the B2C functionality of VS Code, including keyboard shortcuts `Ctrl+Shift+5`. | ||
|
||
data:image/s3,"s3://crabby-images/0691c/0691cd07ba9f2dc9e34724e48ec25fbe9f6cca6c" alt="policy build" | ||
|
||
On the first time, you run the **B2C Policy build** command, the VS code extension lets you create the `appsettings.json` file, with default set of environments, keys, and values: | ||
|
||
```JSON | ||
{ | ||
"Environments": [ | ||
{ | ||
"Name": "Development", | ||
"Production": false, | ||
"Tenant": "your-tenant.onmicrosoft.com", | ||
"PolicySettings" : { | ||
"IdentityExperienceFrameworkAppId": "Your dev environment AD app Id", | ||
"ProxyIdentityExperienceFrameworkAppId": "Your AD dev environment Proxy app Id", | ||
"FacebookAppId": "0" | ||
} | ||
}, | ||
{ | ||
"Name": "Test", | ||
"Production": false, | ||
"Tenant": "your-tenant.onmicrosoft.com", | ||
"PolicySettings" : { | ||
"IdentityExperienceFrameworkAppId": "Your test environment AD app Id", | ||
"ProxyIdentityExperienceFrameworkAppId": "Your test environment AD Proxy app Id", | ||
"FacebookAppId": "0" | ||
} | ||
}, | ||
{ | ||
"Name": "Production", | ||
"Production": true, | ||
"Tenant": "your-tenant.onmicrosoft.com", | ||
"PolicySettings" : { | ||
"IdentityExperienceFrameworkAppId": "Your production environment AD app Id", | ||
"ProxyIdentityExperienceFrameworkAppId": "Your production environment AD Proxy app Id", | ||
"FacebookAppId": "0" | ||
} | ||
}] | ||
} | ||
``` | ||
You can add, or remove environments, keys, and values, to accommodate your needs. For example, you can add new settings, such as the URL of a REST API end point, Google+ app Id, URL of content definitions. You can also add new environment, such as pre-prod. Make sure you provide the same set of key (with the relevant values) for each environment. In the following example, we add the **Pre-Production** environment and new set of key-values. | ||
|
||
```JSON | ||
{ | ||
"Environments": [ | ||
{ | ||
"Name": "Development", | ||
... | ||
}, | ||
{ | ||
"Name": "Test", | ||
... | ||
}, | ||
{ | ||
"Name": "QA", | ||
... | ||
}, | ||
{ | ||
"Name": "Pre-Production", | ||
}, | ||
{ | ||
"Name": "Production", | ||
"Production": true, | ||
"Tenant": "your-tenant.onmicrosoft.com", | ||
"PolicySettings" : { | ||
"IdentityExperienceFrameworkAppId": "Your AD app Id", | ||
"ProxyIdentityExperienceFrameworkAppId": "Your AD Proxy app Id", | ||
"FacebookAppId": "0", | ||
"MicrosoftAppId": "0", | ||
"GoogleAppId": "0", | ||
"RESTApiServer": "The location of your REST API", | ||
"HTMLPagesServer": "The location of your HTML page layout files" | ||
} | ||
}] | ||
} | ||
``` | ||
After the command is completed, you will find the exported policies under the **Environment** folder. **Important**: Before you upload the policy to your Azure AD B2C tenant, check the values of the exported policy files. | ||
|
||
|
||
## Disclaimer | ||
The extension is developed and managed by the open-source community in [GitHub](https://github.com/yoelhor/aad-b2c-tools.git). The extension is not part of Azure AD B2C product and it's not supported under any Microsoft standard support program or service. The extension is provided AS IS without warranty of any kind. For any issue, visit the [GitHub](https://github.com/yoelhor/aad-b2c-tools.git) repository. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.