631 lines
25 KiB
JavaScript
631 lines
25 KiB
JavaScript
'use strict';
|
||
|
||
import React, {Component} from 'react';
|
||
import {withTranslation} from '../lib/i18n';
|
||
import {Trans} from 'react-i18next';
|
||
import {requiresAuthenticatedUser, Title, withPageHelpers} from '../lib/page'
|
||
import {withAsyncErrorHandler, withErrorHandling} from '../lib/error-handling';
|
||
import axios from '../lib/axios';
|
||
import {Button} from '../lib/bootstrap-components';
|
||
import {getUrl} from "../lib/urls";
|
||
import {withComponentMixins} from "../lib/decorator-helpers";
|
||
import styles from "./styles.scss"
|
||
|
||
@withComponentMixins([
|
||
withTranslation,
|
||
withErrorHandling,
|
||
withPageHelpers,
|
||
requiresAuthenticatedUser
|
||
])
|
||
export default class API extends Component {
|
||
constructor(props) {
|
||
super(props);
|
||
|
||
this.state = {
|
||
accessToken: null
|
||
};
|
||
}
|
||
|
||
@withAsyncErrorHandler
|
||
async loadAccessToken() {
|
||
const response = await axios.get(getUrl('rest/access-token'));
|
||
this.setState({
|
||
accessToken: response.data
|
||
});
|
||
}
|
||
|
||
componentDidMount() {
|
||
// noinspection JSIgnoredPromiseFromCall
|
||
this.loadAccessToken();
|
||
}
|
||
|
||
async resetAccessToken() {
|
||
const response = await axios.post(getUrl('rest/access-token-reset'));
|
||
this.setState({
|
||
accessToken: response.data
|
||
});
|
||
}
|
||
|
||
render() {
|
||
const t = this.props.t;
|
||
|
||
const accessToken = this.state.accessToken || 'ACCESS_TOKEN';
|
||
|
||
let accessTokenMsg;
|
||
if (this.state.accessToken) {
|
||
accessTokenMsg = <div>{t('personalAccessToken') + ': '}<code>{accessToken}</code></div>;
|
||
} else {
|
||
accessTokenMsg = <div>{t('accessTokenNotYetGenerated')}</div>;
|
||
}
|
||
|
||
return (
|
||
<div className={styles.api}>
|
||
<Title>{t('api')}</Title>
|
||
|
||
<div className="card mb-3">
|
||
<div className="card-body">
|
||
<div className="float-right">
|
||
<Button label={this.state.accessToken ? t('resetAccessToken') : t('generateAccessToken')} icon="redo" className="btn-info" onClickAsync={::this.resetAccessToken} />
|
||
</div>
|
||
{accessTokenMsg}
|
||
</div>
|
||
</div>
|
||
|
||
<div className="card mb-3">
|
||
<div className="card-body">
|
||
<h4 className="card-title">{t('notesAboutTheApi')}</h4>
|
||
|
||
<ul className="card-text">
|
||
<li>
|
||
<Trans i18nKey="apiResponseIsAJsonStructureWithErrorAnd">API response is a JSON structure with <code>error</code> and <code>data</code> properties. If the response <code>error</code> has a value set then the request failed.</Trans>
|
||
</li>
|
||
<li>
|
||
<Trans i18nKey="youNeedToDefineProperContentTypeWhen">You need to define proper <code>Content-Type</code> when making a request. You can either use <code>application/x-www-form-urlencoded</code> for normal form data or <code>application/json</code> for a JSON payload. Using <code>multipart/form-data</code> is not supported.</Trans>
|
||
</li>
|
||
</ul>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="accordion" id="apicalls">
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moresubscribers"><h4>GET /api/subscriptions/:listCid – {t('Get subscribers')}</h4></button>
|
||
</div>
|
||
<div id="moresubscribers" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('Get subscribers')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}
|
||
<ul>
|
||
<li><strong>start</strong> – {t('startPosition')} (<em>{t('optionalDefault0')}</em>)</li>
|
||
<li><strong>limit</strong> – {t('limitEmailsCountInResponse')} (<em>{t('optionalDefault10000')}</em>)</li>
|
||
</ul>
|
||
</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XGET '{getUrl(`api/subscriptions/P5wKkz-e7?access_token=${accessToken}&limit=10&start=10&search=gmail`)}' </pre>
|
||
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<h4><button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moresubscribe"><h4>POST /api/subscribe/:listCid – {t('addSubscription')}</h4></button></h4>
|
||
</div>
|
||
<div id="moresubscribe" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallEitherInsertsANewSubscription')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('subscribersEmailAddress')} (<em>{t('required')}</em>)</li>
|
||
<li><strong>FIRST_NAME</strong> – {t('subscribersFirstName')}</li>
|
||
<li><strong>LAST_NAME</strong> – {t('subscribersLastName')}</li>
|
||
<li><strong>TIMEZONE</strong> – {t('subscribersTimezoneEgEuropeTallinnPstOr')}</li>
|
||
<li><strong>MERGE_TAG_VALUE</strong> – {t('customFieldValueUseYesnoForOptionGroup')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
{t('additionalPostArguments')}:
|
||
</p>
|
||
|
||
<ul>
|
||
<li>
|
||
<strong>FORCE_SUBSCRIBE</strong> – {t('setToYesIfYouWantToMakeSureTheEmailIs')}
|
||
by default.
|
||
</li>
|
||
<li>
|
||
<strong>REQUIRE_CONFIRMATION</strong> – {t('setToYesIfYouWantToSendConfirmationEmail')}
|
||
</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/subscribe/B16uVTdW?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com&MERGE_CHECKBOX=yes&REQUIRE_CONFIRMATION=yes'</pre>
|
||
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>"data": ("id":"TTrw41znK")</pre>
|
||
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moreunsubscribe"><h4>POST /api/unsubscribe/:listCId – {t('removeSubscription')}</h4></button>
|
||
</div>
|
||
<div id="moreunsubscribe" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallMarksASubscriptionAs')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('subscribersEmailAddress')} (<em>{t('required')}</em>)</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/unsubscribe/B16uVTdW?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com'</pre>
|
||
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>"data": ("id":"TTrw41znK", "unsubscribed":true)</pre>
|
||
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moredelete"><h4>POST /api/delete/:listCId – {t('deleteSubscription')}</h4></button>
|
||
</div>
|
||
<div id="moredelete" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallDeletesASubscription')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('subscribersEmailAddress')} (<em>{t('required')}</em>)</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/delete/B16uVTdW?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com'</pre>
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>"data": ("id":"TTrw41znK", "deleted":true)</pre>
|
||
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#morefield"><h4>POST /api/field/:listId – {t('addNewCustomField')}</h4></button>
|
||
</div>
|
||
<div id="morefield" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallCreatesANewCustomFieldForA')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>NAME</strong> – {t('fieldName')} (<em>{t('required')}</em>)</li>
|
||
<li><strong>TYPE</strong> – {t('oneOfTheFollowingTypes')}
|
||
<ul>
|
||
<li><strong>text</strong> – Text</li>
|
||
<li><strong>website</strong> – Website</li>
|
||
<li><strong>longtext</strong> – Multi-line text</li>
|
||
<li><strong>gpg</strong> – GPG Public Key</li>
|
||
<li><strong>number</strong> – Number</li>
|
||
<li><strong>radio</strong> – Radio Buttons</li>
|
||
<li><strong>checkbox</strong> – Checkboxes</li>
|
||
<li><strong>dropdown</strong> – Drop Down</li>
|
||
<li><strong>date-us</strong> – Date (MM/DD/YYY)</li>
|
||
<li><strong>date-eur</strong> – Date (DD/MM/YYYY)</li>
|
||
<li><strong>birthday-us</strong> – Birthday (MM/DD)</li>
|
||
<li><strong>birthday-eur</strong> – Birthday (DD/MM)</li>
|
||
<li><strong>json</strong> – JSON value for custom rendering</li>
|
||
<li><strong>option</strong> – Option</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>GROUP</strong> – {t('ifTheTypeIsOptionThenYouAlsoNeedTo')}</li>
|
||
<li><strong>GROUP_TEMPLATE</strong> – {t('templateForTheGroupElementIfNotSetThen')}</li>
|
||
<li><strong>VISIBLE</strong> – yes/no, {t('ifNotVisibleThenTheSubscriberCanNotView')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/field/B16uVTdW?access_token=${accessToken}`)}' \<br/>
|
||
--data 'NAME=Comment&TYPE=text'</pre>
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>"data": ("id":22, "tag":"MERGE_COMMENT")</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moreblacklistget"><h4>GET /api/blacklist/get – {t('getListOfBlacklistedEmails')}</h4></button>
|
||
</div>
|
||
<div id="moreblacklistget" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallGetListOfBlacklistedEmails')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}
|
||
<ul>
|
||
<li><strong>start</strong> – {t('startPosition')} (<em>{t('optionalDefault0')}</em>)</li>
|
||
<li><strong>limit</strong> – {t('limitEmailsCountInResponse')} (<em>{t('optionalDefault10000')}</em>)</li>
|
||
<li><strong>search</strong> – {t('filterByPartOfEmail')} (<em>{t('optionalDefault')}</em>)</li>
|
||
</ul>
|
||
</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XGET '{getUrl(`api/blacklist/get?access_token=${accessToken}&limit=10&start=10&search=gmail`)}' </pre>
|
||
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moreblacklistadd"><h4>POST /api/blacklist/add – {t('addEmailToBlacklist')}</h4></button>
|
||
</div>
|
||
<div id="moreblacklistadd" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallEitherAddEmailsToBlacklist')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('emailAddress')} (<em>{t('required')}</em>)</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/blacklist/add?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moreblacklistdelete"><h4>POST /api/blacklist/delete – {t('deleteEmailFromBlacklist')}</h4></button>
|
||
</div>
|
||
<div id="moreblacklistdelete" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('thisApiCallEitherDeleteEmailsFrom')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('emailAddress')} (<em>{t('required')}</em>)</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/blacklist/delete?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#morelistsemail"><h4>GET /api/lists/:email – {t('getTheListsAUserHasSubscribedTo')}</h4></button>
|
||
</div>
|
||
<div id="morelistsemail" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('retrieveTheListsThatTheUserWithEmailHas')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XGET '{getUrl(`api/lists/test@example.com?access_token=${accessToken}`)}'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#morelistsnamespace"><h4>GET /api/lists-by-namespace/:namespaceId – {t('getListsInNamespace')}</h4></button>
|
||
</div>
|
||
<div id="morelistsnamespace" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('retrieveTheListsThatTheNamespaceHas')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XGET '{getUrl(`api/lists-by-namespace/1?access_token=${accessToken}`)}'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#morecreatelist"><h4>POST /api/list – {t('createList')}</h4></button>
|
||
</div>
|
||
<div id="morecreatelist" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('createListDescription')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>NAMESPACE</strong> – {t('namespace')} (<em>{t('required')}</em>)</li>
|
||
<li><strong>UNSUBSCRIPTION_MODE</strong> – {t('unsubscription')} (<em>{t('required')}</em>):
|
||
<ul>
|
||
<li><strong>0</strong> - {t('onestepIeNoEmailWithConfirmationLink')}</li>
|
||
<li><strong>1</strong> - {t('onestepWithUnsubscriptionFormIeNoEmail')}</li>
|
||
<li><strong>2</strong> - {t('twostepIeAnEmailWithConfirmationLinkWill')}</li>
|
||
<li><strong>3</strong> - {t('twostepWithUnsubscriptionFormIeAnEmail')}</li>
|
||
<li><strong>4</strong> - {t('manualIeUnsubscriptionHasToBePerformedBy')}</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>NAME</strong> – {t('name')}</li>
|
||
<li><strong>DESCRIPTION</strong> – {t('description')}</li>
|
||
<li><strong>HOMEPAGE</strong> – {t('homepage')}</li>
|
||
<li><strong>CONTACT_EMAIL</strong> – {t('contactEmail')}</li>
|
||
<li><strong>DEFAULT_FORM</strong> – {t('webAndEmailFormsAndTemplatesUsedIn')}</li>
|
||
<li><strong>FIELDWIZARD</strong> – {t('representationOfSubscribersName')}:
|
||
<ul>
|
||
<li><strong>none</strong> - {t('emptyCustomNoFields')}</li>
|
||
<li><strong>full_name</strong> - {t('nameOneField')}</li>
|
||
<li><strong>first_last_name</strong> - {t('firstNameAndLastNameTwoFields')}</li>
|
||
</ul>
|
||
</li>
|
||
<li><strong>TO_NAME</strong> – {t('recipientsNameTemplate')}</li>
|
||
<li><strong>LISTUNSUBSCRIBE_DISABLED</strong> – {t('doNotSendListUnsubscribeHeaders')}</li>
|
||
<li><strong>PUBLIC_SUBSCRIBE</strong> – {t('allowPublicUsersToSubscribeThemselves')}</li>
|
||
<li><strong>SEND_CONFIGURATION</strong> – {t('sendConfiguration-1')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/list?access_token=${accessToken}`)}' \<br/>
|
||
-d 'NAMESPACE=1' \<br/>
|
||
-d 'UNSUBSCRIPTION_MODE=0' \<br/>
|
||
-d 'NAME=list1' \<br/>
|
||
-d 'DESCRIPTION=a very nice list' \<br/>
|
||
-d 'CONTACT_EMAIL=test@example.com' \<br/>
|
||
-d 'HOMEPAGE=example.com' \<br/>
|
||
-d 'FIELDWIZARD=first_last_name' \<br/>
|
||
-d 'SEND_CONFIGURATION=1' \<br/>
|
||
-d 'PUBLIC_SUBSCRIBE=1' \<br/>
|
||
-d 'LISTUNSUBSCRIBE_DISABLED=0'
|
||
</pre>
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>"data": ("id":"WSGjaP1fY")</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moredeletelist"><h4>DELETE /api/list/:listCId – {t('deleteList')}</h4></button>
|
||
</div>
|
||
<div id="moredeletelist" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('deleteListDescription')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XDELETE '{getUrl(`api/list/WSGjaP1fY?access_token=${accessToken}`)}'</pre>
|
||
<p>
|
||
{t('Response example')}:
|
||
</p>
|
||
<pre>{t('Empty object')}</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#morerss"><h4>GET /api/rss/fetch/:campaignCid – {t('triggerFetchOfACampaign')}</h4></button>
|
||
</div>
|
||
<div id="morerss" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('forcesTheRssFeedCheckToImmediatelyCheck')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XGET '{getUrl(`api/rss/fetch/5OOnZKrp0?access_token=${accessToken}`)}'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="card">
|
||
<div class="card-header">
|
||
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#moretemplate"><h4>POST /api/templates/:templateId/send – {t('sendTransactionalEmail')}</h4></button>
|
||
</div>
|
||
<div id="moretemplate" class="collapse" data-parent="#apicalls">
|
||
<div class="card-body">
|
||
<p>
|
||
{t('sendSingleEmailByTemplateWithGiven')}
|
||
</p>
|
||
|
||
<p>
|
||
{t('Query params')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>access_token</strong> – {t('yourPersonalAccessToken')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>POST</strong> {t('arguments')}
|
||
</p>
|
||
<ul>
|
||
<li><strong>EMAIL</strong> – {t('emailAddress')} (<em>{t('required')}</em>)</li>
|
||
<li><strong>SEND_CONFIGURATION_ID</strong> – {t('idOfConfigurationUsedToCreateMailer')}</li>
|
||
<li><strong>SUBJECT</strong> – {t('subject')}</li>
|
||
<li><strong>TAGS</strong> – {t('mapOfTemplatesubjectVariablesToReplace')}</li>
|
||
<li><strong>ATTACHMENTS</strong> – {t('Attachments (format as consumed by nodemailer)')}</li>
|
||
</ul>
|
||
|
||
<p>
|
||
<strong>{t('example')}</strong>
|
||
</p>
|
||
|
||
<pre>curl -XPOST '{getUrl(`api/templates/1/send?access_token=${accessToken}`)}' \<br/>
|
||
--data 'EMAIL=test@example.com&SUBJECT=Test&TAGS[FOO]=bar&TAGS[TEST]=example'</pre>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
|
||
|
||
</div>
|
||
);
|
||
}
|
||
}
|