
Security News
Attackers Are Hunting High-Impact Node.js Maintainers in a Coordinated Social Engineering Campaign
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.
@marxa/storage
Advanced tools
Una librería pa' trepar archivos **Firesbase Storage** y para importar y exportar bases de datos a **Firesbase Firestore** desde Angular
Una librería pa' trepar archivos Firesbase Storage y para importar y exportar bases de datos a Firesbase Firestore desde Angular
A library to upload files to Firesbase Storage and import and export data bases for Firesbase Firestore from Angular
| :exclamation: IMPORTANTE :exclamation: |
|---|
| This documentation is writed in mexican spanish for latin developers for motivate to they always read software documentation. But you always can count on the cunning of google translate XD. |
This library was generated with Angular CLI version 11.0.9.
Esta librería sólo chambea con Angular Material y Angular Fire para Firebase.
Sigue los siguientes pasos para crear un proyecto que combine Firebase + Angular:
src/environments/environment.ts y pega el código que has creado como se muestra el ejemplo de abajo. export const environment = {
production: false,
firebaseConfig: {
apiKey: "AIzaS++++++++++++++++++++++++++",
authDomain: "++++++++.firebaseapp.com",
projectId: "++++++++",
storageBucket: "+++++++++.appspot.com",
messagingSenderId: "0000000000",
appId: "1:000000000000:web:++++++++++++++",
measurementId: "G-++++++++++"
}
};
Corre los siguientes comandos en tu consola y sigue las instrucciones de cada CLI:
ng add @angular/fire
ng add @angular/material
En app.module.ts inicializa tu proyecto de firebase, no se te vaya a olvidar:
import { AngularFireModule } from "@angular/fire";
@NgModule({
declarations: [],
imports: [
AngularFireModule.initializeApp(environment.firebaseConfig)
],
})
export class AppModule {}
¿Listo? ¡A huevo! Ya puedes instalar esta librería corriendo el comando npm i @marxa/storage -s.
Para usar la librería tienes que agregar el módulo de la librería al imports del módulo de tu proyecto de Angular donde vayas a usarlo.
import { AngularFireModule } from "@angular/fire";
import { MxStorageModule } from '@marxa/storage';
@NgModule({
declarations: [],
imports: [
MxStorageModule,
//No se te olvide inicializar tu app de AngularFire
AngularFireModule.initializeApp(environment.firebaseConfig)
],
})
export class AppModule {}
Esta librería cuenta con un Files Picker donde el cliente puede dar click o arrastrar los archivos para agregarlos y luego subirlos a Firebase Storage. Este componente tiene la especial colaboración de NgxDropzone
| :exclamation: Antes de empezar |
|---|
| En tu proyecto de firebase, si no has creado un valde (bucket) pa' cargar todas las cosas, ve a la sección y pícale al botón de Comenzar |
<mx-files-picker
[maxFileSize]="2097152"
path="cosas"
prefixName="marxa-"
[metadata]="{autor: 'yomero'}"
toggleButtonLabel="Cargar archivos"
[multiple]="false"
dropzoneLabel="Toca o arrastra un archivo hasta aquí"
uploadButtonLabel="Subir"
color="primary"
></mx-files-picker>
En veces, necesitas que el diseño no te estorbe. Para esas ocasiones puedes usar el modo Modal el cual tendrá el mismo efecto.
<mx-files-picker
color="primary"
[openModal]="true"
></mx-files-picker>
Cuando necesites tener control de la subida de los datos, puedes quitar el botón disparador de subida y usar el Service que te permita ejecutar el disparador y tener control observable del evento.
<mx-files-picker
color="primary"
[uploadButton]="false"
></mx-files-picker>
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent implements OnDestroy {
constructor(
private _storage: MxStorage
) { }
onUpload(){
this._storage.upload().subscribe( (files:iUploadedFile[]) => {
console.log(files)
})
}
}
| :exclamation: Importante |
|---|
| En caso de que quieras acceder a los archivos listos para subirse puedes acceder a través del servicio |
Ahora se muestra la tabla de opciones con las que cuenta el Files Picker.
| Atributo | Descripción |
|---|---|
@Input() path: string | Permite crear rutas o carpetas donde se guardarán los archivos |
@Input() prefixName: string | Agrega un prefijo al nombre del archivo trepado |
@Input() metadata?: Object | (Opcional) Si lo agregas, debe ser un objeto con la metadata que quieras o necesites |
@Input() multiple: boolean | Default: false Permite cargar varios archivos a la vez en el Dropzone |
@Input() maxFileSize?: number | (Opcional) Evita que se suban archivos muy pesados agregando los bytes que quieres limitar. Ej. 2Mb = 2097152b |
@Input() showDropzone: boolean = false | Default: false Muestra el dropzone desde un principio y omite el botón de mostrar dropzone |
@Input() uploadButton: boolean | Default: true Muestra u oculta el botón disparador de subida de archivos |
@Input() uploadStatus: boolean | Default: true Muestr u oculta la barra de status del archivo subido |
@Input() toggleButtonLabel: string | Default: 'Subir archivos' Mensaje que se muestra en el botón que muestra el Dropzone |
@Input() uploadButtonLabel: string | Default: 'Subir' Mensaje que se muestra en el botón que sube los archivos |
@Input() dropzoneLabel: string | Default: 'Arrastra los archivos o toca aquí' Mensaje que se muestra dentro del Dropzone |
@Input() disable: boolean | Default: false Deshabilita el botón de subida de archivos. Perfecto para validar si no se han subido archivos |
@Input() color: 'primary', 'accent' o 'warn' | Default: 'primary' Basado en Angular Material Color Palette muestra el botón de subida de archivos depende el color seleccionado |
@Input() openModal: boolean | Default: false Define si se abrirá el dropzone en el lugar del botón o en un modal |
@Output() uploadComplete: iUploadedFile[] | Informa cuando terminó de subir todos los archivos y entrga un array con la información de archivos subidos. |
@Output() onLoaded: void | Informa cuando los archivos fueron cargados en el dropzone |
Este componente importa los datos de un archivo CSV a la base de datos de Firestore agregando cada fila como un documento de la colección.
| :exclamation: Antes de empezar |
|---|
| Si quieres que esto funcione. Debes tener inicializada tu base de datos de Firestore en proyecto. |
| :warning: CUIDADO |
|---|
| Subir los registros de un CSV te costará 1 registro de escritura de la Firestore por cada 500 filas en tu documento. Peeeero... |
| Si mandas llamar la colección que subiste te costará la cantidad total de la colección de registros de lectura de la Firestore de los cuales 14k son gratuitos, de esa cantidad en adelante puede costarte mucho dinero estar llamando esta colección de documentos. |
Supongamos que vas a subir una lista de productos a una E-commerce.
<mx-import-file
[requiredColumns]="needColumns"
[importCol]="'productos'"
[idField]="'referencia'"
[renameColumns]="false"
></mx-import-file>
requiredColumns.importCol.idField. OJO: Los campos de la columna que selecciones serán transfromados a lowerCase, se cambiarán los espacios, comas, puntos, diagonales, arrobas y guiones medios por guiones bajos (_) y se omitirán comillas| :eye: CUIDADO |
|---|
| Los archivos deben subirse en CSV, sin filas de encabezado o títulos. La primera fila debe ser la de los nombres de las columnas. |
Para exportar colecciones de Firestorea un archivo CSV, sigue los siguientes pasos:
downloadListimport { AngularFirestore } from '@angular/fire/firestore';
import { MxStorage } from '@marxa/storage';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent implements OnDestroy {
constructor(
private _afs: AngularFirestore,
private _storage: MxStorage
) { }
async onDownload(){
let list: any[] = [];
const collection = await this._afs.collection('collection').get()
// Si tu lista no es muy larga puedes usar el básico forEach
collection.forEach(item => {
list.push(item.data())
})
// De lo contrario, MxStorage cuenta con un iterador asíncrono
await this._storage.asynForEach(list, (item: any) => {
list.push(item.data())
})
this._storage.downloadList(list)
// Esto automáticamente descargará el archivo en tu dispositivo
}
}
Información del archivo cargado a Firebase Storage
| Propiedad | Descripción |
|---|---|
fileName?: string | Optional Muestra el nombre con el cual fue cargado el archivo |
uploaded?: Date | firebase.firestore.Timestamp |
metadata?: any | Optional El objeto cargado como metadata |
format?: string | Optional Formato del archivo cargado. Ejemplo: 'image/jpg' |
Se extienda a iUploadInfo Resultado del archivo cargado a Firebase Storage
| Propiedad | Descripción |
|---|---|
url?: string | La url con la cual acceder al archivo en Storage |
uploadedState?: number o true | No'más sirve para el momento de estar cargando |
| Propiedad | Descripción |
|---|---|
files: any[] | Los archivos que han de subirse |
recordsLength: number | La cantidad de filas del documento CSV que se importará a Firestore |
headerMap: Map<string, string> | Map de las columnas del documento CSV que se importará a Firestore. El primer string corresponde al valor original y el segundo al que se ha de transformar |
mergeImport: boolean | Default: true Controla si al subir filas, el valor es true y el documento tiene el mismo ID, los datos del documento no se borrarán, sólo se actualizarán los campos existentes en el documento. Si no existen los creará. De lo contrario, si es false se borrarán los campos anteriores y se sustituirán por los nuevos. |
RawHeaderList(): Observable<string[]> | Método get que provee un observable de la lista de nombres de las columnas del archivo CSV que se cargará. Retorna una observable con la lista de nombres de las columnas |
| Observable | Descripción |
|---|---|
fileUploadedStatus$: Subject<iUploadedFile> | Notifica el status del archivo que se está subiendo en el momento |
upload$: Subject<void> | Notifica cuando cuando se ha solicitado subir los archivos |
uploadComplete$: Subject<iUploadedFile[]> | Notifica cuando los archivos se han cargado y los muestra en un array |
clearDropzone$: Subject<void> | Le notifica al dropzone que debe cerrarse |
closeImportDialog$: Subject<void> | Le notifica al modal que debe cerrarse |
closeSpinner$: Subject<void> | Le notifica al spinner que debe cerrarse |
importState$: BehaviorSubject<string> | Notifica el estado de la importación |
recordsReaded$: BehaviorSubject<number> | Notifica cuantos registros se han cargado a Firestore |
upload()Ejecuta el ciclo de subir los archivos en MxStorage.files: any[]
uploadFile(file, path, prefixName?, metadata?): Observable<iUploadedFile>Sube un único archivo y retorna un observable con el archivo cargado.
| Parámetro | Descripción |
|---|---|
file: any | Archivo nativo |
path: string | La ruta donde será almacenada dentro del bucket de Firebase Storage |
| prefixName: `string | null` |
metadata: any | (Opcional) Si este parámetro se asigna se agrega a la metadata del archivo. DEBE SER OBJETO |
deleteFiles(files, path?): Promise<void> Método para eliminar archivos del Storage returna una promsea vacía
| Parámetro | Descripción |
|---|---|
files: iUploadInfo[] | Arreglo de archivos en la forma de interface iUploadInfo |
path: string | (Opcional) Si no se especifica, se toma de la interface iUploadInfo, Ruta del archivo a eliminarse |
asyncForEach(array, callback): Promise<void>Método para iterar arreglos de manera asíncrona. Retorna una promsea vacía
| Parámetro | Descripción |
|---|---|
array: any[] | Un arreglo cualquiera |
callbarck: any | Función que se realizará por cada elemento del array, Proporciona las propiedades value y index |
downloadList(list, filename): Promise<void>Método para descargar un array de objetos en formato CSV. Los objetos anidados obtendrán el nombre del objeto padre.hijo. Sólo permite 3 niveles de objetos anidados.
| Parámetro | Descripción |
|---|---|
list: any[] | Cualquier array de objetos |
filename: string | Nombre del archivo al descargarse |
getRawValue(value): ObjectMétodo que extrae objetos anidados a un sólo objeto. Sólo permite 3 niveles de objetos anidados.
| Parámetro | Descripción |
|---|---|
value: any | Objeto cualquiera |
importFile(collection?, idField?, mergeImport?): Promise<void>Método para importar archivos CSV a Firestore. Retorna una promsea vacía
| Parámetro | Descripción |
|---|---|
collection: string | (Opcional) El nombre de la colección a la que se importará. Si no se provee este parámetro se creará una colección llamada 'imports'. |
idField: string | (Opcional) Nombre de la columna del archivo que servirá para marcar como id cada documento en la colección. NOTA: Si el id del documento resultante existe en la colección, el documento se actualizará. El id será transformado a lowerCase, cambiando espacios, puntos, comas, diagonales, arrobas y guiones medios por guiones bajos (_) y eliminado las comillas. |
mergeImport: boolean | (Opcional, Default: true) Controla si al subir filas, el valor es true y el documento tiene el mismo ID, los datos del documento no se borrarán, sólo se actualizarán los campos existentes en el documento. Si no existen los creará. De lo contrario, si es false se borrarán los campos anteriores y se sustituirán por los nuevos. |
Email: jguzman@marxadigital.com
FAQs
Una librería pa' trepar archivos **Firesbase Storage** y para importar y exportar bases de datos a **Firesbase Firestore** desde Angular
We found that @marxa/storage demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.