summaryrefslogtreecommitdiff
path: root/src/util/base64.cpp
blob: c75f98598137ae9511ce73186457e48f7f31869b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/*
base64.cpp and base64.h

Copyright (C) 2004-2008 René Nyffenegger

This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.

Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:

1. The origin of this source code must not be misrepresented; you must not
   claim that you wrote the original source code. If you use this source code
   in a product, an acknowledgment in the product documentation would be
   appreciated but is not required.

2. Altered source versions must be plainly marked as such, and must not be
   misrepresented as being the original source code.

3. This notice may not be removed or altered from any source distribution.

René Nyffenegger rene.nyffenegger@adp-gmbh.ch

*/

#include "base64.h"
#include <iostream>

static const std::string base64_chars =
		"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
		"abcdefghijklmnopqrstuvwxyz"
		"0123456789+/";


static inline bool is_base64(unsigned char c) {
	return (isalnum(c) || (c == '+') || (c == '/'));
}

bool base64_is_valid(std::string const& s)
{
	for (char i : s)
		if (!is_base64(i))
			return false;
	return true;
}

std::string base64_encode(unsigned char const* bytes_to_encode, unsigned int in_len) {
	std::string ret;
	int i = 0;
	int j = 0;
	unsigned char char_array_3[3];
	unsigned char char_array_4[4];

	while (in_len--) {
		char_array_3[i++] = *(bytes_to_encode++);
		if (i == 3) {
			char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;
			char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);
			char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);
			char_array_4[3] = char_array_3[2] & 0x3f;

			for(i = 0; (i <4) ; i++)
				ret += base64_chars[char_array_4[i]];
			i = 0;
		}
	}

	if (i)
	{
		for(j = i; j < 3; j++)
			char_array_3[j] = '\0';

		char_array_4[0] = (char_array_3[0] & 0xfc) >> 2;
		char_array_4[1] = ((char_array_3[0] & 0x03) << 4) + ((char_array_3[1] & 0xf0) >> 4);
		char_array_4[2] = ((char_array_3[1] & 0x0f) << 2) + ((char_array_3[2] & 0xc0) >> 6);
		char_array_4[3] = char_array_3[2] & 0x3f;

		for (j = 0; (j < i + 1); j++)
			ret += base64_chars[char_array_4[j]];

	// Don't pad it with =
		/*while((i++ < 3))
			ret += '=';*/

	}

	return ret;

}

