Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@clevercloud/client
Advanced tools
This project contains a REST client for Clever Cloud's API and some utils.
First, you need to install the Node.js module:
npm install @clevercloud/client
All API REST paths are accessible as "functions" organized in "services". A call to a function of a service will just prepare the HTTP request and return the request params in an object via a promise. It won't authenticate the request and it won't send it.
You will need to chain some helpers to the function call to:
Those helpers are ready to use for browsers or Node.js and for oAuth v1 signature auth. The recommended way is to wrap those helpers in one place of your app and to reuse it everywhere you need to send API calls.
Here's an example for a browser based project using ECMAScript modules with oAuth v1 signature and using the fetch
API to send requests.
In a file, expose this function:
import { addOauthHeader } from '@clevercloud/client/esm/oauth.js';
import { prefixUrl } from '@clevercloud/client/esm/prefix-url.js';
import { request } from '@clevercloud/client/esm/request.fetch.js';
export function sendToApi (requestParams) {
// load and cache config and tokens
const API_HOST = 'https://api.clever-cloud.com'
const tokens = {
OAUTH_CONSUMER_KEY: 'your OAUTH_CONSUMER_KEY',
OAUTH_CONSUMER_SECRET: 'your OAUTH_CONSUMER_SECRET',
API_OAUTH_TOKEN: 'your API_OAUTH_TOKEN',
API_OAUTH_TOKEN_SECRET: 'your API_OAUTH_TOKEN_SECRET',
}
return Promise.resolve(requestParams)
.then(prefixUrl(API_HOST))
.then(addOauthHeader(tokens))
.then(request);
// chain a .catch() call here if you need to handle some errors or maybe redirect to login
}
NOTE: If your project relies on a specific REST library (axios, jQuery...), you'll have to write your own request function to plug the params to your lib instead of using request.fetch.js
.
Then, in any file of your app, import the API function you need directly (it helps with tree shaking), call it and add a .then(sendToApi)
like this:
import { getAllEnvVars } from '@clevercloud/client/esm/api/v2/application.js';
import { sendToApi } from '../send-to-api.js';
const envVars = await getAllEnvVars({ id: oid, appId }).then(sendToApi);
NOTE: It returns a promise, you may want to use await
with it.
Here's an example for a Node.js based project using CommonJS modules with oAuth v1 signature and using the fetch
module to send requests.
In a file, expose this function:
const { addOauthHeader } = require('@clevercloud/client/cjs/oauth.js');
const { prefixUrl } = require('@clevercloud/client/cjs/prefix-url.js');
const { request } = require('@clevercloud/client/cjs/request.fetch.js');
module.exports.sendToApi = function sendToApi (requestParams) {
// load and cache config and tokens
const API_HOST = 'https://api.clever-cloud.com'
const tokens = {
OAUTH_CONSUMER_KEY: 'your OAUTH_CONSUMER_KEY',
OAUTH_CONSUMER_SECRET: 'your OAUTH_CONSUMER_SECRET',
API_OAUTH_TOKEN: 'your API_OAUTH_TOKEN',
API_OAUTH_TOKEN_SECRET: 'your API_OAUTH_TOKEN_SECRET',
}
return Promise.resolve(requestParams)
.then(prefixUrl(API_HOST))
.then(addOauthHeader(tokens))
.then(request);
// chain a .catch() call here if you need to handle some errors or maybe redirect to login
}
NOTE: If your project relies on a specific REST library (axios, request...), you'll have to write your own request function to plug the params to your lib instead of using request.fetch.js
.
Then, in any file of your app, require the service, call the function on it and add a .then(sendToApi)
like this:
const application = require('@clevercloud/client/cjs/api/v2/application.js');
const { sendToApi } = require('../send-to-api.js');
const envVars = await application.getAllEnvVars({ id: oid, appId }).then(sendToApi);
NOTE: It returns a promise, you may want to use await
with it.
A general documentation is proposed on our Website. As stated in the documentation:
You need to create an oAuth consumer token in the Clever Cloud console. Click on "Create...", then on "an oauth consumer" under your organization name. All created consumers will appear under the list of applications and add-ons.
Once you got the consumer, you still need to generate the aAuth tokens. You may do the whole aAuth dance in the browser.
If you use the clever-tools CLI, you can also generate tokens using the following command :
clever login
Once successfully logged in, you’ll be provided with a token / secret couple.
To generate a REST client from the API, run this command:
npm run generate-client
This command will:
To generate a REST client (ECMAScript modules) from the API, run this command:
npm run generate-client-from-openapi
This command will do the following steps:
./data/patch-for-openapi-clever-v2.json
(this step should disappear one day)/self
and /organisation/{id}
)esm/api
esm/api/v2/legacy-client.js
NOTE: The first step caches the Open API document locally for next calls, be sure to run this command to clear the content of .cache
if you want a clean build:
npm run clean-cache
If you want to generate a client for the preprod, you can change the config of OPEN_API_URL
in tasks/config.js
.
To generate a REST client for Node.js (CommonJS modules) from the API, run this command:
npm run generate-cjs-modules
NOTE: This is based on the ECMAScript modules in esm
. Be sure to generate the ESM client before running this.
This stream is exposed the inner SSE source with component-emitter
, a tiny lib implementing an API that closely match both EventTarget
from the DOM and EventEmitter
from Node.js.
Here's an example of how to use LogsStream
to retrieve live logs from an app:
// Browser implementation or Node.js implementation
import { LogsStream } from '@clevercloud/client/esm/streams/logs.browser.js';
// import { LogsStream } from '@clevercloud/client/esm/streams/logs.node.js';
// Load and cache config and tokens
const API_HOST = 'https://api.clever-cloud.com';
const tokens = {
OAUTH_CONSUMER_KEY: 'your OAUTH_CONSUMER_KEY',
OAUTH_CONSUMER_SECRET: 'your OAUTH_CONSUMER_SECRET',
API_OAUTH_TOKEN: 'your API_OAUTH_TOKEN',
API_OAUTH_TOKEN_SECRET: 'your API_OAUTH_TOKEN_SECRET',
};
// Create a LogsStream instance (filter and deploymentId are optional)
const logsStream = new LogsStream({ apiHost: API_HOST, tokens, appId, filter, deploymentId });
// Listen to "log" events
logsStream.on('log', (rawLogLine) => console.log(rawLogLine));
// Open the stream
logsStream.open();
This stream is exposed the inner WebSocket source with component-emitter
, a tiny lib implementing an API that closely match both EventTarget
from the DOM and EventEmitter
from Node.js.
Here's an example of how to use EventsStream
to retrieve events from the Clever Cloud platform:
// Browser implementation or Node.js implementation
import { EventsStream } from '@clevercloud/client/esm/streams/events.browser.js';
// import { EventsStream } from '@clevercloud/client/esm/streams/events.node.js';
// Load and cache config and tokens
const API_HOST = 'https://api.clever-cloud.com';
const tokens = {
OAUTH_CONSUMER_KEY: 'your OAUTH_CONSUMER_KEY',
OAUTH_CONSUMER_SECRET: 'your OAUTH_CONSUMER_SECRET',
API_OAUTH_TOKEN: 'your API_OAUTH_TOKEN',
API_OAUTH_TOKEN_SECRET: 'your API_OAUTH_TOKEN_SECRET',
};
// Create an EventsStream instance (appId is optional)
const eventsStream = new EventsStream({ apiHost: API_HOST, tokens, appId });
// Listen to "event" events
eventsStream.on('event', (rawEvent) => console.log(rawEvent));
// Open the stream
eventsStream.open();
When an error (network failures, bad authentication...) occurs with the source stream, an error event is emitted:
stream.on('error', (error) => console.error(error));
See "auto retry behaviour" section for more details...
You can close the stream at any time like this:
stream.close();
It won't remove event listeners from the stream instance so you can re-open it easily.
When you call .open()
on a stream, it's not resilient to network failures by default.
We have an opt-in auto retry behaviour to handle those, you can enable it when you open the stream like this:
stream.open({ autoRetry: true });
Network failure are detected with a ping/pong system. When such a failure is detected and auto retry behaviour is enabled, the source stream is closed and a new open is attempted automatically.
You probably don't need to but you can listen to events related to this auto retry behaviour:
// "close" event is emitted each time a network failure is detected (or any unknown error not related to authentication)
stream.on('close', (reason) => console.log('Stream closed because of', reason));
// "open" event is emitted on first .open() call and each time a new open is attempted
stream.on('open', () => console.log('Stream open...'));
// "ping" event is emitted each time a ping is received from the source stream
stream.on('ping', () => console.log('Received ping'));
When enabled, the auto retry behaviour will follow an infinite exponential backoff pattern. You can change the default timings and max number of retries like this:
stream.open({
autoRetry: true,
// Factor used to compute exponential backoff delays, defaults to 1.25
backoffFactor: 1.5,
// First iteration timeout in ms, also used to compute exponential backoff delays, defaults to 1500
initRetryTimeout: 2000,
// Maximum number of consecutive iterations the auto retry behaviour can do, defaults to Infinity
maxRetryCount: 6,
});
import { ApplicationLogStream } from '@clevercloud/client/esm/streams/application-log.js';
// Load and cache config and tokens
const API_HOST = 'https://api.clever-cloud.com';
const tokens = {
OAUTH_CONSUMER_KEY: 'your OAUTH_CONSUMER_KEY',
OAUTH_CONSUMER_SECRET: 'your OAUTH_CONSUMER_SECRET',
API_OAUTH_TOKEN: 'your API_OAUTH_TOKEN',
API_OAUTH_TOKEN_SECRET: 'your API_OAUTH_TOKEN_SECRET',
};
// Create an EventsStream instance (appId is optional)
const logsStream = new ApplicationLogStream({
apiHost: API_HOST,
tokens,
ownerId: 'YYY',
appId: 'XXX',
// optionnal auto retry config
// retryConfiguration: {
// enabled: true,
// backoffFactor: number,
// initRetryTimeout: number,
// maxRetryCount: number,
// },
// optionnal logs request params
// since: Date,
// until: Date,
// service: string[],
// limit: number,
// deploymentId: string,
// instanceId: string[],
// filter: string,
// field: string[],
// throttleElements: number,
// throttlePerInMilliseconds: number,
});
logsStream
.on('open', (event) => console.debug('stream opened!', event))
.on('error', (event) => console.error('error', event.error))
.onLog((event) => console.log(event.data.date, event.data.message));
logsStream.start();
// You can also pause the stream
logsStream.pause();
// And resume it
logsStream.resume();
This project is licensed under the Apache-2.0.
We're using modified versions of projects related to SSE:
These projects are licensed under MIT license.
8.0.2 (2023-10-31)
sse-parse
used by ApplicationLogsStream
(Node.js < 18.16)FAQs
JavaScript REST client and utils for Clever Cloud's API
The npm package @clevercloud/client receives a total of 1,587 weekly downloads. As such, @clevercloud/client popularity was classified as popular.
We found that @clevercloud/client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.