[{"data":1,"prerenderedAt":1992},["ShallowReactive",2],{"navigation_docs":3,"-docs-guides-sdks":82,"-docs-guides-sdks-surround":1988},[4,9,40,61],{"title":5,"path":6,"stem":7,"order":8},"Changelog","\u002Fdocs\u002Fchangelog","docs\u002F4.changelog",4,{"title":10,"path":11,"stem":12,"children":13,"page":39},"Api","\u002Fdocs\u002Fapi","docs\u002Fapi",[14,18,22,26,30,34],{"title":15,"path":16,"stem":17},"Overview","\u002Fdocs\u002Fapi\u002Foverview","docs\u002Fapi\u002F1.overview",{"title":19,"path":20,"stem":21},"Quotes","\u002Fdocs\u002Fapi\u002Fquotes","docs\u002Fapi\u002F2.quotes",{"title":23,"path":24,"stem":25},"Authors","\u002Fdocs\u002Fapi\u002Fauthors","docs\u002Fapi\u002F3.authors",{"title":27,"path":28,"stem":29},"Playlists","\u002Fdocs\u002Fapi\u002Fplaylists","docs\u002Fapi\u002F4.playlists",{"title":31,"path":32,"stem":33},"Categories","\u002Fdocs\u002Fapi\u002Fcategories","docs\u002Fapi\u002F5.categories",{"title":35,"path":36,"stem":37,"order":38},"API Reference","\u002Fdocs\u002Fapi\u002F_dir","docs\u002Fapi\u002F_dir",3,false,{"title":41,"path":42,"stem":43,"children":44,"page":39},"Getting Started","\u002Fdocs\u002Fgetting-started","docs\u002Fgetting-started",[45,49,53,57],{"title":46,"path":47,"stem":48},"Introduction","\u002Fdocs\u002Fgetting-started\u002Fintroduction","docs\u002Fgetting-started\u002F1.introduction",{"title":50,"path":51,"stem":52},"Authentication","\u002Fdocs\u002Fgetting-started\u002Fauthentication","docs\u002Fgetting-started\u002F2.authentication",{"title":54,"path":55,"stem":56},"Quick Start","\u002Fdocs\u002Fgetting-started\u002Fquickstart","docs\u002Fgetting-started\u002F3.quickstart",{"title":41,"path":58,"stem":59,"order":60},"\u002Fdocs\u002Fgetting-started\u002F_dir","docs\u002Fgetting-started\u002F_dir",1,{"title":62,"path":63,"stem":64,"children":65,"page":39},"Guides","\u002Fdocs\u002Fguides","docs\u002Fguides",[66,70,74,78],{"title":67,"path":68,"stem":69},"Rate Limits & Pricing","\u002Fdocs\u002Fguides\u002Frate-limits","docs\u002Fguides\u002F1.rate-limits",{"title":71,"path":72,"stem":73},"Error Handling","\u002Fdocs\u002Fguides\u002Ferror-handling","docs\u002Fguides\u002F2.error-handling",{"title":75,"path":76,"stem":77},"SDKs & Libraries","\u002Fdocs\u002Fguides\u002Fsdks","docs\u002Fguides\u002F3.sdks",{"title":62,"path":79,"stem":80,"order":81},"\u002Fdocs\u002Fguides\u002F_dir","docs\u002Fguides\u002F_dir",2,{"id":83,"title":75,"body":84,"description":1981,"extension":1982,"links":1983,"meta":1984,"navigation":213,"path":76,"seo":1986,"stem":77,"__hash__":1987},"docs\u002Fdocs\u002Fguides\u002F3.sdks.md",{"type":85,"value":86,"toc":1966},"minimark",[87,91,95,100,105,108,936,941,1111,1121,1125,1128,1318,1321,1350,1353,1357,1360,1364,1405,1407,1411,1414,1418,1458,1462,1553,1557,1652,1656,1797,1801,1903,1905,1909,1912,1962],[88,89,75],"h1",{"id":90},"sdks-libraries",[92,93,94],"p",{},"While the Quote Gallery API can be used with any HTTP client, SDKs and wrapper libraries make integration faster and more pleasant. This page lists official utilities and community-contributed packages.",[96,97,99],"h2",{"id":98},"official-tools","Official Tools",[101,102,104],"h3",{"id":103},"javascript-typescript-client","JavaScript \u002F TypeScript Client",[92,106,107],{},"A lightweight, fully-typed API client you can copy directly into your project. No package installation required.",[109,110,115],"pre",{"className":111,"code":112,"language":113,"meta":114,"style":114},"language-js shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","class QuoteGalleryClient {\n  constructor(apiKey, options = {}) {\n    this.apiKey = apiKey\n    this.baseUrl = options.baseUrl ?? 'https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1'\n  }\n\n  async request(endpoint, params = {}) {\n    const url = new URL(`${this.baseUrl}${endpoint}`)\n    Object.entries(params).forEach(([key, value]) => {\n      if (value !== undefined && value !== null) {\n        url.searchParams.set(key, String(value))\n      }\n    })\n\n    const response = await fetch(url.toString(), {\n      headers: { 'X-API-Key': this.apiKey },\n    })\n\n    if (!response.ok) {\n      const error = await response.json()\n      throw new Error(`API Error ${response.status}: ${error.error}`)\n    }\n\n    return response.json()\n  }\n\n  getQuotes(params) { return this.request('\u002Fquotes', params) }\n  getRandomQuote(params) { return this.request('\u002Fquotes\u002Frandom', params) }\n  getQuote(id, params) { return this.request(`\u002Fquotes\u002F${id}`, params) }\n  getAuthors(params) { return this.request('\u002Fauthors', params) }\n  getAuthor(id, params) { return this.request(`\u002Fauthors\u002F${id}`, params) }\n  getPlaylists(params) { return this.request('\u002Fplaylists', params) }\n  getPlaylist(id, params) { return this.request(`\u002Fplaylists\u002F${id}`, params) }\n  getCategories() { return this.request('\u002Fcategories') }\n}\n","js","",[116,117,118,134,160,173,202,208,215,241,280,325,360,392,398,406,411,444,474,481,486,509,532,580,586,591,605,610,615,655,692,738,775,820,857,902,931],"code",{"__ignoreMap":114},[119,120,122,126,130],"span",{"class":121,"line":60},"line",[119,123,125],{"class":124},"spNyl","class",[119,127,129],{"class":128},"sBMFI"," QuoteGalleryClient",[119,131,133],{"class":132},"sMK4o"," {\n",[119,135,136,139,142,146,149,152,155,158],{"class":121,"line":81},[119,137,138],{"class":124},"  constructor",[119,140,141],{"class":132},"(",[119,143,145],{"class":144},"sHdIc","apiKey",[119,147,148],{"class":132},",",[119,150,151],{"class":144}," options",[119,153,154],{"class":132}," =",[119,156,157],{"class":132}," {})",[119,159,133],{"class":132},[119,161,162,165,168,170],{"class":121,"line":38},[119,163,164],{"class":132},"    this.",[119,166,145],{"class":167},"sTEyZ",[119,169,154],{"class":132},[119,171,172],{"class":167}," apiKey\n",[119,174,175,177,180,182,184,187,189,192,195,199],{"class":121,"line":8},[119,176,164],{"class":132},[119,178,179],{"class":167},"baseUrl",[119,181,154],{"class":132},[119,183,151],{"class":167},[119,185,186],{"class":132},".",[119,188,179],{"class":167},[119,190,191],{"class":132}," ??",[119,193,194],{"class":132}," '",[119,196,198],{"class":197},"sfazB","https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1",[119,200,201],{"class":132},"'\n",[119,203,205],{"class":121,"line":204},5,[119,206,207],{"class":132},"  }\n",[119,209,211],{"class":121,"line":210},6,[119,212,214],{"emptyLinePlaceholder":213},true,"\n",[119,216,218,221,225,227,230,232,235,237,239],{"class":121,"line":217},7,[119,219,220],{"class":124},"  async",[119,222,224],{"class":223},"swJcz"," request",[119,226,141],{"class":132},[119,228,229],{"class":144},"endpoint",[119,231,148],{"class":132},[119,233,234],{"class":144}," params",[119,236,154],{"class":132},[119,238,157],{"class":132},[119,240,133],{"class":132},[119,242,244,247,250,252,255,259,261,264,267,269,272,274,277],{"class":121,"line":243},8,[119,245,246],{"class":124},"    const",[119,248,249],{"class":167}," url",[119,251,154],{"class":132},[119,253,254],{"class":132}," new",[119,256,258],{"class":257},"s2Zo4"," URL",[119,260,141],{"class":223},[119,262,263],{"class":132},"`${",[119,265,266],{"class":132},"this.",[119,268,179],{"class":167},[119,270,271],{"class":132},"}${",[119,273,229],{"class":167},[119,275,276],{"class":132},"}`",[119,278,279],{"class":223},")\n",[119,281,283,286,288,291,293,296,299,301,304,306,309,312,314,317,320,323],{"class":121,"line":282},9,[119,284,285],{"class":167},"    Object",[119,287,186],{"class":132},[119,289,290],{"class":257},"entries",[119,292,141],{"class":223},[119,294,295],{"class":167},"params",[119,297,298],{"class":223},")",[119,300,186],{"class":132},[119,302,303],{"class":257},"forEach",[119,305,141],{"class":223},[119,307,308],{"class":132},"([",[119,310,311],{"class":144},"key",[119,313,148],{"class":132},[119,315,316],{"class":144}," value",[119,318,319],{"class":132},"])",[119,321,322],{"class":124}," =>",[119,324,133],{"class":132},[119,326,328,332,335,338,341,344,347,349,351,354,357],{"class":121,"line":327},10,[119,329,331],{"class":330},"s7zQu","      if",[119,333,334],{"class":223}," (",[119,336,337],{"class":167},"value",[119,339,340],{"class":132}," !==",[119,342,343],{"class":132}," undefined",[119,345,346],{"class":132}," &&",[119,348,316],{"class":167},[119,350,340],{"class":132},[119,352,353],{"class":132}," null",[119,355,356],{"class":223},") ",[119,358,359],{"class":132},"{\n",[119,361,363,366,368,371,373,376,378,380,382,385,387,389],{"class":121,"line":362},11,[119,364,365],{"class":167},"        url",[119,367,186],{"class":132},[119,369,370],{"class":167},"searchParams",[119,372,186],{"class":132},[119,374,375],{"class":257},"set",[119,377,141],{"class":223},[119,379,311],{"class":167},[119,381,148],{"class":132},[119,383,384],{"class":257}," String",[119,386,141],{"class":223},[119,388,337],{"class":167},[119,390,391],{"class":223},"))\n",[119,393,395],{"class":121,"line":394},12,[119,396,397],{"class":132},"      }\n",[119,399,401,404],{"class":121,"line":400},13,[119,402,403],{"class":132},"    }",[119,405,279],{"class":223},[119,407,409],{"class":121,"line":408},14,[119,410,214],{"emptyLinePlaceholder":213},[119,412,414,416,419,421,424,427,429,432,434,437,440,442],{"class":121,"line":413},15,[119,415,246],{"class":124},[119,417,418],{"class":167}," response",[119,420,154],{"class":132},[119,422,423],{"class":330}," await",[119,425,426],{"class":257}," fetch",[119,428,141],{"class":223},[119,430,431],{"class":167},"url",[119,433,186],{"class":132},[119,435,436],{"class":257},"toString",[119,438,439],{"class":223},"()",[119,441,148],{"class":132},[119,443,133],{"class":132},[119,445,447,450,453,456,458,461,464,466,469,471],{"class":121,"line":446},16,[119,448,449],{"class":223},"      headers",[119,451,452],{"class":132},":",[119,454,455],{"class":132}," {",[119,457,194],{"class":132},[119,459,460],{"class":223},"X-API-Key",[119,462,463],{"class":132},"'",[119,465,452],{"class":132},[119,467,468],{"class":132}," this.",[119,470,145],{"class":167},[119,472,473],{"class":132}," },\n",[119,475,477,479],{"class":121,"line":476},17,[119,478,403],{"class":132},[119,480,279],{"class":223},[119,482,484],{"class":121,"line":483},18,[119,485,214],{"emptyLinePlaceholder":213},[119,487,489,492,494,497,500,502,505,507],{"class":121,"line":488},19,[119,490,491],{"class":330},"    if",[119,493,334],{"class":223},[119,495,496],{"class":132},"!",[119,498,499],{"class":167},"response",[119,501,186],{"class":132},[119,503,504],{"class":167},"ok",[119,506,356],{"class":223},[119,508,359],{"class":132},[119,510,512,515,518,520,522,524,526,529],{"class":121,"line":511},20,[119,513,514],{"class":124},"      const",[119,516,517],{"class":167}," error",[119,519,154],{"class":132},[119,521,423],{"class":330},[119,523,418],{"class":167},[119,525,186],{"class":132},[119,527,528],{"class":257},"json",[119,530,531],{"class":223},"()\n",[119,533,535,538,540,543,545,548,551,554,556,558,561,564,567,569,572,574,576,578],{"class":121,"line":534},21,[119,536,537],{"class":330},"      throw",[119,539,254],{"class":132},[119,541,542],{"class":257}," Error",[119,544,141],{"class":223},[119,546,547],{"class":132},"`",[119,549,550],{"class":197},"API Error ",[119,552,553],{"class":132},"${",[119,555,499],{"class":167},[119,557,186],{"class":132},[119,559,560],{"class":167},"status",[119,562,563],{"class":132},"}",[119,565,566],{"class":197},": ",[119,568,553],{"class":132},[119,570,571],{"class":167},"error",[119,573,186],{"class":132},[119,575,571],{"class":167},[119,577,276],{"class":132},[119,579,279],{"class":223},[119,581,583],{"class":121,"line":582},22,[119,584,585],{"class":132},"    }\n",[119,587,589],{"class":121,"line":588},23,[119,590,214],{"emptyLinePlaceholder":213},[119,592,594,597,599,601,603],{"class":121,"line":593},24,[119,595,596],{"class":330},"    return",[119,598,418],{"class":167},[119,600,186],{"class":132},[119,602,528],{"class":257},[119,604,531],{"class":223},[119,606,608],{"class":121,"line":607},25,[119,609,207],{"class":132},[119,611,613],{"class":121,"line":612},26,[119,614,214],{"emptyLinePlaceholder":213},[119,616,618,621,623,625,627,629,632,634,637,639,641,644,646,648,650,652],{"class":121,"line":617},27,[119,619,620],{"class":223},"  getQuotes",[119,622,141],{"class":132},[119,624,295],{"class":144},[119,626,298],{"class":132},[119,628,455],{"class":132},[119,630,631],{"class":330}," return",[119,633,468],{"class":132},[119,635,636],{"class":257},"request",[119,638,141],{"class":223},[119,640,463],{"class":132},[119,642,643],{"class":197},"\u002Fquotes",[119,645,463],{"class":132},[119,647,148],{"class":132},[119,649,234],{"class":167},[119,651,356],{"class":223},[119,653,654],{"class":132},"}\n",[119,656,658,661,663,665,667,669,671,673,675,677,679,682,684,686,688,690],{"class":121,"line":657},28,[119,659,660],{"class":223},"  getRandomQuote",[119,662,141],{"class":132},[119,664,295],{"class":144},[119,666,298],{"class":132},[119,668,455],{"class":132},[119,670,631],{"class":330},[119,672,468],{"class":132},[119,674,636],{"class":257},[119,676,141],{"class":223},[119,678,463],{"class":132},[119,680,681],{"class":197},"\u002Fquotes\u002Frandom",[119,683,463],{"class":132},[119,685,148],{"class":132},[119,687,234],{"class":167},[119,689,356],{"class":223},[119,691,654],{"class":132},[119,693,695,698,700,703,705,707,709,711,713,715,717,719,721,724,726,728,730,732,734,736],{"class":121,"line":694},29,[119,696,697],{"class":223},"  getQuote",[119,699,141],{"class":132},[119,701,702],{"class":144},"id",[119,704,148],{"class":132},[119,706,234],{"class":144},[119,708,298],{"class":132},[119,710,455],{"class":132},[119,712,631],{"class":330},[119,714,468],{"class":132},[119,716,636],{"class":257},[119,718,141],{"class":223},[119,720,547],{"class":132},[119,722,723],{"class":197},"\u002Fquotes\u002F",[119,725,553],{"class":132},[119,727,702],{"class":167},[119,729,276],{"class":132},[119,731,148],{"class":132},[119,733,234],{"class":167},[119,735,356],{"class":223},[119,737,654],{"class":132},[119,739,741,744,746,748,750,752,754,756,758,760,762,765,767,769,771,773],{"class":121,"line":740},30,[119,742,743],{"class":223},"  getAuthors",[119,745,141],{"class":132},[119,747,295],{"class":144},[119,749,298],{"class":132},[119,751,455],{"class":132},[119,753,631],{"class":330},[119,755,468],{"class":132},[119,757,636],{"class":257},[119,759,141],{"class":223},[119,761,463],{"class":132},[119,763,764],{"class":197},"\u002Fauthors",[119,766,463],{"class":132},[119,768,148],{"class":132},[119,770,234],{"class":167},[119,772,356],{"class":223},[119,774,654],{"class":132},[119,776,778,781,783,785,787,789,791,793,795,797,799,801,803,806,808,810,812,814,816,818],{"class":121,"line":777},31,[119,779,780],{"class":223},"  getAuthor",[119,782,141],{"class":132},[119,784,702],{"class":144},[119,786,148],{"class":132},[119,788,234],{"class":144},[119,790,298],{"class":132},[119,792,455],{"class":132},[119,794,631],{"class":330},[119,796,468],{"class":132},[119,798,636],{"class":257},[119,800,141],{"class":223},[119,802,547],{"class":132},[119,804,805],{"class":197},"\u002Fauthors\u002F",[119,807,553],{"class":132},[119,809,702],{"class":167},[119,811,276],{"class":132},[119,813,148],{"class":132},[119,815,234],{"class":167},[119,817,356],{"class":223},[119,819,654],{"class":132},[119,821,823,826,828,830,832,834,836,838,840,842,844,847,849,851,853,855],{"class":121,"line":822},32,[119,824,825],{"class":223},"  getPlaylists",[119,827,141],{"class":132},[119,829,295],{"class":144},[119,831,298],{"class":132},[119,833,455],{"class":132},[119,835,631],{"class":330},[119,837,468],{"class":132},[119,839,636],{"class":257},[119,841,141],{"class":223},[119,843,463],{"class":132},[119,845,846],{"class":197},"\u002Fplaylists",[119,848,463],{"class":132},[119,850,148],{"class":132},[119,852,234],{"class":167},[119,854,356],{"class":223},[119,856,654],{"class":132},[119,858,860,863,865,867,869,871,873,875,877,879,881,883,885,888,890,892,894,896,898,900],{"class":121,"line":859},33,[119,861,862],{"class":223},"  getPlaylist",[119,864,141],{"class":132},[119,866,702],{"class":144},[119,868,148],{"class":132},[119,870,234],{"class":144},[119,872,298],{"class":132},[119,874,455],{"class":132},[119,876,631],{"class":330},[119,878,468],{"class":132},[119,880,636],{"class":257},[119,882,141],{"class":223},[119,884,547],{"class":132},[119,886,887],{"class":197},"\u002Fplaylists\u002F",[119,889,553],{"class":132},[119,891,702],{"class":167},[119,893,276],{"class":132},[119,895,148],{"class":132},[119,897,234],{"class":167},[119,899,356],{"class":223},[119,901,654],{"class":132},[119,903,905,908,910,912,914,916,918,920,922,925,927,929],{"class":121,"line":904},34,[119,906,907],{"class":223},"  getCategories",[119,909,439],{"class":132},[119,911,455],{"class":132},[119,913,631],{"class":330},[119,915,468],{"class":132},[119,917,636],{"class":257},[119,919,141],{"class":223},[119,921,463],{"class":132},[119,923,924],{"class":197},"\u002Fcategories",[119,926,463],{"class":132},[119,928,356],{"class":223},[119,930,654],{"class":132},[119,932,934],{"class":121,"line":933},35,[119,935,654],{"class":132},[937,938,940],"h4",{"id":939},"usage","Usage",[109,942,944],{"className":111,"code":943,"language":113,"meta":114,"style":114},"const client = new QuoteGalleryClient(process.env.QUOTE_GALLERY_API_KEY)\n\nconst { data: quotes } = await client.getQuotes({ language: 'en', limit: 5 })\nconst { data: random } = await client.getRandomQuote({ language: 'en' })\nconst { data: categories } = await client.getCategories()\n",[116,945,946,974,978,1039,1083],{"__ignoreMap":114},[119,947,948,951,954,957,959,961,964,966,969,971],{"class":121,"line":60},[119,949,950],{"class":124},"const",[119,952,953],{"class":167}," client ",[119,955,956],{"class":132},"=",[119,958,254],{"class":132},[119,960,129],{"class":257},[119,962,963],{"class":167},"(process",[119,965,186],{"class":132},[119,967,968],{"class":167},"env",[119,970,186],{"class":132},[119,972,973],{"class":167},"QUOTE_GALLERY_API_KEY)\n",[119,975,976],{"class":121,"line":81},[119,977,214],{"emptyLinePlaceholder":213},[119,979,980,982,984,987,989,992,994,996,998,1001,1003,1006,1008,1011,1014,1016,1018,1021,1023,1025,1028,1030,1034,1037],{"class":121,"line":38},[119,981,950],{"class":124},[119,983,455],{"class":132},[119,985,986],{"class":223}," data",[119,988,452],{"class":132},[119,990,991],{"class":167}," quotes ",[119,993,563],{"class":132},[119,995,154],{"class":132},[119,997,423],{"class":330},[119,999,1000],{"class":167}," client",[119,1002,186],{"class":132},[119,1004,1005],{"class":257},"getQuotes",[119,1007,141],{"class":167},[119,1009,1010],{"class":132},"{",[119,1012,1013],{"class":223}," language",[119,1015,452],{"class":132},[119,1017,194],{"class":132},[119,1019,1020],{"class":197},"en",[119,1022,463],{"class":132},[119,1024,148],{"class":132},[119,1026,1027],{"class":223}," limit",[119,1029,452],{"class":132},[119,1031,1033],{"class":1032},"sbssI"," 5",[119,1035,1036],{"class":132}," }",[119,1038,279],{"class":167},[119,1040,1041,1043,1045,1047,1049,1052,1054,1056,1058,1060,1062,1065,1067,1069,1071,1073,1075,1077,1079,1081],{"class":121,"line":8},[119,1042,950],{"class":124},[119,1044,455],{"class":132},[119,1046,986],{"class":223},[119,1048,452],{"class":132},[119,1050,1051],{"class":167}," random ",[119,1053,563],{"class":132},[119,1055,154],{"class":132},[119,1057,423],{"class":330},[119,1059,1000],{"class":167},[119,1061,186],{"class":132},[119,1063,1064],{"class":257},"getRandomQuote",[119,1066,141],{"class":167},[119,1068,1010],{"class":132},[119,1070,1013],{"class":223},[119,1072,452],{"class":132},[119,1074,194],{"class":132},[119,1076,1020],{"class":197},[119,1078,463],{"class":132},[119,1080,1036],{"class":132},[119,1082,279],{"class":167},[119,1084,1085,1087,1089,1091,1093,1096,1098,1100,1102,1104,1106,1109],{"class":121,"line":204},[119,1086,950],{"class":124},[119,1088,455],{"class":132},[119,1090,986],{"class":223},[119,1092,452],{"class":132},[119,1094,1095],{"class":167}," categories ",[119,1097,563],{"class":132},[119,1099,154],{"class":132},[119,1101,423],{"class":330},[119,1103,1000],{"class":167},[119,1105,186],{"class":132},[119,1107,1108],{"class":257},"getCategories",[119,1110,531],{"class":167},[1112,1113,1115,1116,1120],"callout",{"type":1114},"tip","For a production-ready version with retry logic, timeouts, and structured error handling, see the full client example in the ",[1117,1118,71],"a",{"href":1119},"\u002Fdocs\u002Fguides\u002Ferror-handling#building-a-robust-api-client"," guide.",[101,1122,1124],{"id":1123},"python-client","Python Client",[92,1126,1127],{},"A minimal Python wrapper for the API:",[109,1129,1133],{"className":1130,"code":1131,"language":1132,"meta":114,"style":114},"language-python shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import os\nimport requests\n\nclass QuoteGalleryClient:\n    def __init__(self, api_key=None, base_url='https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1'):\n        self.api_key = api_key or os.environ.get('QUOTE_GALLERY_API_KEY')\n        self.base_url = base_url\n        self.session = requests.Session()\n        self.session.headers.update({'X-API-Key': self.api_key})\n\n    def _request(self, endpoint, params=None):\n        response = self.session.get(f'{self.base_url}{endpoint}', params=params)\n        response.raise_for_status()\n        return response.json()\n\n    def get_quotes(self, **params):\n        return self._request('\u002Fquotes', params)\n\n    def get_random_quote(self, **params):\n        return self._request('\u002Fquotes\u002Frandom', params)\n\n    def get_quote(self, quote_id, **params):\n        return self._request(f'\u002Fquotes\u002F{quote_id}', params)\n\n    def get_authors(self, **params):\n        return self._request('\u002Fauthors', params)\n\n    def get_author(self, author_id, **params):\n        return self._request(f'\u002Fauthors\u002F{author_id}', params)\n\n    def get_playlists(self, **params):\n        return self._request('\u002Fplaylists', params)\n\n    def get_playlist(self, playlist_id, **params):\n        return self._request(f'\u002Fplaylists\u002F{playlist_id}', params)\n\n    def get_categories(self):\n        return self._request('\u002Fcategories')\n","python",[116,1134,1135,1140,1145,1149,1154,1159,1164,1169,1174,1179,1183,1188,1193,1198,1203,1207,1212,1217,1221,1226,1231,1235,1240,1245,1249,1254,1259,1263,1268,1273,1277,1282,1287,1291,1296,1301,1306,1312],{"__ignoreMap":114},[119,1136,1137],{"class":121,"line":60},[119,1138,1139],{},"import os\n",[119,1141,1142],{"class":121,"line":81},[119,1143,1144],{},"import requests\n",[119,1146,1147],{"class":121,"line":38},[119,1148,214],{"emptyLinePlaceholder":213},[119,1150,1151],{"class":121,"line":8},[119,1152,1153],{},"class QuoteGalleryClient:\n",[119,1155,1156],{"class":121,"line":204},[119,1157,1158],{},"    def __init__(self, api_key=None, base_url='https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1'):\n",[119,1160,1161],{"class":121,"line":210},[119,1162,1163],{},"        self.api_key = api_key or os.environ.get('QUOTE_GALLERY_API_KEY')\n",[119,1165,1166],{"class":121,"line":217},[119,1167,1168],{},"        self.base_url = base_url\n",[119,1170,1171],{"class":121,"line":243},[119,1172,1173],{},"        self.session = requests.Session()\n",[119,1175,1176],{"class":121,"line":282},[119,1177,1178],{},"        self.session.headers.update({'X-API-Key': self.api_key})\n",[119,1180,1181],{"class":121,"line":327},[119,1182,214],{"emptyLinePlaceholder":213},[119,1184,1185],{"class":121,"line":362},[119,1186,1187],{},"    def _request(self, endpoint, params=None):\n",[119,1189,1190],{"class":121,"line":394},[119,1191,1192],{},"        response = self.session.get(f'{self.base_url}{endpoint}', params=params)\n",[119,1194,1195],{"class":121,"line":400},[119,1196,1197],{},"        response.raise_for_status()\n",[119,1199,1200],{"class":121,"line":408},[119,1201,1202],{},"        return response.json()\n",[119,1204,1205],{"class":121,"line":413},[119,1206,214],{"emptyLinePlaceholder":213},[119,1208,1209],{"class":121,"line":446},[119,1210,1211],{},"    def get_quotes(self, **params):\n",[119,1213,1214],{"class":121,"line":476},[119,1215,1216],{},"        return self._request('\u002Fquotes', params)\n",[119,1218,1219],{"class":121,"line":483},[119,1220,214],{"emptyLinePlaceholder":213},[119,1222,1223],{"class":121,"line":488},[119,1224,1225],{},"    def get_random_quote(self, **params):\n",[119,1227,1228],{"class":121,"line":511},[119,1229,1230],{},"        return self._request('\u002Fquotes\u002Frandom', params)\n",[119,1232,1233],{"class":121,"line":534},[119,1234,214],{"emptyLinePlaceholder":213},[119,1236,1237],{"class":121,"line":582},[119,1238,1239],{},"    def get_quote(self, quote_id, **params):\n",[119,1241,1242],{"class":121,"line":588},[119,1243,1244],{},"        return self._request(f'\u002Fquotes\u002F{quote_id}', params)\n",[119,1246,1247],{"class":121,"line":593},[119,1248,214],{"emptyLinePlaceholder":213},[119,1250,1251],{"class":121,"line":607},[119,1252,1253],{},"    def get_authors(self, **params):\n",[119,1255,1256],{"class":121,"line":612},[119,1257,1258],{},"        return self._request('\u002Fauthors', params)\n",[119,1260,1261],{"class":121,"line":617},[119,1262,214],{"emptyLinePlaceholder":213},[119,1264,1265],{"class":121,"line":657},[119,1266,1267],{},"    def get_author(self, author_id, **params):\n",[119,1269,1270],{"class":121,"line":694},[119,1271,1272],{},"        return self._request(f'\u002Fauthors\u002F{author_id}', params)\n",[119,1274,1275],{"class":121,"line":740},[119,1276,214],{"emptyLinePlaceholder":213},[119,1278,1279],{"class":121,"line":777},[119,1280,1281],{},"    def get_playlists(self, **params):\n",[119,1283,1284],{"class":121,"line":822},[119,1285,1286],{},"        return self._request('\u002Fplaylists', params)\n",[119,1288,1289],{"class":121,"line":859},[119,1290,214],{"emptyLinePlaceholder":213},[119,1292,1293],{"class":121,"line":904},[119,1294,1295],{},"    def get_playlist(self, playlist_id, **params):\n",[119,1297,1298],{"class":121,"line":933},[119,1299,1300],{},"        return self._request(f'\u002Fplaylists\u002F{playlist_id}', params)\n",[119,1302,1304],{"class":121,"line":1303},36,[119,1305,214],{"emptyLinePlaceholder":213},[119,1307,1309],{"class":121,"line":1308},37,[119,1310,1311],{},"    def get_categories(self):\n",[119,1313,1315],{"class":121,"line":1314},38,[119,1316,1317],{},"        return self._request('\u002Fcategories')\n",[937,1319,940],{"id":1320},"usage-1",[109,1322,1324],{"className":1130,"code":1323,"language":1132,"meta":114,"style":114},"client = QuoteGalleryClient()\n\nquotes = client.get_quotes(language='en', limit=5)\nrandom_quote = client.get_random_quote(language='en')\ncategories = client.get_categories()\n",[116,1325,1326,1331,1335,1340,1345],{"__ignoreMap":114},[119,1327,1328],{"class":121,"line":60},[119,1329,1330],{},"client = QuoteGalleryClient()\n",[119,1332,1333],{"class":121,"line":81},[119,1334,214],{"emptyLinePlaceholder":213},[119,1336,1337],{"class":121,"line":38},[119,1338,1339],{},"quotes = client.get_quotes(language='en', limit=5)\n",[119,1341,1342],{"class":121,"line":8},[119,1343,1344],{},"random_quote = client.get_random_quote(language='en')\n",[119,1346,1347],{"class":121,"line":204},[119,1348,1349],{},"categories = client.get_categories()\n",[1351,1352],"hr",{},[96,1354,1356],{"id":1355},"community-libraries","Community Libraries",[92,1358,1359],{},"Community-contributed libraries are not maintained by the Quote Gallery team. Use them at your own discretion and check their documentation for the latest updates.",[1112,1361,1363],{"type":1362},"info","Have you built an SDK or library for the Quote Gallery API? We'd love to feature it here! Open an issue or pull request on our GitHub repository.",[1365,1366,1367,1386],"table",{},[1368,1369,1370],"thead",{},[1371,1372,1373,1377,1380,1383],"tr",{},[1374,1375,1376],"th",{},"Language",[1374,1378,1379],{},"Library",[1374,1381,1382],{},"Author",[1374,1384,1385],{},"Link",[1387,1388,1389],"tbody",{},[1371,1390,1391,1395,1401,1403],{},[1392,1393,1394],"td",{},"—",[1392,1396,1397],{},[1398,1399,1400],"em",{},"Be the first to contribute!",[1392,1402,1394],{},[1392,1404,1394],{},[1351,1406],{},[96,1408,1410],{"id":1409},"using-plain-http","Using Plain HTTP",[92,1412,1413],{},"You don't need an SDK to use the Quote Gallery API. Any HTTP client works. Here are quick examples in popular languages and tools:",[101,1415,1417],{"id":1416},"curl","cURL",[109,1419,1423],{"className":1420,"code":1421,"language":1422,"meta":114,"style":114},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","curl -H \"X-API-Key: $QUOTE_GALLERY_API_KEY\" \\\n  \"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5\"\n","bash",[116,1424,1425,1447],{"__ignoreMap":114},[119,1426,1427,1429,1432,1435,1438,1441,1444],{"class":121,"line":60},[119,1428,1416],{"class":128},[119,1430,1431],{"class":197}," -H",[119,1433,1434],{"class":132}," \"",[119,1436,1437],{"class":197},"X-API-Key: ",[119,1439,1440],{"class":167},"$QUOTE_GALLERY_API_KEY",[119,1442,1443],{"class":132},"\"",[119,1445,1446],{"class":167}," \\\n",[119,1448,1449,1452,1455],{"class":121,"line":81},[119,1450,1451],{"class":132},"  \"",[119,1453,1454],{"class":197},"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5",[119,1456,1457],{"class":132},"\"\n",[101,1459,1461],{"id":1460},"php","PHP",[109,1463,1466],{"className":1464,"code":1465,"language":1460,"meta":114,"style":114},"language-php shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","\u003C?php\n$apiKey = getenv('QUOTE_GALLERY_API_KEY');\n\n$ch = curl_init();\ncurl_setopt_array($ch, [\n    CURLOPT_URL => 'https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5',\n    CURLOPT_RETURNTRANSFER => true,\n    CURLOPT_HTTPHEADER => [\"X-API-Key: $apiKey\"],\n]);\n\n$response = curl_exec($ch);\ncurl_close($ch);\n\n$data = json_decode($response, true);\n\nforeach ($data['data'] as $quote) {\n    echo \"\\\"{$quote['text']}\\\" — {$quote['author']['name']}\\n\";\n}\n",[116,1467,1468,1473,1478,1482,1487,1492,1497,1502,1507,1512,1516,1521,1526,1530,1535,1539,1544,1549],{"__ignoreMap":114},[119,1469,1470],{"class":121,"line":60},[119,1471,1472],{},"\u003C?php\n",[119,1474,1475],{"class":121,"line":81},[119,1476,1477],{},"$apiKey = getenv('QUOTE_GALLERY_API_KEY');\n",[119,1479,1480],{"class":121,"line":38},[119,1481,214],{"emptyLinePlaceholder":213},[119,1483,1484],{"class":121,"line":8},[119,1485,1486],{},"$ch = curl_init();\n",[119,1488,1489],{"class":121,"line":204},[119,1490,1491],{},"curl_setopt_array($ch, [\n",[119,1493,1494],{"class":121,"line":210},[119,1495,1496],{},"    CURLOPT_URL => 'https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5',\n",[119,1498,1499],{"class":121,"line":217},[119,1500,1501],{},"    CURLOPT_RETURNTRANSFER => true,\n",[119,1503,1504],{"class":121,"line":243},[119,1505,1506],{},"    CURLOPT_HTTPHEADER => [\"X-API-Key: $apiKey\"],\n",[119,1508,1509],{"class":121,"line":282},[119,1510,1511],{},"]);\n",[119,1513,1514],{"class":121,"line":327},[119,1515,214],{"emptyLinePlaceholder":213},[119,1517,1518],{"class":121,"line":362},[119,1519,1520],{},"$response = curl_exec($ch);\n",[119,1522,1523],{"class":121,"line":394},[119,1524,1525],{},"curl_close($ch);\n",[119,1527,1528],{"class":121,"line":400},[119,1529,214],{"emptyLinePlaceholder":213},[119,1531,1532],{"class":121,"line":408},[119,1533,1534],{},"$data = json_decode($response, true);\n",[119,1536,1537],{"class":121,"line":413},[119,1538,214],{"emptyLinePlaceholder":213},[119,1540,1541],{"class":121,"line":446},[119,1542,1543],{},"foreach ($data['data'] as $quote) {\n",[119,1545,1546],{"class":121,"line":476},[119,1547,1548],{},"    echo \"\\\"{$quote['text']}\\\" — {$quote['author']['name']}\\n\";\n",[119,1550,1551],{"class":121,"line":483},[119,1552,654],{},[101,1554,1556],{"id":1555},"ruby","Ruby",[109,1558,1561],{"className":1559,"code":1560,"language":1555,"meta":114,"style":114},"language-ruby shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","require 'net\u002Fhttp'\nrequire 'json'\nrequire 'uri'\n\napi_key = ENV['QUOTE_GALLERY_API_KEY']\nuri = URI('https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5')\n\nrequest = Net::HTTP::Get.new(uri)\nrequest['X-API-Key'] = api_key\n\nresponse = Net::HTTP.start(uri.hostname, uri.port, use_ssl: true) do |http|\n  http.request(request)\nend\n\ndata = JSON.parse(response.body)\n\ndata['data'].each do |quote|\n  puts \"\\\"#{quote['text']}\\\" — #{quote['author']['name']}\"\nend\n",[116,1562,1563,1568,1573,1578,1582,1587,1592,1596,1601,1606,1610,1615,1620,1625,1629,1634,1638,1643,1648],{"__ignoreMap":114},[119,1564,1565],{"class":121,"line":60},[119,1566,1567],{},"require 'net\u002Fhttp'\n",[119,1569,1570],{"class":121,"line":81},[119,1571,1572],{},"require 'json'\n",[119,1574,1575],{"class":121,"line":38},[119,1576,1577],{},"require 'uri'\n",[119,1579,1580],{"class":121,"line":8},[119,1581,214],{"emptyLinePlaceholder":213},[119,1583,1584],{"class":121,"line":204},[119,1585,1586],{},"api_key = ENV['QUOTE_GALLERY_API_KEY']\n",[119,1588,1589],{"class":121,"line":210},[119,1590,1591],{},"uri = URI('https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5')\n",[119,1593,1594],{"class":121,"line":217},[119,1595,214],{"emptyLinePlaceholder":213},[119,1597,1598],{"class":121,"line":243},[119,1599,1600],{},"request = Net::HTTP::Get.new(uri)\n",[119,1602,1603],{"class":121,"line":282},[119,1604,1605],{},"request['X-API-Key'] = api_key\n",[119,1607,1608],{"class":121,"line":327},[119,1609,214],{"emptyLinePlaceholder":213},[119,1611,1612],{"class":121,"line":362},[119,1613,1614],{},"response = Net::HTTP.start(uri.hostname, uri.port, use_ssl: true) do |http|\n",[119,1616,1617],{"class":121,"line":394},[119,1618,1619],{},"  http.request(request)\n",[119,1621,1622],{"class":121,"line":400},[119,1623,1624],{},"end\n",[119,1626,1627],{"class":121,"line":408},[119,1628,214],{"emptyLinePlaceholder":213},[119,1630,1631],{"class":121,"line":413},[119,1632,1633],{},"data = JSON.parse(response.body)\n",[119,1635,1636],{"class":121,"line":446},[119,1637,214],{"emptyLinePlaceholder":213},[119,1639,1640],{"class":121,"line":476},[119,1641,1642],{},"data['data'].each do |quote|\n",[119,1644,1645],{"class":121,"line":483},[119,1646,1647],{},"  puts \"\\\"#{quote['text']}\\\" — #{quote['author']['name']}\"\n",[119,1649,1650],{"class":121,"line":488},[119,1651,1624],{},[101,1653,1655],{"id":1654},"go","Go",[109,1657,1660],{"className":1658,"code":1659,"language":1654,"meta":114,"style":114},"language-go shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","package main\n\nimport (\n    \"encoding\u002Fjson\"\n    \"fmt\"\n    \"io\"\n    \"net\u002Fhttp\"\n    \"os\"\n)\n\nfunc main() {\n    apiKey := os.Getenv(\"QUOTE_GALLERY_API_KEY\")\n\n    req, _ := http.NewRequest(\"GET\", \"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5\", nil)\n    req.Header.Set(\"X-API-Key\", apiKey)\n\n    resp, err := http.DefaultClient.Do(req)\n    if err != nil {\n        panic(err)\n    }\n    defer resp.Body.Close()\n\n    body, _ := io.ReadAll(resp.Body)\n\n    var result map[string]interface{}\n    json.Unmarshal(body, &result)\n\n    fmt.Println(string(body))\n}\n",[116,1661,1662,1667,1671,1676,1681,1686,1691,1696,1701,1705,1709,1714,1719,1723,1728,1733,1737,1742,1747,1752,1756,1761,1765,1770,1774,1779,1784,1788,1793],{"__ignoreMap":114},[119,1663,1664],{"class":121,"line":60},[119,1665,1666],{},"package main\n",[119,1668,1669],{"class":121,"line":81},[119,1670,214],{"emptyLinePlaceholder":213},[119,1672,1673],{"class":121,"line":38},[119,1674,1675],{},"import (\n",[119,1677,1678],{"class":121,"line":8},[119,1679,1680],{},"    \"encoding\u002Fjson\"\n",[119,1682,1683],{"class":121,"line":204},[119,1684,1685],{},"    \"fmt\"\n",[119,1687,1688],{"class":121,"line":210},[119,1689,1690],{},"    \"io\"\n",[119,1692,1693],{"class":121,"line":217},[119,1694,1695],{},"    \"net\u002Fhttp\"\n",[119,1697,1698],{"class":121,"line":243},[119,1699,1700],{},"    \"os\"\n",[119,1702,1703],{"class":121,"line":282},[119,1704,279],{},[119,1706,1707],{"class":121,"line":327},[119,1708,214],{"emptyLinePlaceholder":213},[119,1710,1711],{"class":121,"line":362},[119,1712,1713],{},"func main() {\n",[119,1715,1716],{"class":121,"line":394},[119,1717,1718],{},"    apiKey := os.Getenv(\"QUOTE_GALLERY_API_KEY\")\n",[119,1720,1721],{"class":121,"line":400},[119,1722,214],{"emptyLinePlaceholder":213},[119,1724,1725],{"class":121,"line":408},[119,1726,1727],{},"    req, _ := http.NewRequest(\"GET\", \"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5\", nil)\n",[119,1729,1730],{"class":121,"line":413},[119,1731,1732],{},"    req.Header.Set(\"X-API-Key\", apiKey)\n",[119,1734,1735],{"class":121,"line":446},[119,1736,214],{"emptyLinePlaceholder":213},[119,1738,1739],{"class":121,"line":476},[119,1740,1741],{},"    resp, err := http.DefaultClient.Do(req)\n",[119,1743,1744],{"class":121,"line":483},[119,1745,1746],{},"    if err != nil {\n",[119,1748,1749],{"class":121,"line":488},[119,1750,1751],{},"        panic(err)\n",[119,1753,1754],{"class":121,"line":511},[119,1755,585],{},[119,1757,1758],{"class":121,"line":534},[119,1759,1760],{},"    defer resp.Body.Close()\n",[119,1762,1763],{"class":121,"line":582},[119,1764,214],{"emptyLinePlaceholder":213},[119,1766,1767],{"class":121,"line":588},[119,1768,1769],{},"    body, _ := io.ReadAll(resp.Body)\n",[119,1771,1772],{"class":121,"line":593},[119,1773,214],{"emptyLinePlaceholder":213},[119,1775,1776],{"class":121,"line":607},[119,1777,1778],{},"    var result map[string]interface{}\n",[119,1780,1781],{"class":121,"line":612},[119,1782,1783],{},"    json.Unmarshal(body, &result)\n",[119,1785,1786],{"class":121,"line":617},[119,1787,214],{"emptyLinePlaceholder":213},[119,1789,1790],{"class":121,"line":657},[119,1791,1792],{},"    fmt.Println(string(body))\n",[119,1794,1795],{"class":121,"line":694},[119,1796,654],{},[101,1798,1800],{"id":1799},"rust","Rust",[109,1802,1805],{"className":1803,"code":1804,"language":1799,"meta":114,"style":114},"language-rust shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","use reqwest::header;\nuse serde_json::Value;\nuse std::env;\n\n#[tokio::main]\nasync fn main() -> Result\u003C(), Box\u003Cdyn std::error::Error>> {\n    let api_key = env::var(\"QUOTE_GALLERY_API_KEY\")?;\n\n    let client = reqwest::Client::new();\n    let response = client\n        .get(\"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5\")\n        .header(\"X-API-Key\", &api_key)\n        .send()\n        .await?\n        .json::\u003CValue>()\n        .await?;\n\n    println!(\"{:#}\", response);\n    Ok(())\n}\n",[116,1806,1807,1812,1817,1822,1826,1831,1836,1841,1845,1850,1855,1860,1865,1870,1875,1880,1885,1889,1894,1899],{"__ignoreMap":114},[119,1808,1809],{"class":121,"line":60},[119,1810,1811],{},"use reqwest::header;\n",[119,1813,1814],{"class":121,"line":81},[119,1815,1816],{},"use serde_json::Value;\n",[119,1818,1819],{"class":121,"line":38},[119,1820,1821],{},"use std::env;\n",[119,1823,1824],{"class":121,"line":8},[119,1825,214],{"emptyLinePlaceholder":213},[119,1827,1828],{"class":121,"line":204},[119,1829,1830],{},"#[tokio::main]\n",[119,1832,1833],{"class":121,"line":210},[119,1834,1835],{},"async fn main() -> Result\u003C(), Box\u003Cdyn std::error::Error>> {\n",[119,1837,1838],{"class":121,"line":217},[119,1839,1840],{},"    let api_key = env::var(\"QUOTE_GALLERY_API_KEY\")?;\n",[119,1842,1843],{"class":121,"line":243},[119,1844,214],{"emptyLinePlaceholder":213},[119,1846,1847],{"class":121,"line":282},[119,1848,1849],{},"    let client = reqwest::Client::new();\n",[119,1851,1852],{"class":121,"line":327},[119,1853,1854],{},"    let response = client\n",[119,1856,1857],{"class":121,"line":362},[119,1858,1859],{},"        .get(\"https:\u002F\u002Fquotegallery.nl\u002Fapi\u002Fv1\u002Fquotes?limit=5\")\n",[119,1861,1862],{"class":121,"line":394},[119,1863,1864],{},"        .header(\"X-API-Key\", &api_key)\n",[119,1866,1867],{"class":121,"line":400},[119,1868,1869],{},"        .send()\n",[119,1871,1872],{"class":121,"line":408},[119,1873,1874],{},"        .await?\n",[119,1876,1877],{"class":121,"line":413},[119,1878,1879],{},"        .json::\u003CValue>()\n",[119,1881,1882],{"class":121,"line":446},[119,1883,1884],{},"        .await?;\n",[119,1886,1887],{"class":121,"line":476},[119,1888,214],{"emptyLinePlaceholder":213},[119,1890,1891],{"class":121,"line":483},[119,1892,1893],{},"    println!(\"{:#}\", response);\n",[119,1895,1896],{"class":121,"line":488},[119,1897,1898],{},"    Ok(())\n",[119,1900,1901],{"class":121,"line":511},[119,1902,654],{},[1351,1904],{},[96,1906,1908],{"id":1907},"building-your-own-sdk","Building Your Own SDK",[92,1910,1911],{},"If you're building an SDK or wrapper library for the Quote Gallery API, here are some recommendations:",[1913,1914,1915,1925,1930,1946,1950,1958],"field-group",{},[1916,1917,1920,1921,1924],"field",{"name":1918,"type":1919},"Version the Base URL","important","Always include the API version in the base URL (e.g., ",[116,1922,1923],{},"\u002Fapi\u002Fv1","). This makes it easy to support multiple API versions simultaneously when v2 is released.",[1916,1926,1929],{"name":1927,"type":1928},"Accept a Custom Base URL","recommended","Allow users to override the base URL for testing, proxying, or self-hosted scenarios.",[1916,1931,1933,1934,1937,1938,1941,1942,1945],{"name":1932,"type":1928},"Include Retry Logic","Handle ",[116,1935,1936],{},"429"," and ",[116,1939,1940],{},"5xx"," responses with exponential backoff. Parse the ",[116,1943,1944],{},"X-RateLimit-Reset"," header for optimal retry timing.",[1916,1947,1949],{"name":1948,"type":1928},"Type the Responses","If your language supports it, provide typed response models for all endpoints. This greatly improves developer experience.",[1916,1951,1953,1954,1957],{"name":1952,"type":1928},"Support Environment Variables","Default to reading the API key from ",[116,1955,1956],{},"QUOTE_GALLERY_API_KEY"," environment variable so users don't need to pass it explicitly.",[1916,1959,1961],{"name":1960,"type":1919},"Respect Rate Limits","Expose rate limit information from response headers so consumers can make informed decisions about request pacing.",[1963,1964,1965],"style",{},"html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}",{"title":114,"searchDepth":81,"depth":81,"links":1967},[1968,1972,1973,1980],{"id":98,"depth":81,"text":99,"children":1969},[1970,1971],{"id":103,"depth":38,"text":104},{"id":1123,"depth":38,"text":1124},{"id":1355,"depth":81,"text":1356},{"id":1409,"depth":81,"text":1410,"children":1974},[1975,1976,1977,1978,1979],{"id":1416,"depth":38,"text":1417},{"id":1460,"depth":38,"text":1461},{"id":1555,"depth":38,"text":1556},{"id":1654,"depth":38,"text":1655},{"id":1799,"depth":38,"text":1800},{"id":1907,"depth":81,"text":1908},"Official and community SDKs, libraries, and tools for integrating with the Quote Gallery API.","md",null,{"icon":1985},"i-lucide-package",{"title":75,"description":1981},"gwZB_UEo2pNIFuxFWkhAo3pCW5U46BnHnLJcelTD5KM",[1989,1991],{"title":71,"path":72,"stem":73,"description":1990,"children":-1},"Learn about API error codes, response formats, and best practices for handling errors gracefully.",{"title":62,"path":79,"stem":80,"description":1983,"order":81,"children":-1},1774214573889]