data:image/s3,"s3://crabby-images/9fef7/9fef7e77a4ff9a4c39b8a32ffd7ebda8c2145888" alt="Malicious PyPI Package Exploits Deezer API for Coordinated Music Piracy"
Research
Security News
Malicious PyPI Package Exploits Deezer API for Coordinated Music Piracy
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
@globalsoftba/bede-starterkit
Advanced tools
Component library for Bede Experience applications.
Components used to Build feature rich websites using the Bede Platform
Made with create-react-library
npm install --save @bedegaming/bede-starterkit
/**
* src/i18n.tsx
* Initializes translations.
*/
import { translations } from '@bedegaming/bede-starterkit';
import i18n from 'i18next';
import { initReactI18next } from 'react-i18next';
i18n.use(initReactI18next).init({
resources: {
en: { translation: translations }
},
lng: 'en'
});
/**
* src/index.tsx
* Calls initialization function & assembles redux store.
*/
import {
initStarterkit,
reducers,
rootSaga
} from '@bedegaming/bede-starterkit';
import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'react-redux';
import { applyMiddleware, combineReducers, createStore } from 'redux';
import createSagaMiddleware from 'redux-saga';
import App from './App';
import './i18n';
initStarterkit({ appName: 'myAppName' });
const sagaMiddleware = createSagaMiddleware();
const store = createStore(combineReducers(reducers));
sagaMiddleware.run(rootSaga);
ReactDOM.render(
<Provider store={store}>
<App />
</Provider>,
document.getElementById('root')
);
import React, { Component } from 'react';
import { Button } from '@bedegaming/bede-starterkit';
import '@bedegaming/bede-starterkit/dist/index.css';
class Example extends Component {
render() {
return <Button label='Click me' />;
}
}
Global variables that can be overridden to customise the theme can be found in the files within the src/scss/theme
folder. Components also have their own specific theme variables that can be overridden which can be found in their corresponding scss
files.
Hey there Purdy
If importing component typing outside of the src/components
folder please first separate the typing into it's own file, otherwise the extra stuff imported into nativeAppUtils
may cause the native app build to fail.
You will need to do the following steps in order to integrate the components into an AEM React SPA project.
Install this package as a dependency. (when the package is published)
Add a file in ui.frontend/components/src
to import and map the component for AEM
inbox.js
import { InboxContainerAEM } from '@bedegaming/bede-starterkit';
import { MapTo } from '@adobe/cq-react-editable-components';
/**
* Optional configuration to help AEM decide when to render a placeholder
* instead of the component. If not needed feel free to omit the second argument.
*/
const InboxEditorConfig = {
emptyLabel: 'Inbox',
isEmpty: function (props) {
return !props;
}
};
export default MapTo('mysite/components/inbox')(
InboxContainerAEM,
InboxEditorConfig
);
Import the wrapped component file in import-components.js
npm install @teclead/aem-generator
Make the following changes to the scripts package.json
. This will add the functionality to auto generate AEM component/dialog config files.
{
"build": "npm run build:dialogs && react-scripts build && clientlib",
"build:dialogs": "node node_modules/@teclead/aem-generator/builder.js"
}
Add an AEM dialog definition file and modifiy the argument to suitable values for the project. The file will need to be typescript for the build:dialogs script to pick it up.
inbox.dialog.ts
import { inboxDialog } from '@bedegaming/bede-starterkit/dist/aem';
import { TouchUIXMLGenerator } from '@teclead/aem-generator';
new TouchUIXMLGenerator(
inboxDialog(
'../ui.apps/src/main/content/jcr_root/apps/mysite/components/',
'<div></div>',
'componentGroupName'
)
).writeFilesToAEM();
Versioning is done automatically on merge by the autoversion and autoversion-commit scripts as part of the teamcity build job, it works by checking the last commit (squash and merge on merging is advised) for a [fix]
, [patch]
, [feat]
, [minor]
, [major]
, [no-version]
tag and then will take care of bumping the package, commiting and publishing with an updated changelog on completion of build, unless a [no-version]
tag is specified.
Failure to not include a version type tag will result in the teamcity build job failing.
Requires setup of Adobe I/O CLI and Cloud Manager Plugin, more information can be found here. Upon completion of this, the next command to run is
aio cloudmanager:set-pipeline-variables <PIPELINE_ID> --programId=<PROGRAM_ID> --secret NPM_TOKEN <AUTH_TOKEN>
Replacing the <PIPELINE_ID>
, <PROGRAM_ID>
, <AUTH_TOKEN>
with the appropriate values
Using the example url https://experience.adobe.com/#/@bedegamingemeaptrsd/cloud-manager/pipelineexecution.html/program/31510/pipeline/4892025/execution/769397
we would run the command:
aio cloudmanager:set-pipeline-variables 4892025 --programId=31510 --secret NPM_TOKEN AUTH_TOKEN ...
Next in the project that is importing Bede-Starterkit, in the root directory create a .mvn
folder and inside create a file called extensions.xml
. Inside that file add the following snippet.
<extensions xmlns="http://maven.apache.org/EXTENSIONS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/EXTENSIONS/1.0.0 http://maven.apache.org/xsd/core-extensions-1.0.0.xsd">
<extension>
<groupId>biz.netcentric.maven.extension</groupId>
<artifactId>maven-ext-repos-from-env</artifactId>
<version>1.2.0</version>
</extension>
</extensions>
Commit it, and your adobe instance is ready to go. For more information about this setup click here.
FAQs
Component library for Bede Experience applications.
The npm package @globalsoftba/bede-starterkit receives a total of 0 weekly downloads. As such, @globalsoftba/bede-starterkit popularity was classified as not popular.
We found that @globalsoftba/bede-starterkit demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 11 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.
Research
Security News
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.
Security News
Newly introduced telemetry in devenv 1.4 sparked a backlash over privacy concerns, leading to the removal of its AI-powered feature after strong community pushback.