Skip to content

Instantly share code, notes, and snippets.

@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 / 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: {};
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';
@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 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,
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 uploadZone.vue
<template>
<div class="upload-container">
<el-upload
v-show="!imageUrl"
ref="uploadZone"
class="image-uploader"
drag
:multiple="false"
:show-file-list="false"
:auto-upload="false"