airtable
Add context to all requests
Um pacote #Golang simples para acessar a API Airtable.
A API Airtable Golang foi testada compatível com o GO 1.13 no UP.
go get github.com/mehanizm/airtable
Você deve obter your_api_token
na página da conta Airtable
client := airtable . NewClient ( "your_api_token" )
Você pode usar o cliente HTTP personalizado aqui
client . SetCustomClient ( http . DefaultClient )
Cada método abaixo pode ser usado com contexto personalizado. Simplesmente use MethodNameContext
Ligue e forneça o contexto como primeiro argumento.
bases , err := client . GetBases (). WithOffset ( "" ). Do ()
schema , err := client . GetBaseSchema ( "your_database_ID" ). Do ()
Para obter o your_database_ID
, você deve acessar a página da API principal e selecionar o banco de dados.
table := client . GetTable ( "your_database_ID" , "your_table_name" )
Para obter registros da tabela, você pode usar algo assim
records , err := table . GetRecords ().
FromView ( "view_1" ).
WithFilterFormula ( "AND({Field1}='value_1',NOT({Field2}='value_2'))" ).
WithSort ( sortQuery1 , sortQuery2 ).
ReturnFields ( "Field1" , "Field2" ).
InStringFormat ( "Europe/Moscow" , "ru" ).
Do ()
if err != nil {
// Handle error
}
recordsToSend := & airtable. Records {
Records : [] * airtable. Record {
{
Fields : map [ string ] any {
"Field1" : "value1" ,
"Field2" : true ,
},
},
},
}
receivedRecords , err := table . AddRecords ( recordsToSend )
if err != nil {
// Handle error
}
record , err := table . GetRecord ( "recordID" )
if err != nil {
// Handle error
}
Para atualizar parcial um registro
res , err := record . UpdateRecordPartial ( map [ string ] any { "Field_2" : false })
if err != nil {
// Handle error
}
Para registros completos de atualização
toUpdateRecords := & airtable. Records {
Records : [] * airtable. Record {
{
Fields : map [ string ] any {
"Field1" : "value1" ,
"Field2" : true ,
},
},
{
Fields : map [ string ] any {
"Field1" : "value1" ,
"Field2" : true ,
},
},
},
}
updatedRecords , err := table . UpdateRecords ( toUpdateRecords )
if err != nil {
// Handle error
}
res , err := record . DeleteRecord ()
if err != nil {
// Handle error
}
Para excluir até 10 registros
records , err := table . DeleteRecords ([] string { "recordID1" , "recordsID2" })
if err != nil {
// Handle error
}
Inspirado pela API Go Trello