NocoDB
✨ L'alternativa Open Source ad Airtable ✨

Trasforma qualsiasi MySQL, PostgreSQL, SQL Server, SQLite & Mariadb in un foglio di calcolo intelligente.

[![Build Status](https://travis-ci.org/dwyl/esta.svg?branch=master)](https://travis-ci.com/github/NocoDB/NocoDB) [![Node version](https://badgen.net/npm/node/next)](http://nodejs.org/download/) [![Twitter](https://img.shields.io/twitter/url/https/twitter.com/NocoDB.svg?style=social&label=Follow%20%40NocoDB)](https://twitter.com/NocoDB)

Sito WebDiscordTwitter

![OpenSourceAirtableAlternative](https://user-images.githubusercontent.com/5435402/133762127-e94da292-a1c3-4458-b09a-02cd5b57be53.png) NocoDB - The Open Source Airtable alternative | Product Hunt # Prova veloce ### 1-Click Deploy #### Heroku Deploy NocoDB to Heroku with 1-Click
### Con Docker. ```bash docker run -d --name nocodb -p 8080:8080 nocodb/nocodb:latest ``` > Per rendere persistenti i dati puoi montare il volume su `/usr/app/data/`. ### Con NPM. ``` npx create-nocodb-app ``` ### Con git. ``` git clone https://github.com/nocodb/nocodb-seed cd nocodb-seed npm install npm start ``` ### GUI Accedi al Pannello di Controllo visitando: [http://localhost:8080/dashboard](http://localhost:8080/dashboard) # Unisciti alla nostra comunità Unisciti a NocoDB: Una alternativa Gratuita e Open Source ad Airtable
# Screenshots ![1](https://user-images.githubusercontent.com/86527202/136069047-e9090ea1-c95b-4ae5-9897-b48cab1ea3ab.png)
![2](https://user-images.githubusercontent.com/86527202/136069059-fb225bc4-0dac-439c-9a31-e21d02097427.png)
![5](https://user-images.githubusercontent.com/86527202/136069065-b2371359-7fff-420f-90d1-16e41b52b757.png)
![6](https://user-images.githubusercontent.com/86527202/136069070-df63e1d6-ecdf-4423-989f-51cc9f52e52a.png)
![7](https://user-images.githubusercontent.com/86527202/136069076-b32cdacf-5cb8-44ee-b8fe-4279ec1b4308.png)
![8](https://user-images.githubusercontent.com/86527202/136069078-08b5c09d-b2bd-4cc0-8c92-1d08c46e5f83.png)
![9](https://user-images.githubusercontent.com/86527202/136069081-15dad5b6-dd2c-472d-b4b7-9fdf5e00b0e8.png)
![9a](https://user-images.githubusercontent.com/86527202/136069084-31134cb0-d9b3-441f-ae29-9ff11ee1c45b.png)
![9b](https://user-images.githubusercontent.com/86527202/136069085-770cb6a4-6273-4edd-9382-01e46f59bc3b.png)
![10](https://user-images.githubusercontent.com/86527202/136069088-dba928db-d92a-4ff2-bb05-614becd208a1.png)
![11](https://user-images.githubusercontent.com/86527202/136069091-16764d3e-1995-4a45-99e8-652f28d2a946.png)
# Caratteristiche ### Interfaccia a foglio di calcolo - ⚡ Ricerca, ordina, filtra, nascondi le colonne con super facilità - ⚡ Crea Views: Griglie, Gallerie, Kanban, Gantt, Form - ⚡ Condividi Views: Pubbliche o protette da password - ⚡ Views personali o bloccate - ⚡ Carica immagini nelle celle (funziona con S3, Minio, GCP, Azure, Digitalocean, Linode, OVH, BackBlaze) !! - ⚡ Ruoli: proprietario, creatore, editor, commentatore, visualizzatore, commentatore o ruoli personalizzati. - ⚡ Controllo accessi: controllo di accesso anche a livello di database, tabella e colonna. ### App store per automazioni del flusso di lavoro: - ⚡ Chat: Microsoft Teams, Slack, Discord, Mattermost - ⚡ Email: SMTP, SES, MailChimp - ⚡ SMS: Twilio - ⚡ Whatsapp - ⚡ Qualsiasi API di terze parti ### Accesso API programmatico tramite: - ⚡ REST APIs (Swagger) - ⚡ APIs GraphQL. - ⚡ Include autenticazione JWT e AUTH - ⚡ API Token da integrare con Zapier, Integromat. # Impostazione in produzione NOCODB richiede un database per memorizzare i metadati delle viste dei fogli di calcolo e dei database esterni. I parametri di connessione per questo database possono essere specificati nella variabile di ambiente NC_DB. ## Docker #### Esempio con MySQL ``` docker run -d -p 8080:8080 \ -e NC_DB="mysql2://host.docker.internal:3306?u=root&p=password&d=d1" \ -e NC_AUTH_JWT_SECRET="569a1821-0a93-45e8-87ab-eb857f20a010" \ nocodb/nocodb:latest ``` #### Esempio con Postgres ``` docker run -d -p 8080:8080 \ -e NC_DB="pg://host:port?u=user&p=password&d=database" \ -e NC_AUTH_JWT_SECRET="569a1821-0a93-45e8-87ab-eb857f20a010" \ nocodb/nocodb:latest ``` #### Esempio con SQL Server ``` docker run -d -p 8080:8080 \ -e NC_DB="mssql://host:port?u=user&p=password&d=database" \ -e NC_AUTH_JWT_SECRET="569a1821-0a93-45e8-87ab-eb857f20a010" \ nocodb/nocodb:latest ``` ## Docker Compose ``` git clone https://github.com/nocodb/nocodb cd docker-compose cd mysql or pg or mssql docker-compose up ``` ## Variabili d'ambiente | Variabile | Obbligatoria | Descrizione | Se assente | |-------------------------|-----------|----------------------------------------------------------------------------------|--------------------------------------------| | NC_DB | Si | Visualizza gli URLs del nostro database. | Un BD SQLite verrà creato nella cartella principale | | DATABASE_URL | No | Formato URL JDBC. Può essere utilizzato in alternativa a NC_DB. Utilizzato nell'installazione 1-Click con Heroku| | | DATABASE_URL_FILE | No | Path per i file contenenti gli URL JDBC. Può essere utilizzato in alternativa a NC_DB. Utilizzato nell'installazione 1-Click con Heroku| | | NC_PUBLIC_URL | Si | Per inviare inviti via mail | Autogenerato dai parametri delle richieste http | | NC_AUTH_JWT_SECRET | Si | Segreto JWT utilizzato per l'autenticazione e la memorizzazione di altri segreti | Sarà generato un segreto in maniera randomica | | NC_SENTRY_DSN | No | Per il monitoraggio con Sentry | | | NC_CONNECT_TO_EXTERNAL_DB_DISABLED | No | Disabilita la creazione di Progetti con database esterni | | | NC_DISABLE_TELE | No | Disabilita la telemetria | | | NC_BACKEND_URL | No | URL di Backend Personalizzato | Sarà utilizato ``http://localhost:8080`` | # Setup di sviluppo ``` git clone https://github.com/nocodb/nocodb cd nocodb # run backend cd packages/nocodb npm install npm run watch:run # apre localhost:8080/dashboard nel browser # run frontend cd packages/nc-gui npm install npm run dev # apre localhost:3000/dashboard nel browser ``` Modifiche al codice generano un riavvio automatico. ## Utilizzare i test Cypress in locale ```shell # installa le dipendenze (Cypress) npm install # esegui i servizi richiesti con Docker Compose docker-compose -f ./docker-compose-cypress.yml up # attendi la disponibilità delle porte 3000 e 8080 # ed esegui Cypress con il seguente comando: npm run cypress:run # o esegui questo comando per avviarlo con l'interfaccia grafica npm run cypress:open ``` # Contributi - Leggi ./scripts/contribute/HowToApplyLicense.md - Ignora l'aggiunta di header per .json, .md o .yml # 🎯 Perché lo abbiamo creato? La maggior parte delle aziende utilizza fogli di calcolo o database per le proprie esigenze aziendali. I fogli di calcolo vengono utilizzati da oltre un miliardo di persone in modo collaborativo ogni singolo giorno. Tuttavia, i database che sono strumenti molto più potenti quando si tratta di elaborazione. I tentativi di risolvere questo problema con le offerte SaaS hanno significato orribili controlli di accesso, blocco del fornitore, blocco dei dati, brusche variazioni di prezzo e, soprattutto, un soffitto di vetro su ciò che è possibile in futuro. # ❤ La nostra missione: La nostra missione è creare la più potente interfaccia per database "senza codice", disponibile a codice libero per ogni azienda nel mondo. Lo facciamo non solo per democratizzare l'accesso ad un potente strumento di elaborazione, ma anche per supportare i miliardi di persone che creano e costruiscono su Internet.