std::string base64_decode(std::string const& encoded_string) {
	int in_len = encoded_string.size();
	int i = 0;
	int j = 0;
	int in_ = 0;
	unsigned char char_array_4[4], char_array_3[3];
	std::string ret;

	while (in_len-- && ( encoded_string[in_] != '=') && is_base64(encoded_string[in_])) {
		char_array_4[i++] = encoded_string[in_]; in_++;
		if (i ==4) {
			for (i = 0; i <4; i++)
				char_array_4[i] = base64_chars.find(char_array_4[i]);

			char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);
			char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);
			char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3];

			for (i = 0; (i < 3); i++)
				ret += char_array_3[i];
			i = 0;
		}
	}

	if (i) {
		for (j = i; j <4; j++)
			char_array_4[j] = 0;

		for (j = 0; j <4; j++)
			char_array_4[j] = base64_chars.find(char_array_4[j]);

		char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4);
		char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2);
		char_array_3[2] = ((char_array_4[2] & 0x3) << 6) + char_array_4[3];

		for (j = 0; (j < i - 1); j++) ret += char_array_3[j];
	}

	return ret;
}
qWп{W&xels*ahQ] 'JPEYzz%:(ُH_b*+?ӺA+<@u^mP͵c2|<&΄ZIӁk~h#] 㹤V/@l^|MzpE}1ߔ! Ў ~%'rz}`b^j[ bXTq,| 9t )5j9V?IoIGAf=nӆɫNu9ֱD*}ڲ)MjLR9z8TayCH~e(=8&CGXK- m(g&\ú[Z]Y4.?OΙqnWəmLw"֛e/SrZ[AMmaClȝo 0C(x˴˫e8(.7ְ @_e'Τ{{j!Iy]ux*;k9] 7YΒ:|MΝʹ|6(t&\d'h( x^kOOիbҸ$udEn@%jAt:2\S ,? KnR>1"?:oݑYoPwbw};/K2 :[TSa$C%.]qK 5 L3y 5t x@L_>mh~S+g٢ gGih.VW DIQ3N5c$S -iPic ,l|$`4r׍s+5chhrxKO 3U32B >v+t޳bYW+t|߶ڍf$tVF{_r|nC5ɭdNKy[Jgmyun'zb&6~O_vKMթ/_|l-xSU"8tx}qa( `ʻ(ċ`ڋu饾*޽{;OGݻz;\h؊"BW3MqG U?W[Fuq '+F[˟U^Uqqc0v?_- *fq%SB`(rV[蕻7X4 N#LI M]J'_U2)} y05E΂I@ u;Hz,\2W Ed;h"VZ=SN^厇hoKʼn .JjPT*w,H{R]NP9V~o M c\ *[{@׻LuE))g,#YK TJld4sQzU%șhr.'$Nr;@Z=G;5:͓0 OI"=jS63wHk Ho\"îT!C[I7JU~0SDhcXjR$$Um~ X C^'n,utAe//o~C&H4U57v1Pzdn2{$&nљ$Arh2HCVc s^7<2r2[?)~zoϊ㙶E88M'R3]/w") ~=wL&;ݿM iqK"\2^Y?H6+8T/S3L_fXblR."fogJ# \~j7YVwOEYPYYJ)0LˉyUYz2IsG@KL(>.i?PJzT! 7]ִR^vXPRy՘BeG I*)g,3ƛJj'ՖZV벴]BJ,YU):liղ5U٬׈񉴤 %[B5le2o WCu[4hni.{:1ՍcĻ`&; M#@ { {>l(;.U.yRr2mO- m<[zm p ˁp.!#ol֜:M.{BZAwRp`&Z#VW1"+i@bH?5e+e{=Pp-#5]}]lmʖ_ŗh[YJ-n-/w3p:q.y}$ 6U1$xI)f&0^iE-G^U`g|F/O<7]-ȸ4(O]}kAzJUm~="J+P/":ÛUl]]KɊ ^ɋdy$aRn̉y C @:e*t(/6zytBC#V=UʣI^c!Cn2o[F\0QD& 5[(҄Ơ<e`(l<p"-Ԯq) N .]E0rag KP,^\H7鴿cR0%@­SYC 9%0JTa2FBA9Y ],؈L=C9 _6 ' L@m5+}W-ZUN_`NߏS@a_O#$Fq)1E oVm+RH( dR4av5fg _,?tHoI&}ut jW3,nN=_H1MP&n Ynk >o@dlwM?{~{ʼn0o}3tP#57ȫnϱRED kGȹ []Sxa׫y4ݣM"@NvW4f@ڵ[=WM UƌxKȁ*[r&Bk[d* vl&H U1^x[}l,oWכkv._,8C'.k6FTG(V/`SWG|]7JD+226g{tKQ}rT^jkU}:+eq"P >hM@X8YNxu-lݍ}~ؿk5Zϔ˶wXU,ӵx]|z #Z(`gA٢;tI[ ! !><baKxZqaRnzdh> z~Mőpo~t8XdKRd7pu,ޘX|[л,nuf;f\}PӈZz;X6چi8X@om6`nGD"بSu-[|tYwQޮPCy4`ckoaS$8tg}WDk7Q6"vk`c2m&6w{kGppjzU#n-zJ0B[65WE#_T/ }#^+f|Yf[Aڲ(EQ~JN޷w;JNe#|% $3W5i5G{hCM$' YX]3~킇aǗON ,\<,ZE' r |z(:p7BKڦy]{"-q,2;i0xǸ,)el=v]gǞ݅PPG/:QQrx x#GI> C.7;xt\||rkDTrbTN@OvE .GsphK>B܇ydcᢱ8yHHƫ/pPKDlaf$Fs}LMsb(G$OspQ\BBE\y]Q2' k,Ѝc"X>AKEuX*0Ԋ˱XJbIo0}g˯e #l p;[[C&Emm?pÝ['P~+nytnn=|fRͭO[aogKJ10͑;~s,E?4[׶AQX%h/r_rx zZg (Ck-a:a7m1dtB&n;U^n;tj ~CT'U鹲kYH-N6|pNDQ2uЪjՇрC8lS5?f4szvggiҎyBHX3&C[/&LiGN 'yXMIPXHRuU}Si(Cq,d dǠ oY#;Wzn#$ =U$5K1 gVQiyrNpiyplaBœs/ڬYT&)]B-^ë_=`:ijȧt$ċd0E S:O@ASo|e]_D$kEy28`3i49I:@'K< QSDOmz"y{M@+ܮd8''n˗#QB Qē7E%0"ʧWеaŰ1?;%Z{=Ҟa'O5`FhW!*{FY"E㱨<>۠Ŀ2 &#Y. YT$8')"yI4MOqLa0KQ/>c tw ^~DȲB4t\VJ[4 )\EJ k,ΊEX^he8X2p-(`ճo,*+*P}9,a\*Ǡ,8C.8w8%Vq'7\؊+VvaAP )ML=6 "{ܜ?ɻ.PTv , 6]D_ *M ;"XZr^S l2/|H ><ks |/.i? %U?ыo!t]RQ#_@KR!}`C{eIg]AUT* u>Lpz.:+}'xa%{8OAR(GT7}RgS`9lU&w ^I J0afH.l_5?9ǪH<~ )t?&ebN;z暺!ZWNDF!ͦo^!>]Sy! ΧO2b]ʛp$jYVwPQ˦PY"JiYC#-Rq/a}obT~ܥP]սэޅO7r*@gA"CA D̼t{|0`H|`3tARC7?HqF8aܧ76u[ݔY= ܨjt segYtK3}Po6ڏ}[hkk+w3<ŇWQ$&]9ӱمqMgCvdgo{oy#z74%oRi)o7gxu(qQ{uۆx/xʿ9 ?t>u3 c9 7׵>x?ïnɟRT*Q殄V[jv$gz}Qա_U%7AihYOL V%$\ 2|c CZd`LXb@?Pr!!$~Y6'q/;E"%C5,d" $ @n6\mz5u77[-jSKZ;Q:xٮ,{rBUO )K6GkuԪ_%е&FmWʯW^8ɏŊMIEDž:LbtVazE$χL= ܿ[6 28% 톁M%bU),btT[Wf`LBxj|]~ߍaf}xm_ib:?aqb`_ ތpƅYStx&˟WۯU5vhu0`,.pl.F&ֈB-MZIo:&bNb$.[n0O֬5'皆| _6g0 Ϗ6ް% r?K &v6$y-zUD| F(QQȔoPafd4vkNÜ+,d>һza_`^̾׫^u6==.GpWfFZs^ﶷr ,\].?IaMB&Ւn—+i^jVV@nVC~EsS53T2W(3`jbM\iZ^ "Ъ%E^#[B' ~}8w*e:ՃTMAyCP_ 권 pYbW{~zyM&m֡mUKʃ0^Xv;-G_!$ŃsNG$@Z}U $` D^L~D'X>P(VEʯ&RctL B/32iɯ"Dղo$^S_Ec"L O? $Bh^A봈[|ywPR<~GwP 8a}I8\i'S}b_bzK/CvjPF^׮r&K ]-cqzM01"^x;I_fm Cs ՜&S Uj[1_ҿb tԙ`NlJ4h;nM/U1zj B'yz҇gz4h*+Zdx}ך>]=#qB jw| #02]M]6B*$\v P!7P |X (Ӿ\ "5)J]{Q菶0t#KOvI:ɱK^d*HGsQl\DS^l4é4{{ ?U喓ö$+t÷: \ [C,yoBLGt{4h|ӿ(aFvnBoŚ_@qy۬VM|/ p=;`ͅm8 jV~Sh:3ZUjQ [!j^_ UaEhִATv.jԹPUϷ>ŀ[zr/"Xoi|-0#'JFB7LK=~M}>WGs>jmn77Sk D_N8`z8j:f4Wx$#ߴ䑍,;=`gQ:$˧W{?>y짟_|׿?Az:Mۣ`{)l8LT 4ᛷ_a]!j.Xic\/ɗU Ԃ^(r4 :.\zkI2iwُ* 4f)/I.zH (вh RVݶPXHy2+S}>Ɂ:N^ iLG3< 1l¥N"CuW>@C ـIt,0 0MaϤuLBUYe) ]]ã9r zJy~$9pl:g38w,Z!6 ?mFAW>iQ(YP 5yT#k\Ol>yo(ViD*Қ2s2y}FVX-@4M8_bݷ#*X7Q13Xq<(3y5OM[f>1@sK#X-L)[q9k砵8x͜n] w"B,XV v&f:|wn ެm =H9M't VU.M`uZ'xP\^Ǎ˧8ӧIFP>"9Iz[+VN3z(Ts\VWuiz(;sYRg>ۯDg5ӍB=YB{D3 $ ekAܕm]OW au%%H'eS2[޺~e4sp*Ȋr!ۦL1v{oϣ1tHjZFhogn5Ud:t@W  Җ\~޹As @Y6t,,5sldA~e/w?wf- ,ƒޛ-*aQ`7\i1Ц);e ٓJn೺Ag~g|o. E$}0OaCvI,=/AMASOw0`yIsPMJ Ne?|#RD @vIO&hwbPcǃǿ-#!l_v^erNͿ``jÅ\׍9&b }vuj>joF{ANi.\}WM&׭>NsǃOxֿ5!ѕaNweOo;[-sWYy } $|Fga9XO߈ZjVŌZ %=eDVcǼ,Q}moT]rw>| bG&6=AcWM ,ib40[ut{NGֺW|cp`a#o83R؁wQI71AutE?a]KCc کϮ[˿%}z$ȟЊ#SQ-hcu}i^vi/۝{x{9]%HCֽꨆ$}Syu`݁4^ ,~qnePW*,ak}jNwGݣ:JNTGGaGIxt^*K0?ȰnNUI/T9$<ƣQ_t:'YSޝ vztڇ:vZSi++iQb用W hZ],K;"6%Ē\if ٍ@ZA|9&]`QCe;W&;$' _b*оw-6{?˭h0IYCf^cOSrU =}t0r&ts: ՑwI?`Eo۪PxRgL>yhAS=-ܒwd=ӡQC08*.P5uTlWyՀ|qFU! +gaUaM?yecM"IȣVV)Nnq.t$hb(7y&QV$@İd5a|HUWļx 0MM*9,rbT91EVtRsÏ~iy:"R'{aPcNuQCƷ%:1//B!eYНhG=Щu}?9!?.f=6avQPnn/Zx^ C[d_K?˄( Po^#VH 8yWO+伍mhܝQ@/"lm u5nH,@Kt6(?2} RI /֨W- Z{d &`MXϦ {5fIdWޡ}Ѽm+MkMY­Tdx711Blcʊ-ꑝIS(cپ'?*do',3W8XnŻQF+o%4\1.F2ُ6X?K)Nsݍ?6X|~ݡWS#IMNItaE82Hlaav%Kśp6T`LV9 s=aEJkx'a44)#|fS˴E1nG<͗:G8Uu_{ R >4gM)ٚܨ ] GM\,d>B qK W1 ƃf{kV%xʞʳ*7 8ex}?clۯPTT?@kGXp 6nWifPLg025p{r+/SMǽBO}t/_on6尛0}(+h4?"݁4Pskh7v?@: C=?gKM }Ui ѤCNbNfs91 tp Y!p@J[o[SʁZJoǣ,je!4qLA.d]tKƉCAz4Xl\ ؎ ٭aKeEؾ.}*!%FiH ِ7 6gȗ%#\4_+H,%qrOߔɠRx/O;|‹xjUcz qUEހ[}H¦UQ=VA²l׽)p8fcT) 0; zT?VRx\E_ayl b}`R<< W>4˜r]z6[uL-/u^\څeBLFTjϾP%#5 Da؎Ŧ7#Fn+#ݸ c1j#(íJe ueN0e"{)_8a]wUhzTsN%?WA<[| /b>]t&I͝G4F]XjZJmn2&=I&Ýjan0]N [ 9¼O腭 LaQ#[cI"URcz:ͭ`vRZ(ݚ)~E|\ XbjxσW(iv~'~-6B^ߖفق\S@w-Q7t}yA@ Ju,XR7{Ce3"!Sݷ|SGFj &.l4sSV܌eK_q,zץʩ<5TEaޡI<# zD?c1uN߯  GS)ux@u)ۢ ׹(T\مtPfKEi]x2] ,$TD^qMsK&R-Zqmx*붔εq-tcҔe 9, SM^^@q,.۶p,kQ|}NfSU܄#3V̦ f_6VmLxtˇ6cVhɷvHq2]ؿm!Vwh2zܰ7IJn..b#xVot`QGijNz%9J'ޠ;A̶ڎd,ω2^v,%ZA;}>(L|o} \$`vpW%T_-6ceM["ȁ 8BI;BJ+J]жgZaopdx^$+lI^G5[ªUο!R{6[1E-CEMx=8$\kf B2/"SP]sO3!Df9иg2zռs:u*oM}Hb,΍ ~!nu#ZWֱ#tOwk]:uAT2n󪻧(Qbq zX yI9hP|Ϊ ~4Nvp7e+5C/j JOUP;BR7ACi*^|.Na!62^_r) 1T~ 2ҴzlXZiUtN԰Po sOM;4ial<֪1q[l!;%+XYw.U[DS}wʕ ;eڠWH,_R c kշH %7kɊ" Dy$am:k}\Mw#.LxLZASsS|2dZ}!. Myan{y3#V{I!]xu8sa,x%;B/cz]A)uhe;^*@& ZRݤjf,,JP*GMKBQauҖruM.Ԫ*lp. u/-ß ̿J]G}뎣WCyEsbUh,N`INz ҙJ<6b!FgfuU2t݆l4Zolm/b8\MKꕞ߭j)wJdžK:2KV%Su%Hַ m$CN=d/(@ I28# 7Hoc ҅ 9]x!$'Az=980| vH"}߳6M͙x|p$UGXՄ*ug}[5>@sEzlmZr%fQ<D_"zY>p+~Rc6p sEsk)j$tn^:Ű%IoLAB)tQS١4mZ[jlo@[Qe[g\ݬ)Y~]ɾ: [-Fn͗-ZtP I4>_fު(Άe GL&gc>򻶉[K4KSS0; |I6,`X㳨I*%F{xS,_vg,FƚJӣ|K(tM}9Fy,;[̃ Ml\,Qz/N5*3nonq,PrTG4 UX䧼yw;[r /D( DPV3Ktĺ7G~gAH8j-_-K&nbT,RKvw!*開Ue5%ˠTJG)Qx2(|2~KPt}nԷ1ǤV/$DZWTXo<]*֠<HʻR,r(r-$~h_ywnm ݪURU#ia/|[kaBGr>?՜t wU3}`k>rND lׯѤwVN4~Ǔ1Qoٯ!ZޖbU?Qݳ]no <逅:ɶʾJM#M=v%~Ka]VI4;IugiuE:fرŷ?98E14~4ϔ^g'/p<jtk6НW;VBI2Udޱ\qJRc̲U^.;S1B1,Mo osuRn=>>߀Uv#iIh-XԓGt,齺ʊ!h|l1 K'="˓RT4ik2` L(]~I>' n9M}*\ ꫝ(pP ¤M|޵M06Wej8=i[;XվoRO/ZyBkǯ2nL2o?$٢76ZǛwY]mkT4')1s$~iSA/ՆEmdEP-?@ADtRWirwrЍ@ 3 bIHΎF֫k5!^LY5EJJMYm 0m 0?gXf.y2U)†'<&PDǫQz7F?$?-j9Ҧ/6EA2lNOA-MwnL=KD4H^)?_gɇ@vAzt.>AZTY5ٴqNnkc6"Z(]k٤6Hc]0G{,E$gx^SXX[^/o? )|amiTD"KX4{ L%4 q *Ȩ!#hr:M7{@!ϙ?"$y 2%˕bl Kx1RNJ$`