Merge pull request #856 from automatisch/search-user-in-twitter
feat(twitter): add search user action
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
import createTweet from './create-tweet';
|
import createTweet from './create-tweet';
|
||||||
|
import searchUser from './search-user';
|
||||||
|
|
||||||
export default [createTweet];
|
export default [createTweet, searchUser];
|
||||||
|
@@ -0,0 +1,30 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Search user',
|
||||||
|
key: 'searchUser',
|
||||||
|
description: 'Search a user on Twitter',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Username',
|
||||||
|
key: 'username',
|
||||||
|
type: 'string' as const,
|
||||||
|
required: true,
|
||||||
|
description: 'The username of the Twitter user you want to search for',
|
||||||
|
variables: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const { data } = await $.http.get(`/2/users/by/username/${$.step.parameters.username}`, {
|
||||||
|
params: {
|
||||||
|
expansions: 'pinned_tweet_id',
|
||||||
|
'tweet.fields': 'attachments,author_id,context_annotations,conversation_id,created_at,edit_controls,entities,geo,id,in_reply_to_user_id,lang,non_public_metrics,public_metrics,organic_metrics,promoted_metrics,possibly_sensitive,referenced_tweets,reply_settings,source,text,withheld',
|
||||||
|
'user.fields': 'created_at,description,entities,id,location,name,pinned_tweet_id,profile_image_url,protected,public_metrics,url,username,verified,verified_type,withheld'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data.data
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
@@ -1,4 +1,5 @@
|
|||||||
import { Token } from 'oauth-1.0a';
|
import { Token } from 'oauth-1.0a';
|
||||||
|
import { URLSearchParams } from 'node:url';
|
||||||
import { IJSONObject, TBeforeRequest } from '@automatisch/types';
|
import { IJSONObject, TBeforeRequest } from '@automatisch/types';
|
||||||
import oauthClient from './oauth-client';
|
import oauthClient from './oauth-client';
|
||||||
|
|
||||||
@@ -9,15 +10,24 @@ type RequestDataType = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const addAuthHeader: TBeforeRequest = ($, requestConfig) => {
|
const addAuthHeader: TBeforeRequest = ($, requestConfig) => {
|
||||||
const { url, method, data } = requestConfig;
|
const { baseURL, url, method, data, params } = requestConfig;
|
||||||
|
|
||||||
const token: Token = {
|
const token: Token = {
|
||||||
key: $.auth.data?.accessToken as string,
|
key: $.auth.data?.accessToken as string,
|
||||||
secret: $.auth.data?.accessSecret as string,
|
secret: $.auth.data?.accessSecret as string,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const searchParams = new URLSearchParams(params);
|
||||||
|
const stringifiedParams = searchParams.toString();
|
||||||
|
let fullUrl = `${baseURL}${url}`;
|
||||||
|
|
||||||
|
// append the search params
|
||||||
|
if (stringifiedParams) {
|
||||||
|
fullUrl = `${fullUrl}?${stringifiedParams}`;
|
||||||
|
}
|
||||||
|
|
||||||
const requestData: RequestDataType = {
|
const requestData: RequestDataType = {
|
||||||
url: `${requestConfig.baseURL}${url}`,
|
url: fullUrl,
|
||||||
method,
|
method,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -3,6 +3,9 @@ favicon: /favicons/twitter.svg
|
|||||||
items:
|
items:
|
||||||
- name: Create Tweet
|
- name: Create Tweet
|
||||||
desc: Create a tweet.
|
desc: Create a tweet.
|
||||||
|
items:
|
||||||
|
- name: Search User
|
||||||
|
desc: Search a user.
|
||||||
---
|
---
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
|
Reference in New Issue
Block a user