Anypoint for ARC
An element that renders an UI to search Anypoint Exchange for available assets.
Usage
Installation
npm install --save @advanced-rest-client/anypoint
In an html file
<html>
<head>
<script type="module">
import '@advanced-rest-client/anypoint/define/exchange-search.js';
</script>
</head>
<body>
<exchange-search></exchange-search>
</body>
</html>
In a LitElement template
import { LitElement, html } from 'lit-element';
import '@advanced-rest-client/anypoint/define/exchange-search.js';
class SampleElement extends LitElement {
render() {
return html`
<exchange-search
.columns="${columns}"
@selected="${this._assetHandler}"
></exchange-search>
`;
}
_assetHandler(e) {
console.log(e.detail);
}
}
customElements.define('sample-element', SampleElement);
Authorization
The element uses @anypoint-web-components/anypoint-signin
to sing a user in.
Set anypointAuth
, exchangeRedirectUri
, and exchangeClientId
attributes to enable the authorization button.
<exchange-search
anypointAuth
exchangeRedirectUri="${redirectUrl}"
exchangeClientId="${clientId}"
@anypointcodeexchange="${this._processCodeExchange}"
></exchange-search>
Note, that currently the Anypoint authorization server only support "code" oauth flow. This means you have to handle code response and exchange the code for access token. To do so, handle the anypointcodeexchange
event dispatched by the anypoint-signin
element.
_handleTokenExchange(e) {
const { code } = e;
e.detail.result = this.exchangeCode(code);
}
async exchangeCode(code) {
const init = {
method: 'POST',
body: code,
};
const response = await fetch('YOUR SERVER URL', init);
const info = await response.json();
return {
accessToken: info.accessToken,
expiresAt: Date.now() + info.expiresIn,
expiresIn: info.expiresIn,
expiresAssumed: false,
state: '0',
};
}));
}
Development
git clone https://github.com/advanced-rest-client/anypoint
cd anypoint
npm install
Running the demo locally
npm start
Running the tests
npm test