feat: Added workflow to release at NPM site (#48)

* chore: Changed name for release

* chore: Sorted package.json

* ci: Added workflow to publish releases

* chore: Updated .gitignore

* chore: Updated lint to use nodejs v18

* chore: Updated package name in README.md

* chore: Change the current version
This commit is contained in:
Edgard Lorraine Messias
2023-05-10 20:07:26 -03:00
committed by GitHub
parent 13810ec7ea
commit 7c3f0df560
8 changed files with 2457 additions and 171 deletions

View File

@@ -13,7 +13,7 @@ jobs:
- name: Install Node - name: Install Node
uses: actions/setup-node@v1 uses: actions/setup-node@v1
with: with:
node-version: 16.x node-version: 18.x
- name: Install packages - name: Install packages
run: yarn run: yarn

46
.github/workflows/manual-release.yml vendored Normal file
View File

@@ -0,0 +1,46 @@
name: Manual Release
on:
workflow_dispatch:
inputs:
increment:
type: string
description: "Must be: patch, minor, major, pre* or <version>"
required: true
default: "patch"
jobs:
manual-release:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
with:
token: ${{ secrets.PERSONAL_TOKEN }}
- name: Setup GIT
run: |
git config --global user.name "github-actions[bot]"
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
- name: Setup Node
uses: actions/setup-node@v3.6.0
with:
node-version: 18.x
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT
- uses: actions/cache@v3
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
- name: Install Dependencies
run: yarn
- name: Release
run: "npx release-it --increment ${{ github.event.inputs.increment }}"

View File

@@ -1,83 +1,79 @@
name: Publish Release name: Publish Release
on: "workflow_dispatch" on:
push:
tags:
- "v*"
jobs: jobs:
publish-release:
# Test:
# runs-on: ubuntu-latest
# steps:
# - name: Checkout Commit
# uses: actions/checkout@v2
#
# - name: Setup Node.js environment
# uses: actions/setup-node@v2.1.1
#
# - name: Install Dependencies
# run: npm install
#
# - name: Run Tests
# run: npm run test
Build:
runs-on: ubuntu-latest runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps: steps:
- name: Checkout Commit - name: Checkout
uses: actions/checkout@v2 uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Parsing Package Info - name: Fetching tags
id: packageInfo run: git fetch --tags -f || true
run: |
echo "::set-output name=package-name::$(jq -r .name package.json)"
echo "::set-output name=package-version::$(jq -r .version package.json)"
echo "::set-output name=commit-msg::$(git log -1 --pretty=%B)"
- name: Setup Node.js environment
uses: actions/setup-node@v2.1.1
- name: Install Dependencies - name: Setup Node
run: yarn uses: actions/setup-node@v3.6.0
with:
node-version: 18.x
registry-url: "https://registry.npmjs.org"
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: Build - name: Get yarn cache directory path
run: yarn run build:tsc id: yarn-cache-dir-path
run: echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT
- name: Create Release
id: releaseCreate - uses: actions/cache@v3
uses: actions/create-release@v1 id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
env: with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
- name: Install Dependencies
run: yarn
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: Publish in NPM
run: npm publish --access public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: Generate Changelog
id: generate_changelog
run: |
changelog=$(npm run changelog:last --silent)
echo "changelog<<EOF" >> $GITHUB_OUTPUT
echo "${changelog}" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
- name: Make Package
run: npm pack
- name: Rename Pack
run: mv *.tgz baileys.tgz
- name: Create Release
uses: meeDamian/github-release@2.0
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with: with:
# The name of the tag. This should come from the webhook payload, `github.GITHUB_REF` when a user pushes a new tag token: ${{ secrets.GITHUB_TOKEN }}
tag_name: v${{ steps.packageInfo.outputs.package-version }} tag: ${{ github.ref }}
# The name of the release. For example, `Release v1.0.1` commitish: ${{ github.sha }}
release_name: v${{ steps.packageInfo.outputs.package-version }} name: ${{ github.ref_name }}
# Text describing the contents of the tag. body: ${{ steps.generate_changelog.outputs.changelog }}
body: ${{steps.packageInfo.outputs.commit-msg}} draft: false
# `true` to create a draft (unpublished) release, `false` to create a published one. Default: `false` prerelease: false
draft: false files: >
# `true` to identify the release as a prerelease. `false` to identify the release as a full release. Default: `false` baileys.tgz
prerelease: false gzip: folders
allow_override: true
- name: Make Package
run: npm pack
- name: Rename Pack
run: mv *.tgz npmPackage.tgz
- name: Git Release
uses: actions/upload-release-asset@v1.0.2
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
# The URL for uploading assets to the release
upload_url: ${{steps.releaseCreate.outputs.upload_url}}
# The path to the asset you want to upload
asset_path: npmPackage.tgz
asset_name: npmPackage.tgz
# The content-type of the asset you want to upload. See the supported Media Types here: https://www.iana.org/assignments/media-types/media-types.xhtml for more information
asset_content_type: application/x-compressed-tar
- name: NPM Publish
uses: JS-DevTools/npm-publish@v1
with:
token: ${{ secrets.NPM_TOKEN }}

20
.gitignore vendored
View File

@@ -1,17 +1,19 @@
node_modules .DS_Store
.env
.yarn/
*.tgz
*/.DS_Store
auth_info*.json auth_info*.json
baileys_auth_info* baileys_auth_info*
baileys_store*.json baileys_store*.json
output.csv
*/.DS_Store
.DS_Store
.env
browser-messages.json browser-messages.json
decoded-ws.json
lib
docs
browser-token.json browser-token.json
Proxy decoded-ws.json
docs
lib
messages*.json messages*.json
node_modules
output.csv
Proxy
test.ts test.ts
TestData TestData

14
.release-it.yml Normal file
View File

@@ -0,0 +1,14 @@
git:
commitMessage: "chore(release): v${version}"
tagAnnotation: "chore(release): v${version}"
tagName: "v${version}"
hooks:
after:bump:
- "npm run changelog:update"
# automatic publish from github workflow
npm:
publish: false
private: true
registry: "OMITTED"

View File

@@ -35,7 +35,7 @@ yarn add github:WhiskeySockets/Baileys
Then import your code using: Then import your code using:
``` ts ``` ts
import makeWASocket from '@adiwajshing/baileys' import makeWASocket from '@whiskeysockets/baileys'
``` ```
## Unit Tests ## Unit Tests
@@ -45,7 +45,7 @@ TODO
## Connecting ## Connecting
``` ts ``` ts
import makeWASocket, { DisconnectReason } from '@adiwajshing/baileys' import makeWASocket, { DisconnectReason } from '@whiskeysockets/baileys'
import { Boom } from '@hapi/boom' import { Boom } from '@hapi/boom'
async function connectToWhatsApp () { async function connectToWhatsApp () {
@@ -175,7 +175,7 @@ You obviously don't want to keep scanning the QR code every time you want to con
So, you can load the credentials to log back in: So, you can load the credentials to log back in:
``` ts ``` ts
import makeWASocket, { BufferJSON, useMultiFileAuthState } from '@adiwajshing/baileys' import makeWASocket, { BufferJSON, useMultiFileAuthState } from '@whiskeysockets/baileys'
import * as fs from 'fs' import * as fs from 'fs'
// utility function to help save the auth state in a single folder // utility function to help save the auth state in a single folder
@@ -288,7 +288,7 @@ Baileys does not come with a defacto storage for chats, contacts, or messages. H
It can be used as follows: It can be used as follows:
``` ts ``` ts
import makeWASocket, { makeInMemoryStore } from '@adiwajshing/baileys' import makeWASocket, { makeInMemoryStore } from '@whiskeysockets/baileys'
// the store maintains the data of the WA connection in memory // the store maintains the data of the WA connection in memory
// can be written out to a file & read from it // can be written out to a file & read from it
const store = makeInMemoryStore({ }) const store = makeInMemoryStore({ })
@@ -327,7 +327,7 @@ The store also provides some simple functions such as `loadMessages` that utiliz
### Non-Media Messages ### Non-Media Messages
``` ts ``` ts
import { MessageType, MessageOptions, Mimetype } from '@adiwajshing/baileys' import { MessageType, MessageOptions, Mimetype } from '@whiskeysockets/baileys'
const id = 'abcd@s.whatsapp.net' // the WhatsApp ID const id = 'abcd@s.whatsapp.net' // the WhatsApp ID
// send a simple text! // send a simple text!
@@ -445,7 +445,7 @@ Sending media (video, stickers, images) is easier & more efficient than ever.
- When specifying a media url, Baileys never loads the entire buffer into memory; it even encrypts the media as a readable stream. - When specifying a media url, Baileys never loads the entire buffer into memory; it even encrypts the media as a readable stream.
``` ts ``` ts
import { MessageType, MessageOptions, Mimetype } from '@adiwajshing/baileys' import { MessageType, MessageOptions, Mimetype } from '@whiskeysockets/baileys'
// Sending gifs // Sending gifs
await sock.sendMessage( await sock.sendMessage(
id, id,
@@ -527,7 +527,7 @@ const sendMsg = await sock.sendMessage(id, templateMessage)
Do not enter this field if you want to automatically generate a thumb Do not enter this field if you want to automatically generate a thumb
*/ */
mimetype: Mimetype.pdf, /* (for media messages) specify the type of media (optional for all media types except documents), mimetype: Mimetype.pdf, /* (for media messages) specify the type of media (optional for all media types except documents),
import {Mimetype} from '@adiwajshing/baileys' import {Mimetype} from '@whiskeysockets/baileys'
*/ */
fileName: 'somefile.pdf', // (for media messages) file name for the media fileName: 'somefile.pdf', // (for media messages) file name for the media
/* will send audio messages as voice notes, if set to true */ /* will send audio messages as voice notes, if set to true */
@@ -586,7 +586,7 @@ The presence expires after about 10 seconds.
If you want to save the media you received If you want to save the media you received
``` ts ``` ts
import { writeFile } from 'fs/promises' import { writeFile } from 'fs/promises'
import { downloadMediaMessage } from '@adiwajshing/baileys' import { downloadMediaMessage } from '@whiskeysockets/baileys'
sock.ev.on('messages.upsert', async ({ messages }) => { sock.ev.on('messages.upsert', async ({ messages }) => {
const m = messages[0] const m = messages[0]

View File

@@ -1,36 +1,44 @@
{ {
"name": "@adiwajshing/baileys", "name": "@whiskeysockets/baileys",
"version": "5.0.0", "version": "5.2.0",
"description": "WhatsApp API", "description": "WhatsApp API",
"homepage": "https://github.com/adiwajshing/Baileys",
"main": "lib/index.js",
"types": "lib/index.d.ts",
"keywords": [ "keywords": [
"whatsapp", "whatsapp",
"js-whatsapp", "js-whatsapp",
"whatsapp-api", "whatsapp-api",
"whatsapp-web", "whatsapp-web",
"whatsapp",
"whatsapp-chat", "whatsapp-chat",
"whatsapp-group", "whatsapp-group",
"automation", "automation",
"multi-device" "multi-device"
], ],
"homepage": "https://github.com/WhiskeySockets/Baileys",
"repository": {
"url": "git@github.com:WhiskeySockets/Baileys.git"
},
"license": "MIT",
"author": "Adhiraj Singh",
"main": "lib/index.js",
"types": "lib/index.d.ts",
"files": [
"lib/*",
"WAProto/*",
"WASignalGroup/*.js"
],
"scripts": { "scripts": {
"test": "jest",
"prepare": "tsc",
"build:all": "tsc && typedoc", "build:all": "tsc && typedoc",
"build:docs": "typedoc", "build:docs": "typedoc",
"build:tsc": "tsc", "build:tsc": "tsc",
"changelog:last": "conventional-changelog -p angular -r 2",
"changelog:preview": "conventional-changelog -p angular -u",
"changelog:update": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0",
"example": "node --inspect -r ts-node/register Example/example.ts", "example": "node --inspect -r ts-node/register Example/example.ts",
"gen:protobuf": "sh WAProto/GenerateStatics.sh", "gen:protobuf": "sh WAProto/GenerateStatics.sh",
"lint": "eslint . --ext .js,.ts,.jsx,.tsx", "lint": "eslint . --ext .js,.ts,.jsx,.tsx",
"lint:fix": "eslint . --fix --ext .js,.ts,.jsx,.tsx" "lint:fix": "eslint . --fix --ext .js,.ts,.jsx,.tsx",
}, "prepare": "tsc",
"author": "Adhiraj Singh", "release": "release-it",
"license": "MIT", "test": "jest"
"repository": {
"url": "git@github.com:adiwajshing/baileys.git"
}, },
"dependencies": { "dependencies": {
"@hapi/boom": "^9.1.3", "@hapi/boom": "^9.1.3",
@@ -43,6 +51,27 @@
"protobufjs": "^6.11.3", "protobufjs": "^6.11.3",
"ws": "^8.0.0" "ws": "^8.0.0"
}, },
"devDependencies": {
"@adiwajshing/eslint-config": "https://github.com/adiwajshing/eslint-config.git",
"@adiwajshing/keyed-db": "^0.2.4",
"@types/got": "^9.6.11",
"@types/jest": "^27.5.1",
"@types/node": "^16.0.0",
"@types/sharp": "^0.29.4",
"@types/ws": "^8.0.0",
"conventional-changelog-cli": "^2.2.2",
"eslint": "^8.0.0",
"jest": "^27.0.6",
"jimp": "^0.16.1",
"link-preview-js": "^3.0.0",
"qrcode-terminal": "^0.12.0",
"release-it": "^15.10.3",
"sharp": "^0.30.5",
"ts-jest": "^27.0.3",
"ts-node": "^10.8.1",
"typedoc": "^0.22.0",
"typescript": "^4.0.0"
},
"peerDependencies": { "peerDependencies": {
"@adiwajshing/keyed-db": "^0.2.4", "@adiwajshing/keyed-db": "^0.2.4",
"jimp": "^0.16.1", "jimp": "^0.16.1",
@@ -57,38 +86,15 @@
"jimp": { "jimp": {
"optional": true "optional": true
}, },
"link-preview-js": {
"optional": true
},
"qrcode-terminal": { "qrcode-terminal": {
"optional": true "optional": true
}, },
"sharp": { "sharp": {
"optional": true "optional": true
},
"link-preview-js": {
"optional": true
} }
}, },
"files": [ "packageManager": "yarn@1.22.19"
"lib/*",
"WAProto/*",
"WASignalGroup/*.js"
],
"devDependencies": {
"@adiwajshing/eslint-config": "https://github.com/adiwajshing/eslint-config.git",
"@adiwajshing/keyed-db": "^0.2.4",
"@types/got": "^9.6.11",
"@types/jest": "^27.5.1",
"@types/node": "^16.0.0",
"@types/sharp": "^0.29.4",
"@types/ws": "^8.0.0",
"eslint": "^8.0.0",
"jest": "^27.0.6",
"jimp": "^0.16.1",
"link-preview-js": "^3.0.0",
"qrcode-terminal": "^0.12.0",
"sharp": "^0.30.5",
"ts-jest": "^27.0.3",
"ts-node": "^10.8.1",
"typedoc": "^0.22.0",
"typescript": "^4.0.0"
}
} }

2300
yarn.lock

File diff suppressed because it is too large Load Diff