Skip to content

Instantly share code, notes, and snippets.

@sofyan-ahmad
sofyan-ahmad / aws-amplify-react-native.d.ts
Last active Mar 24, 2021
aws amplify react native typescript definition
View aws-amplify-react-native.d.ts
declare module 'aws-amplify-react-native' {
const Amplify: any;
export default Amplify;
// *** UI ***
interface ITheme {
container: {};
section: {};
sectionHeader: {};
sectionHeaderText: {};
@sofyan-ahmad
sofyan-ahmad / YourModel.js
Created Mar 24, 2021
Strapi.io - Cache strapi on service level
View YourModel.js
// strapi/api/${YourModel}/services/${YourModel}
const crypto = require('crypto');
const redisClient = require('../../../cache/redis');
const sendNotification = require('./notification');
/**
* Read the documentation (https://strapi.io/documentation/v3.x/concepts/services.html#core-services)
* to customize this service
*/
@sofyan-ahmad
sofyan-ahmad / permissions.js
Created Mar 24, 2021
Strapi.io - cache graphql query request with custom api token and check user permission before return value from cache
View permissions.js
// strapi/extensions/users-permissions/config/policies/permissions.js
const _ = require('lodash');
const crypto = require('crypto');
const redisClient = require('../../../../cache/redis');
const handleErrors = (ctx, err = undefined, type) => {
throw strapi.errors[type](err);
};
@sofyan-ahmad
sofyan-ahmad / authStorage.ts
Last active Feb 3, 2021
AWS Amplify Custom Asyncstorage
View authStorage.ts
import {Auth} from 'aws-amplify';
import AsyncStorage from '@react-native-community/async-storage';
import {ICognitoStorage} from 'amazon-cognito-identity-js';
const MEMORY_KEY_PREFIX = '@fcAuth:';
let dataMemory = {};
const syncPromise: Promise<any> = null;
/**
* This is used to set a specific item in storage
View Install protobuf 3 on Ubuntu
# Make sure you grab the latest version
curl -OL https://github.com/google/protobuf/releases/download/v3.2.0/protoc-3.2.0-linux-x86_64.zip
# Unzip
unzip protoc-3.2.0-linux-x86_64.zip -d protoc3
# Move protoc to /usr/local/bin/
sudo mv protoc3/bin/* /usr/local/bin/
# Move protoc3/include to /usr/local/include/
View googleSheet.service.ts
import {HttpException, Injectable} from '@nestjs/common';
import {google} from 'googleapis';
import {GoogleApiService} from '../googleApi/googleApi.service';
@Injectable()
export class GoogleSheetService {
constructor(private readonly googleApiService: GoogleApiService) {}
async readSheet(): Promise<any[]> {
View googleApi.controller.ts
import {Body, Controller, Get, Post, Render} from '@nestjs/common';
import {GoogleApiService} from './googleApi.service';
@Controller()
export class GoogleApiController {
constructor(private readonly service: GoogleApiService) {}
@Get('authorize')
@Render('main')
View googleApi.service.ts
import {HttpException, Injectable} from '@nestjs/common';
import {Credentials, OAuth2Client} from 'google-auth-library';
import {google} from 'googleapis';
import _ from 'lodash';
import fs from 'fs';
import util from 'util';
import credentialsJson from '../../../credentials.json';
import {IGoogleToken} from './googleToken.interface';
View uploadViews.vue
<template>
<div>
<dropzone
ref="product-image"
v-model="tempProductData.image"
:label="$t('table.image')"
:signed-api="signedAPIRequest"
/>
<el-button @click="uploadImage">Upload</el-button>
View apiClient.ts
import axios from 'axios';
export const getSignedURL = async (
url: string,
file: File
): Promise<{ fileName: string; s3Url: string }> => {
try {
const endpoint = url;
const payload = {
filePath: file.name,