Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
@appsemble/sdk
Advanced tools
Build your own blocks
npm install @appsemble/sdk
bootstrap
The bootstrap function registers a function which gets called every time a new instance of the block is created. If the block returns a DOM Node, it’s attached to the block’s shadow root.
The function may be asynchronous, but should not wait for actions to have finished, as actions are delayed until all blocks on a page are ready.
import { bootstrap } from '@appsemble/sdk';
bootstrap(({ utils }) => {
const root = document.createElement('span');
root.textContent = utils.formatMessage('hello');
return root;
});
Various block settings can be defined by augmenting interfaces in @appsemble/sdk
. This allows you
as a block developer to work in a type safe manner, while providing validation and documentation for
users implementing your block in their app.
Block parameters can be defined by augmenting the @appsemble/sdk#Parameters
interface. The
Appsemble CLI will automatically create a JSON schema from these type definitions. This includes the
TSDoc comments. It’s highly recommended to properly document this interface, as generated
documentation is user-facing. JSON schema properties can be written as TSDoc tags. Markdown is
supported in descriptions.
declare module '@appsemble/sdk' {
interface Parameters {
/**
* This is an example string parameter.
*
* @format email
* @minLength 10
* @maxLength 50
* @pattern ^.+@.*+\..+$
* @example 'Example string'
*/
exampleString: string;
/**
* This is an number parameter.
*
* @type integer
* @minimum 42
* @maximum 1337
* @multipleOf 3
* @example 123
*/
exampleNumber: number;
}
}
Block actions can be defined by augmenting the @appsemble/sdk#Action
interface. Only the action
keys and TSDoc descriptions are used. Markdown is supported in descriptions.
declare module '@appsemble/sdk' {
interface Action {
/**
* This is an example action.
*/
onClick: never;
}
}
Block event emitters can be defined by augmenting the @appsemble/sdk#EventEmitters
interface.
Block event listeners can be defined by augmenting the @appsemble/sdk#EventListeners
interface.
For both emitters and listeners, only the keys and TSDoc descriptions are used. Markdown is
supported in descriptions.
declare module '@appsemble/sdk' {
interface EventEmitters {
/**
* This is an example event emitter.
*/
data: never;
}
interface EventListeners {
/**
* This is an example event listener.
*/
refresh: never;
}
}
Block messages can be defined by augmenting the @appsemble/sdk#Messages
interface. The values of
these properties are used for type safety when calling utils.formatMessage()
. Markdown is
supported in descriptions.
declare module '@appsemble/sdk' {
interface Messages {
/**
* This message doesn’t support variables
*/
bye: never;
}
interface Messages {
/**
* This message accepts a variable named `name`.
*/
hello: {
name: string;
};
}
}
[0.18.25] - 2021-08-13
html
): Add html
block.--resources
flag to app create
.block build
command.resource create
command.resource update
command.page
remapper. This currently only supports the url
property.url
to app
remapper.multipart/form-data
instead of raw data.FAQs
Build your own blocks
The npm package @appsemble/sdk receives a total of 507 weekly downloads. As such, @appsemble/sdk popularity was classified as not popular.
We found that @appsemble/sdk demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 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
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.