Giter Site home page Giter Site logo

crowdin / crowdin-apps-functions Goto Github PK

View Code? Open in Web Editor NEW
6.0 6.0 3.0 1.63 MB

Common functions used by Crowdin Apps

Home Page: https://support.crowdin.com/crowdin-apps/

License: MIT License

Shell 0.12% TypeScript 98.71% JavaScript 1.18%
crowdin apps app helper

crowdin-apps-functions's Introduction

Crowdin Apps Functions library

Lightweight library with utility functions to help you quickly create your own Crowdin App.

Information about Crowdin Apps can be found in the About Crowdin Apps and in the Quick Start guide.

npm npm CI codecov GitHub Release Date GitHub contributors License

Table of Contents

Installation

npm

npm i @crowdin/crowdin-apps-functions

yarn

yarn add @crowdin/crowdin-apps-functions

Quick Start

Typescript
import { generateOAuthToken } from '@crowdin/crowdin-apps-functions';

generateOAuthToken({ clientId: 'app_client_id', clientSecret: 'app_client_secret', code: 'code_from_install_event'});
Javascript ES6 modules
import { generateOAuthToken } from '@crowdin/crowdin-apps-functions';

generateOAuthToken({ clientId: 'app_client_id', clientSecret: 'app_client_secret', code: 'code_from_install_event'});
Javascript CommonJS
const crowdinFunctions = require('@crowdin/crowdin-apps-functions');

crowdinFunctions.generateOAuthToken({ clientId: 'app_client_id', clientSecret: 'app_client_secret', code: 'code_from_install_event'});

Functions summary

Mainly all functions are intended to help you quickly develop your app but they also can reduce some work when you are integrating with Crowdin API. Please refer to JSDoc for more details.

Method name Description
fetchAppToken fetch API token for communication with Crowdin API
generateOAuthToken generates OAuth token for communication with Crowdin API
refreshOAuthToken refresh OAuth token in case if it was expired
constructCrowdinIdFromJwtPayload creates unique id of crowdin user and project from the context
getProjectId extracts project id from crowdin id
validateJwtToken validates if jwt token for your app is valid
updateOrCreateFile create or update file in Crowdin
getFolder get folder with and files under it
getOrCreateFolder get folder with files under it or create it
uploadTranslations adds file to storage and sends it in upload translation request
updateSourceFiles updates source files under specific directory
handleTranslations executes side effect function for each translated file
createOrUpdateWebhook create or update webhook
getSubscription returns an information about app subscription
convertString converts source or translation according to specified config
getBundleConfigurationForm returns UI template config for custom formatters
generateReport generates Crowdin report, covers check if finished

Also please have a look to working example of the Crowdin App. It can be used as a basis for your app.

Contributing

If you want to contribute please read the Contributing guidelines.

Seeking Assistance

If you find any problems or would like to suggest a feature, please feel free to file an issue on Github at Issues Page.

If you've found an error in these samples, please Contact Customer Success Service.

License

The Crowdin Apps Functions library is licensed under the MIT License. 
See the LICENSE.md file distributed with this work for additional 
information regarding copyright ownership.

Except as contained in the LICENSE file, the name(s) of the above copyright
holders shall not be used in advertising or otherwise to promote the sale,
use or other dealings in this Software without prior written authorization.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.