├── _template.html ├── azure ├── microsoftforums.png ├── stackoverflow.png └── windowsazurelogo.png ├── contact.html ├── css ├── azureopensource.css ├── bootstrap-responsive.css ├── bootstrap-responsive.min.css ├── bootstrap.css └── bootstrap.min.css ├── docs └── Contribution License Agreement.pdf ├── guidelines.html ├── images ├── button-fork.jpg └── button-pull-request.jpg ├── img ├── glyphicons-halflings-white.png └── glyphicons-halflings.png ├── index.html ├── js ├── azure.js ├── bootstrap.js └── bootstrap.min.js ├── projects.html ├── robots.txt └── thanks.html /_template.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | title - Windows Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 70 | 71 |
72 | 73 | 74 | 75 |
76 | 77 | 93 | 94 |
95 | 96 | 97 | 98 | 99 | 100 | 101 | -------------------------------------------------------------------------------- /azure/microsoftforums.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/azure/microsoftforums.png -------------------------------------------------------------------------------- /azure/stackoverflow.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/azure/stackoverflow.png -------------------------------------------------------------------------------- /azure/windowsazurelogo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/azure/windowsazurelogo.png -------------------------------------------------------------------------------- /contact.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Contacts and Support - Microsoft Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 26 | 27 | 74 | 75 |
76 | 77 |

Let's get in touch.

78 | 79 | 89 | 90 |

Forum Support

91 |

You'll find that the community on the Internet is probably the best 92 | way to engage and get answers to your questions.

93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 104 | 105 | 106 | 107 | 108 | 109 | 111 | 112 | 113 | 115 | 116 | 117 |
Forum ProviderTagsNotes
StackOverflow

StackOverflow

azureA friendly, open and fun community of developers.
Microsoft Forums for Microsoft Azure

Microsoft forums

A good place for support and feedback on Microsoft Azure features 114 | and services like Web Sites, Mobile Services, etc.
118 | 119 |

Microsoft Azure Support

120 |

There are support options available for your Microsoft Azure subscription - 121 | you can find more information & submit a support ticket at https://manage.windowsazure.com/?getsupport=true.

123 | 124 |

All accounts include billing support at no cost and there are 125 | paid plans available for additional levels of support.

126 | 127 |

You can read up on this and more on the Microsoft Azure 129 | Support section of the 130 | primary web site.

131 | 132 |

Contacting the team

133 |

Support for the Microsoft Azure SDK is not available direct from 134 | the Microsoft engineers working on the product in an official capacity.

135 | 136 |

If you would like to discuss feature requests or bug fixes, please use 137 | GitHub Issues on the appropriate Microsoft Azure GitHub repository.

138 | 139 |

You may find many members of the team active on Twitter, StackOverflow, 140 | and other venues. Recognize that these conversations and avenues are friendly but 141 | unofficial and do not represent the opinions of Microsoft.

142 | 143 | 144 | 145 |

SDK & Command Line Tools

146 | 147 | 148 | 149 | 160 | 171 | 184 | 185 | 186 | 199 | 212 | 225 | 226 | 227 | 238 | 249 | 250 | 251 | 252 |
150 |

André Rodrigues

151 |

Software Development Engineer
152 | Lisbon, Portugal
153 | Node.js SDK, x-plat CLI

154 |

158 |

159 |
161 |

Jeff Wilcox

162 |

Software Development Lead
163 | Seattle, WA
164 | Microsoft Azure SDK dev team lead

165 |

169 |

170 |
172 |

Mohit Srivastava

173 |

174 | Lead Program Manager
175 | Seattle, WA
176 | SDK PM team lead 177 |

178 |

179 | 182 |

183 |
187 |

Guang Yang

188 |

189 | Program Manager
190 | Redmond, WA
191 | Microsoft Azure PowerShell, CLI; Node.js, Java SDK 192 |

193 |

194 | 197 |

198 |
200 |

Brady Gaster

201 |

202 | Program Manager
203 | Redmond, WA
204 | .NET SDK 205 |

206 |

207 | 210 |

211 |
213 |

Larry Franks

214 |

215 | Senior Programming Writer
216 | Earth
217 | Node.js SDK content 218 |

219 |

220 | 223 |

224 |
228 |

Albert Cheng

229 |

Software Engineer
230 | Redmond, WA
231 | Microsoft Azure SDK for Java & PHP

232 |

236 |

237 |
239 |

Abdelrahman Elogeel

240 |

Software Development Engineer
241 | Redmond, WA
242 | Microsoft Azure PowerShell & PHP SDK

243 |

247 |

248 |
253 | 254 |

Microsoft Azure Service Bus

255 | 256 | 257 | 258 | 269 | 280 | 291 | 292 | 293 |
259 |

Abhishek Lal

260 |

Senior Program Manager
261 | Seattle, WA
262 | Messaging with Queues, Topics and Relay

263 |

267 |

268 |
270 |

Will Perry

271 |

SDET
272 | Seattle, WA
273 | Notification Hubs

274 |

278 |

279 |
281 |

Clemens Vasters

282 |

Principal Program Manager
283 | Germany
284 | Microsoft Azure Service Bus Architect

285 |

289 |

290 |
294 | 295 |

Microsoft Azure Media Services

296 | 297 | 298 | 299 | 310 | 321 | 332 | 333 | 334 | 345 | 356 | 357 | 358 | 359 |
300 |

John Deutscher

301 |

Principal Program Manager
302 | Redmond, WA
303 | Media Services

304 |

308 |

309 |
311 |

Mingfei Yan

312 |

Program Manager
313 | Redmond, WA
314 | Media Services SDKs

315 |

319 |

320 |
322 |

Vishal Sood

323 |

Senior Program Manager
324 | Redmond, WA
325 | Media Services Clients

326 |

330 |

331 |
335 |

George Trifonov

336 |

Developer
337 | Redmond, WA
338 | Media Services .NET SDK

339 |

343 |

344 |
346 |

Milan Gada

347 |

Senior Program Manager
348 | Redmond, WA
349 | Media Services

350 |

354 |

355 |
360 | 361 |

Microsoft Azure Mobile Services

362 | 363 | 364 | 365 | 376 | 387 | 388 | 389 | 390 |
366 |

Josh Twist

367 |

Program Manager
368 | Redmond, WA
369 | Everything Mobile and Mobile Services

370 |

374 |

375 |
377 |

Yavor Georgiev

378 |

Program Manager
379 | Seattle, WA
380 | Mobile Services client SDKs

381 |

385 |

386 |
391 | 392 | 420 | 421 |

Insider Advisors program

422 |

The Microsoft Azure SDK team maintains a number of specialized "insiders" 423 | programs for projects such as the Node.js SDK.

424 | 425 |

The program is rather unofficial and relaxed in nature. Invitation 426 | is often granted as the team sees active community contributions, open 427 | source contributions or other impressive technology feats.

428 | 429 |
430 | 431 | 447 | 448 |
449 | 450 | 451 | 452 | 453 | 454 | -------------------------------------------------------------------------------- /css/azureopensource.css: -------------------------------------------------------------------------------- 1 | /* windowsazure.github.com css customizations 2 | -------------------------------------------------- */ 3 | 4 | body { 5 | padding-top: 90px; 6 | padding-bottom: 40px; 7 | } 8 | 9 | code { 10 | color: #333; 11 | } 12 | 13 | h3 { 14 | font-size: 24.5px; 15 | color: #777; 16 | } 17 | 18 | h1 { 19 | padding-bottom: 20px; 20 | } 21 | 22 | .nav-tabs > .active > a { 23 | background-color: #eee; 24 | color: #333; 25 | } 26 | 27 | .nav-tabs > .active > a:hover { 28 | background-color: #eee; 29 | color: #333; 30 | } 31 | 32 | .azure-nav-list { 33 | width: 228px; 34 | margin: 30px 0 0; 35 | padding: 0; 36 | } 37 | 38 | .azure-nav-list > li > a { 39 | display: block; 40 | width: 190px; 41 | margin: 0 0 -1px; 42 | padding: 4px 12px; 43 | } 44 | 45 | .azure-nav-list.affix { 46 | top: 40px; 47 | } 48 | 49 | .small-sections section { 50 | padding-top: 6px; 51 | } 52 | 53 | section { 54 | padding-top: 42px; 55 | } 56 | 57 | .twitter-cards > tbody > tr > td > h4, 58 | .twitter-cards > tbody > tr > td > p { 59 | text-align: center; 60 | } 61 | 62 | .twitter-cards > tbody >tr > td { 63 | width: 33%; 64 | } 65 | 66 | .social { 67 | text-align: center; 68 | } 69 | 70 | .social-buttons { 71 | margin-left: 0; 72 | margin-bottom: 0; 73 | padding-left: 0; 74 | list-style: none; 75 | } 76 | 77 | .social-buttons li { 78 | display: inline-block; 79 | padding: 5px 8px; 80 | line-height: 1; 81 | *display: inline; 82 | *zoom: 1; 83 | } 84 | 85 | /* Make tables spaced out a bit more */ 86 | h2 + table, 87 | h3 + table, 88 | h4 + table, 89 | h2 + .row { 90 | margin-top: 5px; 91 | } 92 | 93 | /* Responsive parts */ 94 | 95 | /* Desktop large 96 | ------------------------- */ 97 | @media (min-width: 1200px) { 98 | .azure-nav-list { 99 | width: 258px; 100 | } 101 | .azure-nav-list > li > a { 102 | width: 230px; /* Override the previous IE8-9 hack */ 103 | } 104 | } 105 | 106 | /* Desktop 107 | ------------------------- */ 108 | @media (max-width: 980px) { 109 | /* Unfloat brand */ 110 | body > .navbar-fixed-top .brand { 111 | float: left; 112 | margin-left: 0; 113 | padding-left: 10px; 114 | padding-right: 10px; 115 | } 116 | 117 | /* When affixed, space properly */ 118 | .azure-nav-list { 119 | top: 0; 120 | width: 218px; 121 | margin-top: 30px; 122 | margin-right: 0; 123 | } 124 | } 125 | 126 | /* Tablet to desktop 127 | ------------------------- */ 128 | @media (min-width: 768px) and (max-width: 979px) { 129 | /* Remove any padding from the body */ 130 | body { 131 | padding-top: 0; 132 | } 133 | /* Adjust sidenav width */ 134 | .azure-nav-list { 135 | width: 166px; 136 | margin-top: 20px; 137 | } 138 | .azure-nav-list.affix { 139 | top: 0; 140 | } 141 | } 142 | 143 | /* Tablet 144 | ------------------------- */ 145 | @media (max-width: 767px) { 146 | /* Remove any padding from the body */ 147 | body { 148 | padding-top: 0; 149 | } 150 | 151 | /* Sidenav */ 152 | .azure-nav-list { 153 | width: auto; 154 | margin-bottom: 20px; 155 | } 156 | .azure-nav-list.affix { 157 | position: static; 158 | width: auto; 159 | top: 0; 160 | } 161 | 162 | /* Unfloat the back to top link in footer */ 163 | .footer { 164 | margin-left: -20px; 165 | margin-right: -20px; 166 | padding-left: 20px; 167 | padding-right: 20px; 168 | } 169 | .footer p { 170 | margin-bottom: 9px; 171 | } 172 | } 173 | 174 | /* Landscape phones 175 | ------------------------- */ 176 | @media (max-width: 480px) { 177 | /* Remove padding above jumbotron */ 178 | body { 179 | padding-top: 0; 180 | } 181 | 182 | /* Change up some type stuff */ 183 | h2 small { 184 | display: block; 185 | } 186 | 187 | /* center align subhead text like the masthead */ 188 | .subhead h1, 189 | .subhead p { 190 | text-align: center; 191 | } 192 | 193 | /* Do our best to make tables work in narrow viewports */ 194 | table code { 195 | white-space: normal; 196 | word-wrap: break-word; 197 | word-break: break-all; 198 | } 199 | 200 | /* Tighten up footer */ 201 | .footer { 202 | padding-top: 20px; 203 | padding-bottom: 20px; 204 | } 205 | } 206 | -------------------------------------------------------------------------------- /css/bootstrap-responsive.css: -------------------------------------------------------------------------------- 1 | /*! 2 | * Bootstrap Responsive v2.3.0 3 | * 4 | * Copyright 2012 Twitter, Inc 5 | * Licensed under the Apache License v2.0 6 | * http://www.apache.org/licenses/LICENSE-2.0 7 | * 8 | * Designed and built with all the love in the world @twitter by @mdo and @fat. 9 | */ 10 | 11 | .clearfix { 12 | *zoom: 1; 13 | } 14 | 15 | .clearfix:before, 16 | .clearfix:after { 17 | display: table; 18 | line-height: 0; 19 | content: ""; 20 | } 21 | 22 | .clearfix:after { 23 | clear: both; 24 | } 25 | 26 | .hide-text { 27 | font: 0/0 a; 28 | color: transparent; 29 | text-shadow: none; 30 | background-color: transparent; 31 | border: 0; 32 | } 33 | 34 | .input-block-level { 35 | display: block; 36 | width: 100%; 37 | min-height: 30px; 38 | -webkit-box-sizing: border-box; 39 | -moz-box-sizing: border-box; 40 | box-sizing: border-box; 41 | } 42 | 43 | @-ms-viewport { 44 | width: device-width; 45 | } 46 | 47 | .hidden { 48 | display: none; 49 | visibility: hidden; 50 | } 51 | 52 | .visible-phone { 53 | display: none !important; 54 | } 55 | 56 | .visible-tablet { 57 | display: none !important; 58 | } 59 | 60 | .hidden-desktop { 61 | display: none !important; 62 | } 63 | 64 | .visible-desktop { 65 | display: inherit !important; 66 | } 67 | 68 | @media (min-width: 768px) and (max-width: 979px) { 69 | .hidden-desktop { 70 | display: inherit !important; 71 | } 72 | .visible-desktop { 73 | display: none !important ; 74 | } 75 | .visible-tablet { 76 | display: inherit !important; 77 | } 78 | .hidden-tablet { 79 | display: none !important; 80 | } 81 | } 82 | 83 | @media (max-width: 767px) { 84 | .hidden-desktop { 85 | display: inherit !important; 86 | } 87 | .visible-desktop { 88 | display: none !important; 89 | } 90 | .visible-phone { 91 | display: inherit !important; 92 | } 93 | .hidden-phone { 94 | display: none !important; 95 | } 96 | } 97 | 98 | .visible-print { 99 | display: none !important; 100 | } 101 | 102 | @media print { 103 | .visible-print { 104 | display: inherit !important; 105 | } 106 | .hidden-print { 107 | display: none !important; 108 | } 109 | } 110 | 111 | @media (min-width: 1200px) { 112 | .row { 113 | margin-left: -30px; 114 | *zoom: 1; 115 | } 116 | .row:before, 117 | .row:after { 118 | display: table; 119 | line-height: 0; 120 | content: ""; 121 | } 122 | .row:after { 123 | clear: both; 124 | } 125 | [class*="span"] { 126 | float: left; 127 | min-height: 1px; 128 | margin-left: 30px; 129 | } 130 | .container, 131 | .navbar-static-top .container, 132 | .navbar-fixed-top .container, 133 | .navbar-fixed-bottom .container { 134 | width: 1170px; 135 | } 136 | .span12 { 137 | width: 1170px; 138 | } 139 | .span11 { 140 | width: 1070px; 141 | } 142 | .span10 { 143 | width: 970px; 144 | } 145 | .span9 { 146 | width: 870px; 147 | } 148 | .span8 { 149 | width: 770px; 150 | } 151 | .span7 { 152 | width: 670px; 153 | } 154 | .span6 { 155 | width: 570px; 156 | } 157 | .span5 { 158 | width: 470px; 159 | } 160 | .span4 { 161 | width: 370px; 162 | } 163 | .span3 { 164 | width: 270px; 165 | } 166 | .span2 { 167 | width: 170px; 168 | } 169 | .span1 { 170 | width: 70px; 171 | } 172 | .offset12 { 173 | margin-left: 1230px; 174 | } 175 | .offset11 { 176 | margin-left: 1130px; 177 | } 178 | .offset10 { 179 | margin-left: 1030px; 180 | } 181 | .offset9 { 182 | margin-left: 930px; 183 | } 184 | .offset8 { 185 | margin-left: 830px; 186 | } 187 | .offset7 { 188 | margin-left: 730px; 189 | } 190 | .offset6 { 191 | margin-left: 630px; 192 | } 193 | .offset5 { 194 | margin-left: 530px; 195 | } 196 | .offset4 { 197 | margin-left: 430px; 198 | } 199 | .offset3 { 200 | margin-left: 330px; 201 | } 202 | .offset2 { 203 | margin-left: 230px; 204 | } 205 | .offset1 { 206 | margin-left: 130px; 207 | } 208 | .row-fluid { 209 | width: 100%; 210 | *zoom: 1; 211 | } 212 | .row-fluid:before, 213 | .row-fluid:after { 214 | display: table; 215 | line-height: 0; 216 | content: ""; 217 | } 218 | .row-fluid:after { 219 | clear: both; 220 | } 221 | .row-fluid [class*="span"] { 222 | display: block; 223 | float: left; 224 | width: 100%; 225 | min-height: 30px; 226 | margin-left: 2.564102564102564%; 227 | *margin-left: 2.5109110747408616%; 228 | -webkit-box-sizing: border-box; 229 | -moz-box-sizing: border-box; 230 | box-sizing: border-box; 231 | } 232 | .row-fluid [class*="span"]:first-child { 233 | margin-left: 0; 234 | } 235 | .row-fluid .controls-row [class*="span"] + [class*="span"] { 236 | margin-left: 2.564102564102564%; 237 | } 238 | .row-fluid .span12 { 239 | width: 100%; 240 | *width: 99.94680851063829%; 241 | } 242 | .row-fluid .span11 { 243 | width: 91.45299145299145%; 244 | *width: 91.39979996362975%; 245 | } 246 | .row-fluid .span10 { 247 | width: 82.90598290598291%; 248 | *width: 82.8527914166212%; 249 | } 250 | .row-fluid .span9 { 251 | width: 74.35897435897436%; 252 | *width: 74.30578286961266%; 253 | } 254 | .row-fluid .span8 { 255 | width: 65.81196581196582%; 256 | *width: 65.75877432260411%; 257 | } 258 | .row-fluid .span7 { 259 | width: 57.26495726495726%; 260 | *width: 57.21176577559556%; 261 | } 262 | .row-fluid .span6 { 263 | width: 48.717948717948715%; 264 | *width: 48.664757228587014%; 265 | } 266 | .row-fluid .span5 { 267 | width: 40.17094017094017%; 268 | *width: 40.11774868157847%; 269 | } 270 | .row-fluid .span4 { 271 | width: 31.623931623931625%; 272 | *width: 31.570740134569924%; 273 | } 274 | .row-fluid .span3 { 275 | width: 23.076923076923077%; 276 | *width: 23.023731587561375%; 277 | } 278 | .row-fluid .span2 { 279 | width: 14.52991452991453%; 280 | *width: 14.476723040552828%; 281 | } 282 | .row-fluid .span1 { 283 | width: 5.982905982905983%; 284 | *width: 5.929714493544281%; 285 | } 286 | .row-fluid .offset12 { 287 | margin-left: 105.12820512820512%; 288 | *margin-left: 105.02182214948171%; 289 | } 290 | .row-fluid .offset12:first-child { 291 | margin-left: 102.56410256410257%; 292 | *margin-left: 102.45771958537915%; 293 | } 294 | .row-fluid .offset11 { 295 | margin-left: 96.58119658119658%; 296 | *margin-left: 96.47481360247316%; 297 | } 298 | .row-fluid .offset11:first-child { 299 | margin-left: 94.01709401709402%; 300 | *margin-left: 93.91071103837061%; 301 | } 302 | .row-fluid .offset10 { 303 | margin-left: 88.03418803418803%; 304 | *margin-left: 87.92780505546462%; 305 | } 306 | .row-fluid .offset10:first-child { 307 | margin-left: 85.47008547008548%; 308 | *margin-left: 85.36370249136206%; 309 | } 310 | .row-fluid .offset9 { 311 | margin-left: 79.48717948717949%; 312 | *margin-left: 79.38079650845607%; 313 | } 314 | .row-fluid .offset9:first-child { 315 | margin-left: 76.92307692307693%; 316 | *margin-left: 76.81669394435352%; 317 | } 318 | .row-fluid .offset8 { 319 | margin-left: 70.94017094017094%; 320 | *margin-left: 70.83378796144753%; 321 | } 322 | .row-fluid .offset8:first-child { 323 | margin-left: 68.37606837606839%; 324 | *margin-left: 68.26968539734497%; 325 | } 326 | .row-fluid .offset7 { 327 | margin-left: 62.393162393162385%; 328 | *margin-left: 62.28677941443899%; 329 | } 330 | .row-fluid .offset7:first-child { 331 | margin-left: 59.82905982905982%; 332 | *margin-left: 59.72267685033642%; 333 | } 334 | .row-fluid .offset6 { 335 | margin-left: 53.84615384615384%; 336 | *margin-left: 53.739770867430444%; 337 | } 338 | .row-fluid .offset6:first-child { 339 | margin-left: 51.28205128205128%; 340 | *margin-left: 51.175668303327875%; 341 | } 342 | .row-fluid .offset5 { 343 | margin-left: 45.299145299145295%; 344 | *margin-left: 45.1927623204219%; 345 | } 346 | .row-fluid .offset5:first-child { 347 | margin-left: 42.73504273504273%; 348 | *margin-left: 42.62865975631933%; 349 | } 350 | .row-fluid .offset4 { 351 | margin-left: 36.75213675213675%; 352 | *margin-left: 36.645753773413354%; 353 | } 354 | .row-fluid .offset4:first-child { 355 | margin-left: 34.18803418803419%; 356 | *margin-left: 34.081651209310785%; 357 | } 358 | .row-fluid .offset3 { 359 | margin-left: 28.205128205128204%; 360 | *margin-left: 28.0987452264048%; 361 | } 362 | .row-fluid .offset3:first-child { 363 | margin-left: 25.641025641025642%; 364 | *margin-left: 25.53464266230224%; 365 | } 366 | .row-fluid .offset2 { 367 | margin-left: 19.65811965811966%; 368 | *margin-left: 19.551736679396257%; 369 | } 370 | .row-fluid .offset2:first-child { 371 | margin-left: 17.094017094017094%; 372 | *margin-left: 16.98763411529369%; 373 | } 374 | .row-fluid .offset1 { 375 | margin-left: 11.11111111111111%; 376 | *margin-left: 11.004728132387708%; 377 | } 378 | .row-fluid .offset1:first-child { 379 | margin-left: 8.547008547008547%; 380 | *margin-left: 8.440625568285142%; 381 | } 382 | input, 383 | textarea, 384 | .uneditable-input { 385 | margin-left: 0; 386 | } 387 | .controls-row [class*="span"] + [class*="span"] { 388 | margin-left: 30px; 389 | } 390 | input.span12, 391 | textarea.span12, 392 | .uneditable-input.span12 { 393 | width: 1156px; 394 | } 395 | input.span11, 396 | textarea.span11, 397 | .uneditable-input.span11 { 398 | width: 1056px; 399 | } 400 | input.span10, 401 | textarea.span10, 402 | .uneditable-input.span10 { 403 | width: 956px; 404 | } 405 | input.span9, 406 | textarea.span9, 407 | .uneditable-input.span9 { 408 | width: 856px; 409 | } 410 | input.span8, 411 | textarea.span8, 412 | .uneditable-input.span8 { 413 | width: 756px; 414 | } 415 | input.span7, 416 | textarea.span7, 417 | .uneditable-input.span7 { 418 | width: 656px; 419 | } 420 | input.span6, 421 | textarea.span6, 422 | .uneditable-input.span6 { 423 | width: 556px; 424 | } 425 | input.span5, 426 | textarea.span5, 427 | .uneditable-input.span5 { 428 | width: 456px; 429 | } 430 | input.span4, 431 | textarea.span4, 432 | .uneditable-input.span4 { 433 | width: 356px; 434 | } 435 | input.span3, 436 | textarea.span3, 437 | .uneditable-input.span3 { 438 | width: 256px; 439 | } 440 | input.span2, 441 | textarea.span2, 442 | .uneditable-input.span2 { 443 | width: 156px; 444 | } 445 | input.span1, 446 | textarea.span1, 447 | .uneditable-input.span1 { 448 | width: 56px; 449 | } 450 | .thumbnails { 451 | margin-left: -30px; 452 | } 453 | .thumbnails > li { 454 | margin-left: 30px; 455 | } 456 | .row-fluid .thumbnails { 457 | margin-left: 0; 458 | } 459 | } 460 | 461 | @media (min-width: 768px) and (max-width: 979px) { 462 | .row { 463 | margin-left: -20px; 464 | *zoom: 1; 465 | } 466 | .row:before, 467 | .row:after { 468 | display: table; 469 | line-height: 0; 470 | content: ""; 471 | } 472 | .row:after { 473 | clear: both; 474 | } 475 | [class*="span"] { 476 | float: left; 477 | min-height: 1px; 478 | margin-left: 20px; 479 | } 480 | .container, 481 | .navbar-static-top .container, 482 | .navbar-fixed-top .container, 483 | .navbar-fixed-bottom .container { 484 | width: 724px; 485 | } 486 | .span12 { 487 | width: 724px; 488 | } 489 | .span11 { 490 | width: 662px; 491 | } 492 | .span10 { 493 | width: 600px; 494 | } 495 | .span9 { 496 | width: 538px; 497 | } 498 | .span8 { 499 | width: 476px; 500 | } 501 | .span7 { 502 | width: 414px; 503 | } 504 | .span6 { 505 | width: 352px; 506 | } 507 | .span5 { 508 | width: 290px; 509 | } 510 | .span4 { 511 | width: 228px; 512 | } 513 | .span3 { 514 | width: 166px; 515 | } 516 | .span2 { 517 | width: 104px; 518 | } 519 | .span1 { 520 | width: 42px; 521 | } 522 | .offset12 { 523 | margin-left: 764px; 524 | } 525 | .offset11 { 526 | margin-left: 702px; 527 | } 528 | .offset10 { 529 | margin-left: 640px; 530 | } 531 | .offset9 { 532 | margin-left: 578px; 533 | } 534 | .offset8 { 535 | margin-left: 516px; 536 | } 537 | .offset7 { 538 | margin-left: 454px; 539 | } 540 | .offset6 { 541 | margin-left: 392px; 542 | } 543 | .offset5 { 544 | margin-left: 330px; 545 | } 546 | .offset4 { 547 | margin-left: 268px; 548 | } 549 | .offset3 { 550 | margin-left: 206px; 551 | } 552 | .offset2 { 553 | margin-left: 144px; 554 | } 555 | .offset1 { 556 | margin-left: 82px; 557 | } 558 | .row-fluid { 559 | width: 100%; 560 | *zoom: 1; 561 | } 562 | .row-fluid:before, 563 | .row-fluid:after { 564 | display: table; 565 | line-height: 0; 566 | content: ""; 567 | } 568 | .row-fluid:after { 569 | clear: both; 570 | } 571 | .row-fluid [class*="span"] { 572 | display: block; 573 | float: left; 574 | width: 100%; 575 | min-height: 30px; 576 | margin-left: 2.7624309392265194%; 577 | *margin-left: 2.709239449864817%; 578 | -webkit-box-sizing: border-box; 579 | -moz-box-sizing: border-box; 580 | box-sizing: border-box; 581 | } 582 | .row-fluid [class*="span"]:first-child { 583 | margin-left: 0; 584 | } 585 | .row-fluid .controls-row [class*="span"] + [class*="span"] { 586 | margin-left: 2.7624309392265194%; 587 | } 588 | .row-fluid .span12 { 589 | width: 100%; 590 | *width: 99.94680851063829%; 591 | } 592 | .row-fluid .span11 { 593 | width: 91.43646408839778%; 594 | *width: 91.38327259903608%; 595 | } 596 | .row-fluid .span10 { 597 | width: 82.87292817679558%; 598 | *width: 82.81973668743387%; 599 | } 600 | .row-fluid .span9 { 601 | width: 74.30939226519337%; 602 | *width: 74.25620077583166%; 603 | } 604 | .row-fluid .span8 { 605 | width: 65.74585635359117%; 606 | *width: 65.69266486422946%; 607 | } 608 | .row-fluid .span7 { 609 | width: 57.18232044198895%; 610 | *width: 57.12912895262725%; 611 | } 612 | .row-fluid .span6 { 613 | width: 48.61878453038674%; 614 | *width: 48.56559304102504%; 615 | } 616 | .row-fluid .span5 { 617 | width: 40.05524861878453%; 618 | *width: 40.00205712942283%; 619 | } 620 | .row-fluid .span4 { 621 | width: 31.491712707182323%; 622 | *width: 31.43852121782062%; 623 | } 624 | .row-fluid .span3 { 625 | width: 22.92817679558011%; 626 | *width: 22.87498530621841%; 627 | } 628 | .row-fluid .span2 { 629 | width: 14.3646408839779%; 630 | *width: 14.311449394616199%; 631 | } 632 | .row-fluid .span1 { 633 | width: 5.801104972375691%; 634 | *width: 5.747913483013988%; 635 | } 636 | .row-fluid .offset12 { 637 | margin-left: 105.52486187845304%; 638 | *margin-left: 105.41847889972962%; 639 | } 640 | .row-fluid .offset12:first-child { 641 | margin-left: 102.76243093922652%; 642 | *margin-left: 102.6560479605031%; 643 | } 644 | .row-fluid .offset11 { 645 | margin-left: 96.96132596685082%; 646 | *margin-left: 96.8549429881274%; 647 | } 648 | .row-fluid .offset11:first-child { 649 | margin-left: 94.1988950276243%; 650 | *margin-left: 94.09251204890089%; 651 | } 652 | .row-fluid .offset10 { 653 | margin-left: 88.39779005524862%; 654 | *margin-left: 88.2914070765252%; 655 | } 656 | .row-fluid .offset10:first-child { 657 | margin-left: 85.6353591160221%; 658 | *margin-left: 85.52897613729868%; 659 | } 660 | .row-fluid .offset9 { 661 | margin-left: 79.8342541436464%; 662 | *margin-left: 79.72787116492299%; 663 | } 664 | .row-fluid .offset9:first-child { 665 | margin-left: 77.07182320441989%; 666 | *margin-left: 76.96544022569647%; 667 | } 668 | .row-fluid .offset8 { 669 | margin-left: 71.2707182320442%; 670 | *margin-left: 71.16433525332079%; 671 | } 672 | .row-fluid .offset8:first-child { 673 | margin-left: 68.50828729281768%; 674 | *margin-left: 68.40190431409427%; 675 | } 676 | .row-fluid .offset7 { 677 | margin-left: 62.70718232044199%; 678 | *margin-left: 62.600799341718584%; 679 | } 680 | .row-fluid .offset7:first-child { 681 | margin-left: 59.94475138121547%; 682 | *margin-left: 59.838368402492065%; 683 | } 684 | .row-fluid .offset6 { 685 | margin-left: 54.14364640883978%; 686 | *margin-left: 54.037263430116376%; 687 | } 688 | .row-fluid .offset6:first-child { 689 | margin-left: 51.38121546961326%; 690 | *margin-left: 51.27483249088986%; 691 | } 692 | .row-fluid .offset5 { 693 | margin-left: 45.58011049723757%; 694 | *margin-left: 45.47372751851417%; 695 | } 696 | .row-fluid .offset5:first-child { 697 | margin-left: 42.81767955801105%; 698 | *margin-left: 42.71129657928765%; 699 | } 700 | .row-fluid .offset4 { 701 | margin-left: 37.01657458563536%; 702 | *margin-left: 36.91019160691196%; 703 | } 704 | .row-fluid .offset4:first-child { 705 | margin-left: 34.25414364640884%; 706 | *margin-left: 34.14776066768544%; 707 | } 708 | .row-fluid .offset3 { 709 | margin-left: 28.45303867403315%; 710 | *margin-left: 28.346655695309746%; 711 | } 712 | .row-fluid .offset3:first-child { 713 | margin-left: 25.69060773480663%; 714 | *margin-left: 25.584224756083227%; 715 | } 716 | .row-fluid .offset2 { 717 | margin-left: 19.88950276243094%; 718 | *margin-left: 19.783119783707537%; 719 | } 720 | .row-fluid .offset2:first-child { 721 | margin-left: 17.12707182320442%; 722 | *margin-left: 17.02068884448102%; 723 | } 724 | .row-fluid .offset1 { 725 | margin-left: 11.32596685082873%; 726 | *margin-left: 11.219583872105325%; 727 | } 728 | .row-fluid .offset1:first-child { 729 | margin-left: 8.56353591160221%; 730 | *margin-left: 8.457152932878806%; 731 | } 732 | input, 733 | textarea, 734 | .uneditable-input { 735 | margin-left: 0; 736 | } 737 | .controls-row [class*="span"] + [class*="span"] { 738 | margin-left: 20px; 739 | } 740 | input.span12, 741 | textarea.span12, 742 | .uneditable-input.span12 { 743 | width: 710px; 744 | } 745 | input.span11, 746 | textarea.span11, 747 | .uneditable-input.span11 { 748 | width: 648px; 749 | } 750 | input.span10, 751 | textarea.span10, 752 | .uneditable-input.span10 { 753 | width: 586px; 754 | } 755 | input.span9, 756 | textarea.span9, 757 | .uneditable-input.span9 { 758 | width: 524px; 759 | } 760 | input.span8, 761 | textarea.span8, 762 | .uneditable-input.span8 { 763 | width: 462px; 764 | } 765 | input.span7, 766 | textarea.span7, 767 | .uneditable-input.span7 { 768 | width: 400px; 769 | } 770 | input.span6, 771 | textarea.span6, 772 | .uneditable-input.span6 { 773 | width: 338px; 774 | } 775 | input.span5, 776 | textarea.span5, 777 | .uneditable-input.span5 { 778 | width: 276px; 779 | } 780 | input.span4, 781 | textarea.span4, 782 | .uneditable-input.span4 { 783 | width: 214px; 784 | } 785 | input.span3, 786 | textarea.span3, 787 | .uneditable-input.span3 { 788 | width: 152px; 789 | } 790 | input.span2, 791 | textarea.span2, 792 | .uneditable-input.span2 { 793 | width: 90px; 794 | } 795 | input.span1, 796 | textarea.span1, 797 | .uneditable-input.span1 { 798 | width: 28px; 799 | } 800 | } 801 | 802 | @media (max-width: 767px) { 803 | body { 804 | padding-right: 20px; 805 | padding-left: 20px; 806 | } 807 | .navbar-fixed-top, 808 | .navbar-fixed-bottom, 809 | .navbar-static-top { 810 | margin-right: -20px; 811 | margin-left: -20px; 812 | } 813 | .container-fluid { 814 | padding: 0; 815 | } 816 | .dl-horizontal dt { 817 | float: none; 818 | width: auto; 819 | clear: none; 820 | text-align: left; 821 | } 822 | .dl-horizontal dd { 823 | margin-left: 0; 824 | } 825 | .container { 826 | width: auto; 827 | } 828 | .row-fluid { 829 | width: 100%; 830 | } 831 | .row, 832 | .thumbnails { 833 | margin-left: 0; 834 | } 835 | .thumbnails > li { 836 | float: none; 837 | margin-left: 0; 838 | } 839 | [class*="span"], 840 | .uneditable-input[class*="span"], 841 | .row-fluid [class*="span"] { 842 | display: block; 843 | float: none; 844 | width: 100%; 845 | margin-left: 0; 846 | -webkit-box-sizing: border-box; 847 | -moz-box-sizing: border-box; 848 | box-sizing: border-box; 849 | } 850 | .span12, 851 | .row-fluid .span12 { 852 | width: 100%; 853 | -webkit-box-sizing: border-box; 854 | -moz-box-sizing: border-box; 855 | box-sizing: border-box; 856 | } 857 | .row-fluid [class*="offset"]:first-child { 858 | margin-left: 0; 859 | } 860 | .input-large, 861 | .input-xlarge, 862 | .input-xxlarge, 863 | input[class*="span"], 864 | select[class*="span"], 865 | textarea[class*="span"], 866 | .uneditable-input { 867 | display: block; 868 | width: 100%; 869 | min-height: 30px; 870 | -webkit-box-sizing: border-box; 871 | -moz-box-sizing: border-box; 872 | box-sizing: border-box; 873 | } 874 | .input-prepend input, 875 | .input-append input, 876 | .input-prepend input[class*="span"], 877 | .input-append input[class*="span"] { 878 | display: inline-block; 879 | width: auto; 880 | } 881 | .controls-row [class*="span"] + [class*="span"] { 882 | margin-left: 0; 883 | } 884 | .modal { 885 | position: fixed; 886 | top: 20px; 887 | right: 20px; 888 | left: 20px; 889 | width: auto; 890 | margin: 0; 891 | } 892 | .modal.fade { 893 | top: -100px; 894 | } 895 | .modal.fade.in { 896 | top: 20px; 897 | } 898 | } 899 | 900 | @media (max-width: 480px) { 901 | .nav-collapse { 902 | -webkit-transform: translate3d(0, 0, 0); 903 | } 904 | .page-header h1 small { 905 | display: block; 906 | line-height: 20px; 907 | } 908 | input[type="checkbox"], 909 | input[type="radio"] { 910 | border: 1px solid #ccc; 911 | } 912 | .form-horizontal .control-label { 913 | float: none; 914 | width: auto; 915 | padding-top: 0; 916 | text-align: left; 917 | } 918 | .form-horizontal .controls { 919 | margin-left: 0; 920 | } 921 | .form-horizontal .control-list { 922 | padding-top: 0; 923 | } 924 | .form-horizontal .form-actions { 925 | padding-right: 10px; 926 | padding-left: 10px; 927 | } 928 | .media .pull-left, 929 | .media .pull-right { 930 | display: block; 931 | float: none; 932 | margin-bottom: 10px; 933 | } 934 | .media-object { 935 | margin-right: 0; 936 | margin-left: 0; 937 | } 938 | .modal { 939 | top: 10px; 940 | right: 10px; 941 | left: 10px; 942 | } 943 | .modal-header .close { 944 | padding: 10px; 945 | margin: -10px; 946 | } 947 | .carousel-caption { 948 | position: static; 949 | } 950 | } 951 | 952 | @media (max-width: 979px) { 953 | body { 954 | padding-top: 0; 955 | } 956 | .navbar-fixed-top, 957 | .navbar-fixed-bottom { 958 | position: static; 959 | } 960 | .navbar-fixed-top { 961 | margin-bottom: 20px; 962 | } 963 | .navbar-fixed-bottom { 964 | margin-top: 20px; 965 | } 966 | .navbar-fixed-top .navbar-inner, 967 | .navbar-fixed-bottom .navbar-inner { 968 | padding: 5px; 969 | } 970 | .navbar .container { 971 | width: auto; 972 | padding: 0; 973 | } 974 | .navbar .brand { 975 | padding-right: 10px; 976 | padding-left: 10px; 977 | margin: 0 0 0 -5px; 978 | } 979 | .nav-collapse { 980 | clear: both; 981 | } 982 | .nav-collapse .nav { 983 | float: none; 984 | margin: 0 0 10px; 985 | } 986 | .nav-collapse .nav > li { 987 | float: none; 988 | } 989 | .nav-collapse .nav > li > a { 990 | margin-bottom: 2px; 991 | } 992 | .nav-collapse .nav > .divider-vertical { 993 | display: none; 994 | } 995 | .nav-collapse .nav .nav-header { 996 | color: #777777; 997 | text-shadow: none; 998 | } 999 | .nav-collapse .nav > li > a, 1000 | .nav-collapse .dropdown-menu a { 1001 | padding: 9px 15px; 1002 | font-weight: bold; 1003 | color: #777777; 1004 | -webkit-border-radius: 3px; 1005 | -moz-border-radius: 3px; 1006 | border-radius: 3px; 1007 | } 1008 | .nav-collapse .btn { 1009 | padding: 4px 10px 4px; 1010 | font-weight: normal; 1011 | -webkit-border-radius: 4px; 1012 | -moz-border-radius: 4px; 1013 | border-radius: 4px; 1014 | } 1015 | .nav-collapse .dropdown-menu li + li a { 1016 | margin-bottom: 2px; 1017 | } 1018 | .nav-collapse .nav > li > a:hover, 1019 | .nav-collapse .nav > li > a:focus, 1020 | .nav-collapse .dropdown-menu a:hover, 1021 | .nav-collapse .dropdown-menu a:focus { 1022 | background-color: #f2f2f2; 1023 | } 1024 | .navbar-inverse .nav-collapse .nav > li > a, 1025 | .navbar-inverse .nav-collapse .dropdown-menu a { 1026 | color: #999999; 1027 | } 1028 | .navbar-inverse .nav-collapse .nav > li > a:hover, 1029 | .navbar-inverse .nav-collapse .nav > li > a:focus, 1030 | .navbar-inverse .nav-collapse .dropdown-menu a:hover, 1031 | .navbar-inverse .nav-collapse .dropdown-menu a:focus { 1032 | background-color: #111111; 1033 | } 1034 | .nav-collapse.in .btn-group { 1035 | padding: 0; 1036 | margin-top: 5px; 1037 | } 1038 | .nav-collapse .dropdown-menu { 1039 | position: static; 1040 | top: auto; 1041 | left: auto; 1042 | display: none; 1043 | float: none; 1044 | max-width: none; 1045 | padding: 0; 1046 | margin: 0 15px; 1047 | background-color: transparent; 1048 | border: none; 1049 | -webkit-border-radius: 0; 1050 | -moz-border-radius: 0; 1051 | border-radius: 0; 1052 | -webkit-box-shadow: none; 1053 | -moz-box-shadow: none; 1054 | box-shadow: none; 1055 | } 1056 | .nav-collapse .open > .dropdown-menu { 1057 | display: block; 1058 | } 1059 | .nav-collapse .dropdown-menu:before, 1060 | .nav-collapse .dropdown-menu:after { 1061 | display: none; 1062 | } 1063 | .nav-collapse .dropdown-menu .divider { 1064 | display: none; 1065 | } 1066 | .nav-collapse .nav > li > .dropdown-menu:before, 1067 | .nav-collapse .nav > li > .dropdown-menu:after { 1068 | display: none; 1069 | } 1070 | .nav-collapse .navbar-form, 1071 | .nav-collapse .navbar-search { 1072 | float: none; 1073 | padding: 10px 15px; 1074 | margin: 10px 0; 1075 | border-top: 1px solid #f2f2f2; 1076 | border-bottom: 1px solid #f2f2f2; 1077 | -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1); 1078 | -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1); 1079 | box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1); 1080 | } 1081 | .navbar-inverse .nav-collapse .navbar-form, 1082 | .navbar-inverse .nav-collapse .navbar-search { 1083 | border-top-color: #111111; 1084 | border-bottom-color: #111111; 1085 | } 1086 | .navbar .nav-collapse .nav.pull-right { 1087 | float: none; 1088 | margin-left: 0; 1089 | } 1090 | .nav-collapse, 1091 | .nav-collapse.collapse { 1092 | height: 0; 1093 | overflow: hidden; 1094 | } 1095 | .navbar .btn-navbar { 1096 | display: block; 1097 | } 1098 | .navbar-static .navbar-inner { 1099 | padding-right: 10px; 1100 | padding-left: 10px; 1101 | } 1102 | } 1103 | 1104 | @media (min-width: 980px) { 1105 | .nav-collapse.collapse { 1106 | height: auto !important; 1107 | overflow: visible !important; 1108 | } 1109 | } 1110 | -------------------------------------------------------------------------------- /css/bootstrap-responsive.min.css: -------------------------------------------------------------------------------- 1 | /*! 2 | * Bootstrap Responsive v2.3.0 3 | * 4 | * Copyright 2012 Twitter, Inc 5 | * Licensed under the Apache License v2.0 6 | * http://www.apache.org/licenses/LICENSE-2.0 7 | * 8 | * Designed and built with all the love in the world @twitter by @mdo and @fat. 9 | */.clearfix{*zoom:1}.clearfix:before,.clearfix:after{display:table;line-height:0;content:""}.clearfix:after{clear:both}.hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.input-block-level{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}@-ms-viewport{width:device-width}.hidden{display:none;visibility:hidden}.visible-phone{display:none!important}.visible-tablet{display:none!important}.hidden-desktop{display:none!important}.visible-desktop{display:inherit!important}@media(min-width:768px) and (max-width:979px){.hidden-desktop{display:inherit!important}.visible-desktop{display:none!important}.visible-tablet{display:inherit!important}.hidden-tablet{display:none!important}}@media(max-width:767px){.hidden-desktop{display:inherit!important}.visible-desktop{display:none!important}.visible-phone{display:inherit!important}.hidden-phone{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:inherit!important}.hidden-print{display:none!important}}@media(min-width:1200px){.row{margin-left:-30px;*zoom:1}.row:before,.row:after{display:table;line-height:0;content:""}.row:after{clear:both}[class*="span"]{float:left;min-height:1px;margin-left:30px}.container,.navbar-static-top .container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:1170px}.span12{width:1170px}.span11{width:1070px}.span10{width:970px}.span9{width:870px}.span8{width:770px}.span7{width:670px}.span6{width:570px}.span5{width:470px}.span4{width:370px}.span3{width:270px}.span2{width:170px}.span1{width:70px}.offset12{margin-left:1230px}.offset11{margin-left:1130px}.offset10{margin-left:1030px}.offset9{margin-left:930px}.offset8{margin-left:830px}.offset7{margin-left:730px}.offset6{margin-left:630px}.offset5{margin-left:530px}.offset4{margin-left:430px}.offset3{margin-left:330px}.offset2{margin-left:230px}.offset1{margin-left:130px}.row-fluid{width:100%;*zoom:1}.row-fluid:before,.row-fluid:after{display:table;line-height:0;content:""}.row-fluid:after{clear:both}.row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.564102564102564%;*margin-left:2.5109110747408616%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.row-fluid [class*="span"]:first-child{margin-left:0}.row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.564102564102564%}.row-fluid .span12{width:100%;*width:99.94680851063829%}.row-fluid .span11{width:91.45299145299145%;*width:91.39979996362975%}.row-fluid .span10{width:82.90598290598291%;*width:82.8527914166212%}.row-fluid .span9{width:74.35897435897436%;*width:74.30578286961266%}.row-fluid .span8{width:65.81196581196582%;*width:65.75877432260411%}.row-fluid .span7{width:57.26495726495726%;*width:57.21176577559556%}.row-fluid .span6{width:48.717948717948715%;*width:48.664757228587014%}.row-fluid .span5{width:40.17094017094017%;*width:40.11774868157847%}.row-fluid .span4{width:31.623931623931625%;*width:31.570740134569924%}.row-fluid .span3{width:23.076923076923077%;*width:23.023731587561375%}.row-fluid .span2{width:14.52991452991453%;*width:14.476723040552828%}.row-fluid .span1{width:5.982905982905983%;*width:5.929714493544281%}.row-fluid .offset12{margin-left:105.12820512820512%;*margin-left:105.02182214948171%}.row-fluid .offset12:first-child{margin-left:102.56410256410257%;*margin-left:102.45771958537915%}.row-fluid .offset11{margin-left:96.58119658119658%;*margin-left:96.47481360247316%}.row-fluid .offset11:first-child{margin-left:94.01709401709402%;*margin-left:93.91071103837061%}.row-fluid .offset10{margin-left:88.03418803418803%;*margin-left:87.92780505546462%}.row-fluid .offset10:first-child{margin-left:85.47008547008548%;*margin-left:85.36370249136206%}.row-fluid .offset9{margin-left:79.48717948717949%;*margin-left:79.38079650845607%}.row-fluid .offset9:first-child{margin-left:76.92307692307693%;*margin-left:76.81669394435352%}.row-fluid .offset8{margin-left:70.94017094017094%;*margin-left:70.83378796144753%}.row-fluid .offset8:first-child{margin-left:68.37606837606839%;*margin-left:68.26968539734497%}.row-fluid .offset7{margin-left:62.393162393162385%;*margin-left:62.28677941443899%}.row-fluid .offset7:first-child{margin-left:59.82905982905982%;*margin-left:59.72267685033642%}.row-fluid .offset6{margin-left:53.84615384615384%;*margin-left:53.739770867430444%}.row-fluid .offset6:first-child{margin-left:51.28205128205128%;*margin-left:51.175668303327875%}.row-fluid .offset5{margin-left:45.299145299145295%;*margin-left:45.1927623204219%}.row-fluid .offset5:first-child{margin-left:42.73504273504273%;*margin-left:42.62865975631933%}.row-fluid .offset4{margin-left:36.75213675213675%;*margin-left:36.645753773413354%}.row-fluid .offset4:first-child{margin-left:34.18803418803419%;*margin-left:34.081651209310785%}.row-fluid .offset3{margin-left:28.205128205128204%;*margin-left:28.0987452264048%}.row-fluid .offset3:first-child{margin-left:25.641025641025642%;*margin-left:25.53464266230224%}.row-fluid .offset2{margin-left:19.65811965811966%;*margin-left:19.551736679396257%}.row-fluid .offset2:first-child{margin-left:17.094017094017094%;*margin-left:16.98763411529369%}.row-fluid .offset1{margin-left:11.11111111111111%;*margin-left:11.004728132387708%}.row-fluid .offset1:first-child{margin-left:8.547008547008547%;*margin-left:8.440625568285142%}input,textarea,.uneditable-input{margin-left:0}.controls-row [class*="span"]+[class*="span"]{margin-left:30px}input.span12,textarea.span12,.uneditable-input.span12{width:1156px}input.span11,textarea.span11,.uneditable-input.span11{width:1056px}input.span10,textarea.span10,.uneditable-input.span10{width:956px}input.span9,textarea.span9,.uneditable-input.span9{width:856px}input.span8,textarea.span8,.uneditable-input.span8{width:756px}input.span7,textarea.span7,.uneditable-input.span7{width:656px}input.span6,textarea.span6,.uneditable-input.span6{width:556px}input.span5,textarea.span5,.uneditable-input.span5{width:456px}input.span4,textarea.span4,.uneditable-input.span4{width:356px}input.span3,textarea.span3,.uneditable-input.span3{width:256px}input.span2,textarea.span2,.uneditable-input.span2{width:156px}input.span1,textarea.span1,.uneditable-input.span1{width:56px}.thumbnails{margin-left:-30px}.thumbnails>li{margin-left:30px}.row-fluid .thumbnails{margin-left:0}}@media(min-width:768px) and (max-width:979px){.row{margin-left:-20px;*zoom:1}.row:before,.row:after{display:table;line-height:0;content:""}.row:after{clear:both}[class*="span"]{float:left;min-height:1px;margin-left:20px}.container,.navbar-static-top .container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:724px}.span12{width:724px}.span11{width:662px}.span10{width:600px}.span9{width:538px}.span8{width:476px}.span7{width:414px}.span6{width:352px}.span5{width:290px}.span4{width:228px}.span3{width:166px}.span2{width:104px}.span1{width:42px}.offset12{margin-left:764px}.offset11{margin-left:702px}.offset10{margin-left:640px}.offset9{margin-left:578px}.offset8{margin-left:516px}.offset7{margin-left:454px}.offset6{margin-left:392px}.offset5{margin-left:330px}.offset4{margin-left:268px}.offset3{margin-left:206px}.offset2{margin-left:144px}.offset1{margin-left:82px}.row-fluid{width:100%;*zoom:1}.row-fluid:before,.row-fluid:after{display:table;line-height:0;content:""}.row-fluid:after{clear:both}.row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:30px;margin-left:2.7624309392265194%;*margin-left:2.709239449864817%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.row-fluid [class*="span"]:first-child{margin-left:0}.row-fluid .controls-row [class*="span"]+[class*="span"]{margin-left:2.7624309392265194%}.row-fluid .span12{width:100%;*width:99.94680851063829%}.row-fluid .span11{width:91.43646408839778%;*width:91.38327259903608%}.row-fluid .span10{width:82.87292817679558%;*width:82.81973668743387%}.row-fluid .span9{width:74.30939226519337%;*width:74.25620077583166%}.row-fluid .span8{width:65.74585635359117%;*width:65.69266486422946%}.row-fluid .span7{width:57.18232044198895%;*width:57.12912895262725%}.row-fluid .span6{width:48.61878453038674%;*width:48.56559304102504%}.row-fluid .span5{width:40.05524861878453%;*width:40.00205712942283%}.row-fluid .span4{width:31.491712707182323%;*width:31.43852121782062%}.row-fluid .span3{width:22.92817679558011%;*width:22.87498530621841%}.row-fluid .span2{width:14.3646408839779%;*width:14.311449394616199%}.row-fluid .span1{width:5.801104972375691%;*width:5.747913483013988%}.row-fluid .offset12{margin-left:105.52486187845304%;*margin-left:105.41847889972962%}.row-fluid .offset12:first-child{margin-left:102.76243093922652%;*margin-left:102.6560479605031%}.row-fluid .offset11{margin-left:96.96132596685082%;*margin-left:96.8549429881274%}.row-fluid .offset11:first-child{margin-left:94.1988950276243%;*margin-left:94.09251204890089%}.row-fluid .offset10{margin-left:88.39779005524862%;*margin-left:88.2914070765252%}.row-fluid .offset10:first-child{margin-left:85.6353591160221%;*margin-left:85.52897613729868%}.row-fluid .offset9{margin-left:79.8342541436464%;*margin-left:79.72787116492299%}.row-fluid .offset9:first-child{margin-left:77.07182320441989%;*margin-left:76.96544022569647%}.row-fluid .offset8{margin-left:71.2707182320442%;*margin-left:71.16433525332079%}.row-fluid .offset8:first-child{margin-left:68.50828729281768%;*margin-left:68.40190431409427%}.row-fluid .offset7{margin-left:62.70718232044199%;*margin-left:62.600799341718584%}.row-fluid .offset7:first-child{margin-left:59.94475138121547%;*margin-left:59.838368402492065%}.row-fluid .offset6{margin-left:54.14364640883978%;*margin-left:54.037263430116376%}.row-fluid .offset6:first-child{margin-left:51.38121546961326%;*margin-left:51.27483249088986%}.row-fluid .offset5{margin-left:45.58011049723757%;*margin-left:45.47372751851417%}.row-fluid .offset5:first-child{margin-left:42.81767955801105%;*margin-left:42.71129657928765%}.row-fluid .offset4{margin-left:37.01657458563536%;*margin-left:36.91019160691196%}.row-fluid .offset4:first-child{margin-left:34.25414364640884%;*margin-left:34.14776066768544%}.row-fluid .offset3{margin-left:28.45303867403315%;*margin-left:28.346655695309746%}.row-fluid .offset3:first-child{margin-left:25.69060773480663%;*margin-left:25.584224756083227%}.row-fluid .offset2{margin-left:19.88950276243094%;*margin-left:19.783119783707537%}.row-fluid .offset2:first-child{margin-left:17.12707182320442%;*margin-left:17.02068884448102%}.row-fluid .offset1{margin-left:11.32596685082873%;*margin-left:11.219583872105325%}.row-fluid .offset1:first-child{margin-left:8.56353591160221%;*margin-left:8.457152932878806%}input,textarea,.uneditable-input{margin-left:0}.controls-row [class*="span"]+[class*="span"]{margin-left:20px}input.span12,textarea.span12,.uneditable-input.span12{width:710px}input.span11,textarea.span11,.uneditable-input.span11{width:648px}input.span10,textarea.span10,.uneditable-input.span10{width:586px}input.span9,textarea.span9,.uneditable-input.span9{width:524px}input.span8,textarea.span8,.uneditable-input.span8{width:462px}input.span7,textarea.span7,.uneditable-input.span7{width:400px}input.span6,textarea.span6,.uneditable-input.span6{width:338px}input.span5,textarea.span5,.uneditable-input.span5{width:276px}input.span4,textarea.span4,.uneditable-input.span4{width:214px}input.span3,textarea.span3,.uneditable-input.span3{width:152px}input.span2,textarea.span2,.uneditable-input.span2{width:90px}input.span1,textarea.span1,.uneditable-input.span1{width:28px}}@media(max-width:767px){body{padding-right:20px;padding-left:20px}.navbar-fixed-top,.navbar-fixed-bottom,.navbar-static-top{margin-right:-20px;margin-left:-20px}.container-fluid{padding:0}.dl-horizontal dt{float:none;width:auto;clear:none;text-align:left}.dl-horizontal dd{margin-left:0}.container{width:auto}.row-fluid{width:100%}.row,.thumbnails{margin-left:0}.thumbnails>li{float:none;margin-left:0}[class*="span"],.uneditable-input[class*="span"],.row-fluid [class*="span"]{display:block;float:none;width:100%;margin-left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.span12,.row-fluid .span12{width:100%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.row-fluid [class*="offset"]:first-child{margin-left:0}.input-large,.input-xlarge,.input-xxlarge,input[class*="span"],select[class*="span"],textarea[class*="span"],.uneditable-input{display:block;width:100%;min-height:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.input-prepend input,.input-append input,.input-prepend input[class*="span"],.input-append input[class*="span"]{display:inline-block;width:auto}.controls-row [class*="span"]+[class*="span"]{margin-left:0}.modal{position:fixed;top:20px;right:20px;left:20px;width:auto;margin:0}.modal.fade{top:-100px}.modal.fade.in{top:20px}}@media(max-width:480px){.nav-collapse{-webkit-transform:translate3d(0,0,0)}.page-header h1 small{display:block;line-height:20px}input[type="checkbox"],input[type="radio"]{border:1px solid #ccc}.form-horizontal .control-label{float:none;width:auto;padding-top:0;text-align:left}.form-horizontal .controls{margin-left:0}.form-horizontal .control-list{padding-top:0}.form-horizontal .form-actions{padding-right:10px;padding-left:10px}.media .pull-left,.media .pull-right{display:block;float:none;margin-bottom:10px}.media-object{margin-right:0;margin-left:0}.modal{top:10px;right:10px;left:10px}.modal-header .close{padding:10px;margin:-10px}.carousel-caption{position:static}}@media(max-width:979px){body{padding-top:0}.navbar-fixed-top,.navbar-fixed-bottom{position:static}.navbar-fixed-top{margin-bottom:20px}.navbar-fixed-bottom{margin-top:20px}.navbar-fixed-top .navbar-inner,.navbar-fixed-bottom .navbar-inner{padding:5px}.navbar .container{width:auto;padding:0}.navbar .brand{padding-right:10px;padding-left:10px;margin:0 0 0 -5px}.nav-collapse{clear:both}.nav-collapse .nav{float:none;margin:0 0 10px}.nav-collapse .nav>li{float:none}.nav-collapse .nav>li>a{margin-bottom:2px}.nav-collapse .nav>.divider-vertical{display:none}.nav-collapse .nav .nav-header{color:#777;text-shadow:none}.nav-collapse .nav>li>a,.nav-collapse .dropdown-menu a{padding:9px 15px;font-weight:bold;color:#777;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.nav-collapse .btn{padding:4px 10px 4px;font-weight:normal;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.nav-collapse .dropdown-menu li+li a{margin-bottom:2px}.nav-collapse .nav>li>a:hover,.nav-collapse .nav>li>a:focus,.nav-collapse .dropdown-menu a:hover,.nav-collapse .dropdown-menu a:focus{background-color:#f2f2f2}.navbar-inverse .nav-collapse .nav>li>a,.navbar-inverse .nav-collapse .dropdown-menu a{color:#999}.navbar-inverse .nav-collapse .nav>li>a:hover,.navbar-inverse .nav-collapse .nav>li>a:focus,.navbar-inverse .nav-collapse .dropdown-menu a:hover,.navbar-inverse .nav-collapse .dropdown-menu a:focus{background-color:#111}.nav-collapse.in .btn-group{padding:0;margin-top:5px}.nav-collapse .dropdown-menu{position:static;top:auto;left:auto;display:none;float:none;max-width:none;padding:0;margin:0 15px;background-color:transparent;border:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.nav-collapse .open>.dropdown-menu{display:block}.nav-collapse .dropdown-menu:before,.nav-collapse .dropdown-menu:after{display:none}.nav-collapse .dropdown-menu .divider{display:none}.nav-collapse .nav>li>.dropdown-menu:before,.nav-collapse .nav>li>.dropdown-menu:after{display:none}.nav-collapse .navbar-form,.nav-collapse .navbar-search{float:none;padding:10px 15px;margin:10px 0;border-top:1px solid #f2f2f2;border-bottom:1px solid #f2f2f2;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1)}.navbar-inverse .nav-collapse .navbar-form,.navbar-inverse .nav-collapse .navbar-search{border-top-color:#111;border-bottom-color:#111}.navbar .nav-collapse .nav.pull-right{float:none;margin-left:0}.nav-collapse,.nav-collapse.collapse{height:0;overflow:hidden}.navbar .btn-navbar{display:block}.navbar-static .navbar-inner{padding-right:10px;padding-left:10px}}@media(min-width:980px){.nav-collapse.collapse{height:auto!important;overflow:visible!important}} 10 | -------------------------------------------------------------------------------- /docs/Contribution License Agreement.pdf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/docs/Contribution License Agreement.pdf -------------------------------------------------------------------------------- /guidelines.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Open Source Contribution Guidelines - Windows Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 26 | 27 | 75 | 76 |
77 |
78 |
79 | 98 |
99 |
100 | 101 |

Let's work together.

102 | 103 |
104 |

Ways to contribute

105 | 106 |

107 | If you would like to become involved in the development of 108 | Windows Azure SDKs and Tools there are many different ways 109 | in which you can contribute. We strongly value your 110 | feedback, questions, bug reports, and feature requests. 111 |

112 | 113 |

114 | Consider these options: 115 |

116 | 117 |
    118 |
  • Use the products
  • 119 |
  • Submit a 120 | GitHub issue 121 | to the appropriate repo (for a guide on submitting good 122 | bug reports, read 123 | Painless Bug Tracking). 124 |
  • 125 |
  • Verify fixes for bugs.
  • 126 |
  • Submit a code fix for a bug.
  • 127 |
  • Submit a new feature request (as a GitHub issue).
  • 128 |
  • Help answer questions on forums such as StackOverflow.
  • 129 |
  • Submit a unit test.
  • 130 |
  • Submit another unit test.
  • 131 |
  • Code review pending pull requests and bug fixes.
  • 132 |
  • Tell others about these projects.
  • 133 |
134 |
135 | 136 |
137 |

Get the source code

138 |

139 | Our source is developed & published on GitHub.com 140 | (learn more). If you are 141 | new to Git, 142 | check out the 143 | Pro Git Book online or at 144 | your bookseller of choice. 145 |

146 |

147 | We have based our development process for moving code 148 | around on the now-classic 149 | Successful Git Branching Model 150 | as well as using GitHub pull requests and forks between the 151 | central organization repository and developer accounts. 152 |

153 |

154 | From any of the Windows Azure code repositories on GitHub, 155 | you can "Fork" the code to your own account. 156 |

157 | 158 |

159 | To get the source on your local development machine, 160 | simply clone the repo using Git:
161 | git clone https://github.com/USERNAME/PROJECT.git
162 | git checkout dev
163 |

164 | 165 |

166 | Each repository has a README that should be helpful to 167 | learn more about the specifics of the language, project 168 | and its development environment. 169 |

170 | 171 |
172 | 173 |
174 |

Q&A forums

175 |

176 | The easiest way to ask questions is to use the Windows Azure SDK and Tools forums 178 | on StackOverflow and MSDN. If your target language is .NET 179 | the most appropriate forums for discussion are on MSDN. 180 | 181 | For all other languages please use StackOverflow. 182 |

183 | 184 | 185 | 186 | 187 | 188 | 189 | 190 | 191 | 192 | 194 | 195 | 196 | 197 | 198 | 199 | 202 | 203 | 204 | 206 | 207 | 208 |
Forum ProviderTagsNotes
StackOverflow

StackOverflow

azureA friendly, open and fun community of developers.
Microsoft Forums for Windows Azure

Microsoft forums

A good place for support and feedback on Windows Azure features 205 | and services like Web Sites, Mobile Services, etc.
209 | 210 |
211 | 212 |
213 |

Reporting bugs & issues

214 |

215 | Issues and feature requests are submitted through the project's 216 | Issues section on GitHub. Please use the following guidelines when 217 | you submit issues and feature requests:
218 |

219 | 220 |
    221 |
  • 222 | Make sure the issue is not already reported by searching 223 | through the list of issues 224 |
  • 225 |
  • 226 | Provide detailed description of the issue including the 227 | following information: 228 |
      229 |
    • Which feature the issue appears in
    • 230 |
    • Under what circumstances the issue appears
    • 231 |
    • What is desired behavior
    • 232 |
    • What is breaking
    • 233 |
    • 234 | What is the impact (things like loss or corruption of data, 235 | compromizing security, disruption of service etc.) 236 |
    • 237 |
    • Any code that will be helpful to reproduce the issue
    • 238 |
    239 |
  • 240 |
241 |

242 | Issues are regularly reviewed and updated with additional 243 | information by the core team. Sometimes the core team may have 244 | questions about particular issue that might need clarifications 245 | so, please be ready to provide additional information. 246 |

247 |
248 | 249 |
250 |

Feature requests

251 |

252 | Feature requests and Design Change Requests (DCRs) are an important part of 253 | the lifecycle of any software project. Please log these as Issues in the 254 | appropriate GitHub repository. 255 |

256 |

257 | Although the team will consider any opened issues, please keep in mind 258 | that there is an extremely high bar when it comes to expanding the scope 259 | and functionality of a core product such as an SDK for Windows Azure. 260 |

261 |

262 | When opening any feature requests, consider including as much information 263 | as possible, including: 264 |

265 |
    266 |
  • Detailed scenarios enabled by the feature or DCR.
  • 267 |
  • Information about your use case or additional value your 268 | business or site will see from the feature.
  • 269 |
  • Any design tips or estimation ideas you may have considered already.
  • 270 |
  • Make note of whether you are opening an issue you would 271 | like the Microsoft team or another community member to work on or 272 | if you are looking to design & develop the feature 273 | yourself.
  • 274 |
  • Any potential caveats or concerns you may have already 275 | thought about.
  • 276 |
  • A miniature test plan or list of test scenarios is always 277 | helpful.
  • 278 |
279 |
280 | 281 |
282 | 283 |
284 | 285 | Note: A Contribution Legal Agreement (CLA) is 286 | required before the team can consider your contributions & 287 | pull requests. Please read this entire page carefully. 288 |
289 | 290 |
291 |

Contributing code

292 | 293 |

294 | From an engineering standpoint, please make sure that you can 295 | build and test the code. Familiarize yourself with our 296 | project guidelines and coding conventions. 297 |

298 | 299 |

300 | The SDK team also recommends that you read these great 301 | posts about open source: 302 |

303 | 308 | 309 |

310 | If you have ever considered contributing to the ASP.NET Web Stack, 312 | we have modeled much of this process on that project.

313 | 314 |

315 | Before you start working on a feature or substantial code 316 | contribution please discuss it with 317 | the team and ensure it is an appropriate addition to the core 318 | product. 319 |

320 | 321 |

322 | Note that code submissions will be rigorously reviewed and 323 | tested by the Windows Azure SDK Team (or the appropriate 324 | Azure service owners), and only contributions that meet 325 | an extremely high bar for both quality and design/roadmap 326 | appropriateness will be merged into the source.

327 | 328 |

329 | In some situations Microsoft employees may engage with you 330 | to review design decisions and mitigate issues as part of 331 | the contribution process. Understand that in some situations, 332 | developers inside Microsoft may decide to decline your 333 | pull request and instead log the issue for a future 334 | product milestone or bug fix. The team will provide 335 | information in the pull in these situations and still 336 | thank you for your contribution. 337 |

338 | 339 |

340 | For bug fixes, simply start a conversation in the related 341 | GitHub issue to notify the team and chat about the design of 342 | the fix if needed.

343 | 344 |

345 | There are many opportunities to build value-add services and 346 | frameworks that do not need to direct alterations to the 347 | SDKs and products: NuGet packages for .NET or NPM modules 348 | for Node.js devs can easily take a dependency on the core 349 | SDK components, for example. 350 |

351 | 352 | 353 |
    354 |
  • You have properly documented any new functionality using the 355 | documentation standards for the language (this includes clasees, 356 | methods and functions, properties etc.)
  • 357 |
  • For any change you make proper inline documentation is 358 | included
    359 |
  • 360 |
  • For any new functionality you have written complete unit tests
  • 361 |
  • You have ran all unit tests and they pass
  • 362 |
363 | In order to speed up the process of accepting your contributions, you 364 | should try to make your checkins as small as possible, avoid any unnecessary 365 | deltas and the need to rebase. 366 | 367 |
368 | 369 |
370 |

Contribution License Agreement (CLA)

371 | 372 |

In order to become a contributor to the Windows Azure 373 | open source projects on GitHub you must follow some 374 | legal requirements.

375 | 376 |

Until you meet the legal requirements your pull requests / source 377 | contributions will not be considered or reviewed.

378 | 379 |
380 | 385 |
386 | 387 |
388 | 389 | 390 |

As a community member you must sign the Contribution License Agreement (CLA) 391 | before you can contribute to Microsoft open source projects.

392 | 393 |

You only need complete and submit the documentation once. Please 394 | carefully review the document; you may also need to have your 395 | employer sign the document.

396 | 397 |

Signing the Contribution License Agreement (CLA) does not grant 398 | you rights to commit to the main repository but it does mean that 399 | the Windows Azure team will be able to review and consider your 400 | contributions and you will get credit if we do.

401 | 402 |

You can download the Contribution License Agreement (CLA) by 403 | clicking the following link: http://windowsazure.github.com/docs/Contribution License Agreement.pdf.

405 | 406 |

409 | Download the Contribution License Agreement (CLA)
410 | 281 KB PDF

411 | 412 | 413 |

Please fill in, sign, scan & email the completed document 414 | to cla@microsoft.com. 416 |

417 | 418 |
419 | 420 |
421 | 422 |

If you are currently employed as an active Full-Time Employee (FTE) 423 | at Microsoft you may be able to contribute through your job to 424 | the SDK without signing a CLA.

425 | 426 |

You will need to clearly identify yourself as a Microsoft employee 427 | in your GitHub profile. You should also include your alias in any 428 | pull requests.

429 | 430 |

As a courtesy you should have a conversation about contributing 431 | to the Azure open source projects with your manager, and remember 432 | to follow your business group's guidelines and policies.

433 | 434 |
435 | 436 |
437 | 438 |

If your Microsoft team is looking to partner with the 439 | Windows Azure SDK team to ship new bits, create new 440 | open source projects & meet your shipping 441 | criteria, please start engaging the Windows Azure SDK 442 | triad early.

443 | 444 |

Our SharePoint site contains plenty of information on 445 | the onboarding process, timelines and contacts.

446 | 447 |

449 | Open Windows Azure SDK SharePoint
450 | Requires corporate credentials

451 | 452 |
453 |
454 |
455 | 456 |

457 | Active contributors might be asked to join the core team or 458 | help with feature development. The ability to merge pull 459 | requests typically remains with the SDK team to ensure 460 | that contributions to master are thoroughly reviewed. 461 |

462 | 463 |

464 | Please configure your Git client with a name and email 465 | address to use for your commits. This will also help the 466 | team validate your CLA status: 467 | 468 |

git config user.name Your Name
469 | git config user.email YourAlias@YourEmailDomain
470 |

471 | 472 |
473 | 474 |
475 |

Step-by-step guide

476 | 477 |

Checkout the latest code

478 |

In order to obtain the source code you need to become familiar 479 | with Git (see http://progit.org/book/) 480 | and Github (see http://help.github.com/) 481 | and you need to have Git installed on your local machine. You can 482 | obtain the source code from Github and start a contributor environment by 483 | following the these steps on your local machine:
484 |

485 |
    486 |
  1. Go to https://github.com/WindowsAzure/[PROJECT]
  2. 487 |
  3. Select and choose your own Github account as target
  4. 488 |
  5. Clone the repository on your local machine with the following 489 | Git command
    490 | git clone git@github.com:[USERNAME]/[PROJECT]
    491 |
  6. 492 |
  7. When you clone the repository you should see, at least, 2 branches: dev and master. 493 | dev is the branch where the team does all the day to day development while master is 494 | the branch that is always up to date with the latest release.
    495 | This means, before starting any work, you should switch to the dev branch. You can do so 496 | with the following command:
    497 | git checkout dev
  8. 498 |
499 |

Create bug fixes and features
500 |

501 |

You can then start to make modifications to the code in your local Git repository. 502 | This can be done in your local dev branch or, if you prefer, in a branch out of dev. 503 | In the simplest scenario, working directly on dev, you can commit your work 504 | with following commands:
505 |

506 |
    507 |
  1. Add and commit your local changes
    508 | git commit -a 509 |
  2. 510 |
  3. Push your changes from your local repository to your github fork
    511 | git push 512 |
  4. 513 |
514 |

Once your code is in your github fork, you can then submit a pull request 515 | for the team's review. You can do so with the following commands:
516 |

517 |
    518 |
  1. In GitHub click on the Pull 519 | Request button
  2. 520 |
  3. In the pull request select your fork as source and 521 | WindowsAzure/[PROJECT] as destination for the request
  4. 522 |
  5. Write detailed message describing the changes in the pull 523 | request
  6. 524 |
  7. Submit the pull request for consideration by the Core Team
  8. 525 |
526 |

If there are conflicts between your fork and the main project one, github 527 | will warn you that the pull request cannot be merged. If that's the case, 528 | you can do the following: 529 |

530 |
    531 |
  1. Add remote to your local repository using the following Git 532 | commands
    533 | git remote add upstream -f 534 | git@github.com:WindowsAzure/[PROJECT]
    535 |
  2. 536 |
  3. Update your local repository with the changes from the remote 537 | repository by using the following Git commands (make sure you're in 538 | the branch you're submitting the code from)
    539 | git merge upstream/dev
  4. 540 |
  5. Resolve any conflicts locally and finally do another push with the command
    541 | git push 542 |
  6. 543 |
544 |

Please keep in mind that not all requests will be approved. 545 | Requests are reviewed by the Core Team on a regular basis and will 546 | be updated with the status at each review. If your request is 547 | accepted you will receive information about the next steps and 548 | when the request will be integrated in the main branch. If your 549 | request is rejected you will receive information about the reasons 550 | why it was rejected.
551 |

552 |
553 | 554 |
555 |

Code Reviews

556 |

557 | The Windows Azure SDK team has an active Microsoft discussion 558 | group used for submitting code reviews and discussing design 559 | changes, best practices, and other important topics. 560 |

561 |

562 | Part of the code review process involves using a code review 563 | tool, and for most open source projects, the team uses the 564 | built-in Pull Request functionality on GitHub for enabling 565 | annotations and comments on code before accepting the pull 566 | request/s. 567 |

568 |

569 | Expect a good amount of feedback as part of any pull request: 570 | not only which branch to merge to and from, but also 571 | consistency guidelines, matching existing code, and 572 | making targeted, smart changes when fixing bugs. 573 |

574 | 575 |

Community code reviews

576 |

577 | The SDK team is considering allowing for community code 578 | reviews as well. If you watch a repository of interest, 579 | you can make comments on any public pull request. The 580 | best time for providing feedback is during dev branch 581 | pulls into the primary WindowsAzure GitHub account. 582 |

583 | 584 |
585 | 586 |
587 |

Contact the team

588 | 589 |

The best way to get in touch with the team regarding feature ideas, 590 | developer designs amd communicating about bug fixes is to use the Issues system 591 | built in to GitHub.

592 | 593 |

If you are looking for support or to provide feedback, there are a lot of 594 | places to do this.

595 | 596 |

Detailed support and contact information »

597 | 598 |
599 | 600 | 601 |
602 |

Thank you

603 | 604 |

605 | Huge thanks go to the contributors from the community who 606 | have been actively working with the Windows Azure SDK team. 607 |

608 |

You can find a list of contributors here. 609 |

610 | 611 |
612 | 613 |
614 |

Jobs

615 | 616 |

Microsoft is always hiring bright and talented students & 617 | professionals. Please consider submitting your resume and 618 | applying for open positions at 619 | //careers.microsoft.com.

620 | 621 |
622 | 623 |
624 |
625 | 626 | 627 | 628 |
629 | 630 | 647 | 648 |
649 | 650 | 651 | 652 | 653 | 654 | 655 | 656 | -------------------------------------------------------------------------------- /images/button-fork.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/images/button-fork.jpg -------------------------------------------------------------------------------- /images/button-pull-request.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/images/button-pull-request.jpg -------------------------------------------------------------------------------- /img/glyphicons-halflings-white.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/img/glyphicons-halflings-white.png -------------------------------------------------------------------------------- /img/glyphicons-halflings.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WindowsAzure/windowsazure.github.io/dc5fb3f10b7abe1cd3962e4aa9612601ac74ac96/img/glyphicons-halflings.png -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Open source cloud frameworks, SDKs and contribution guidelines - Windows Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 26 | 27 | 74 | 75 |
76 | 77 |
78 |

Hello, cloud developers!

79 |

The Windows Azure SDK team is busy coding away frameworks and experiences to help 80 | make your projects successful.

81 |

We create SDKs that connect to Windows Azure services through REST wrappers 82 | and interfaces in the language of your choice - including .NET, Java, Node.js, 83 | Python, and others.

84 |

We accept your open source contributions, license our work with Apache 2.0, and use 85 | GitHub.

86 |

Learn how to contribute »

87 |
88 | 89 |
90 | 91 |
92 |
93 | 97 |
98 |
99 | 100 |
101 | 102 |
103 |
104 |

Open Source

105 |

Our frameworks & libraries are developed in agile dev branches on GitHub.

106 |

//github.com/WindowsAzure »

107 |
108 |
109 |

Frameworks & Projects

110 |

We provide the low-level REST abstractions, sample code and documentation, and some higher-level functionality, hand-built in your language of choice.

111 |

Our SDKs & Projects »

112 |
113 |
114 |

Apache 2 License

115 |

We strive to release our work under the permissive and open Apache 2.0 license.

116 |

Read the Apache 2.0 License »

117 |
118 |
119 | 120 |
121 | 122 | 138 | 139 |
140 | 141 | 142 | 143 | 144 | 145 | -------------------------------------------------------------------------------- /js/azure.js: -------------------------------------------------------------------------------- 1 | !function ($) { 2 | 3 | $(function(){ 4 | 5 | var $window = $(window) 6 | 7 | // Disable certain links in docs 8 | $('section [href^=#]').click(function (e) { 9 | e.preventDefault() 10 | }) 11 | 12 | }) 13 | 14 | }(window.jQuery) 15 | -------------------------------------------------------------------------------- /js/bootstrap.min.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * Bootstrap.js by @fat & @mdo 3 | * Copyright 2012 Twitter, Inc. 4 | * http://www.apache.org/licenses/LICENSE-2.0.txt 5 | */ 6 | !function(e){"use strict";e(function(){e.support.transition=function(){var e=function(){var e=document.createElement("bootstrap"),t={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},n;for(n in t)if(e.style[n]!==undefined)return t[n]}();return e&&{end:e}}()})}(window.jQuery),!function(e){"use strict";var t='[data-dismiss="alert"]',n=function(n){e(n).on("click",t,this.close)};n.prototype.close=function(t){function s(){i.trigger("closed").remove()}var n=e(this),r=n.attr("data-target"),i;r||(r=n.attr("href"),r=r&&r.replace(/.*(?=#[^\s]*$)/,"")),i=e(r),t&&t.preventDefault(),i.length||(i=n.hasClass("alert")?n:n.parent()),i.trigger(t=e.Event("close"));if(t.isDefaultPrevented())return;i.removeClass("in"),e.support.transition&&i.hasClass("fade")?i.on(e.support.transition.end,s):s()};var r=e.fn.alert;e.fn.alert=function(t){return this.each(function(){var r=e(this),i=r.data("alert");i||r.data("alert",i=new n(this)),typeof t=="string"&&i[t].call(r)})},e.fn.alert.Constructor=n,e.fn.alert.noConflict=function(){return e.fn.alert=r,this},e(document).on("click.alert.data-api",t,n.prototype.close)}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.button.defaults,n)};t.prototype.setState=function(e){var t="disabled",n=this.$element,r=n.data(),i=n.is("input")?"val":"html";e+="Text",r.resetText||n.data("resetText",n[i]()),n[i](r[e]||this.options[e]),setTimeout(function(){e=="loadingText"?n.addClass(t).attr(t,t):n.removeClass(t).removeAttr(t)},0)},t.prototype.toggle=function(){var e=this.$element.closest('[data-toggle="buttons-radio"]');e&&e.find(".active").removeClass("active"),this.$element.toggleClass("active")};var n=e.fn.button;e.fn.button=function(n){return this.each(function(){var r=e(this),i=r.data("button"),s=typeof n=="object"&&n;i||r.data("button",i=new t(this,s)),n=="toggle"?i.toggle():n&&i.setState(n)})},e.fn.button.defaults={loadingText:"loading..."},e.fn.button.Constructor=t,e.fn.button.noConflict=function(){return e.fn.button=n,this},e(document).on("click.button.data-api","[data-toggle^=button]",function(t){var n=e(t.target);n.hasClass("btn")||(n=n.closest(".btn")),n.button("toggle")})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.$indicators=this.$element.find(".carousel-indicators"),this.options=n,this.options.pause=="hover"&&this.$element.on("mouseenter",e.proxy(this.pause,this)).on("mouseleave",e.proxy(this.cycle,this))};t.prototype={cycle:function(t){return t||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(e.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(t){var n=this.getActiveIndex(),r=this;if(t>this.$items.length-1||t<0)return;return this.sliding?this.$element.one("slid",function(){r.to(t)}):n==t?this.pause().cycle():this.slide(t>n?"next":"prev",e(this.$items[t]))},pause:function(t){return t||(this.paused=!0),this.$element.find(".next, .prev").length&&e.support.transition.end&&(this.$element.trigger(e.support.transition.end),this.cycle()),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(t,n){var r=this.$element.find(".item.active"),i=n||r[t](),s=this.interval,o=t=="next"?"left":"right",u=t=="next"?"first":"last",a=this,f;this.sliding=!0,s&&this.pause(),i=i.length?i:this.$element.find(".item")[u](),f=e.Event("slide",{relatedTarget:i[0],direction:o});if(i.hasClass("active"))return;this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var t=e(a.$indicators.children()[a.getActiveIndex()]);t&&t.addClass("active")}));if(e.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(f);if(f.isDefaultPrevented())return;i.addClass(t),i[0].offsetWidth,r.addClass(o),i.addClass(o),this.$element.one(e.support.transition.end,function(){i.removeClass([t,o].join(" ")).addClass("active"),r.removeClass(["active",o].join(" ")),a.sliding=!1,setTimeout(function(){a.$element.trigger("slid")},0)})}else{this.$element.trigger(f);if(f.isDefaultPrevented())return;r.removeClass("active"),i.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return s&&this.cycle(),this}};var n=e.fn.carousel;e.fn.carousel=function(n){return this.each(function(){var r=e(this),i=r.data("carousel"),s=e.extend({},e.fn.carousel.defaults,typeof n=="object"&&n),o=typeof n=="string"?n:s.slide;i||r.data("carousel",i=new t(this,s)),typeof n=="number"?i.to(n):o?i[o]():s.interval&&i.pause().cycle()})},e.fn.carousel.defaults={interval:5e3,pause:"hover"},e.fn.carousel.Constructor=t,e.fn.carousel.noConflict=function(){return e.fn.carousel=n,this},e(document).on("click.carousel.data-api","[data-slide], [data-slide-to]",function(t){var n=e(this),r,i=e(n.attr("data-target")||(r=n.attr("href"))&&r.replace(/.*(?=#[^\s]+$)/,"")),s=e.extend({},i.data(),n.data()),o;i.carousel(s),(o=n.attr("data-slide-to"))&&i.data("carousel").pause().to(o).cycle(),t.preventDefault()})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.collapse.defaults,n),this.options.parent&&(this.$parent=e(this.options.parent)),this.options.toggle&&this.toggle()};t.prototype={constructor:t,dimension:function(){var e=this.$element.hasClass("width");return e?"width":"height"},show:function(){var t,n,r,i;if(this.transitioning||this.$element.hasClass("in"))return;t=this.dimension(),n=e.camelCase(["scroll",t].join("-")),r=this.$parent&&this.$parent.find("> .accordion-group > .in");if(r&&r.length){i=r.data("collapse");if(i&&i.transitioning)return;r.collapse("hide"),i||r.data("collapse",null)}this.$element[t](0),this.transition("addClass",e.Event("show"),"shown"),e.support.transition&&this.$element[t](this.$element[0][n])},hide:function(){var t;if(this.transitioning||!this.$element.hasClass("in"))return;t=this.dimension(),this.reset(this.$element[t]()),this.transition("removeClass",e.Event("hide"),"hidden"),this.$element[t](0)},reset:function(e){var t=this.dimension();return this.$element.removeClass("collapse")[t](e||"auto")[0].offsetWidth,this.$element[e!==null?"addClass":"removeClass"]("collapse"),this},transition:function(t,n,r){var i=this,s=function(){n.type=="show"&&i.reset(),i.transitioning=0,i.$element.trigger(r)};this.$element.trigger(n);if(n.isDefaultPrevented())return;this.transitioning=1,this.$element[t]("in"),e.support.transition&&this.$element.hasClass("collapse")?this.$element.one(e.support.transition.end,s):s()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}};var n=e.fn.collapse;e.fn.collapse=function(n){return this.each(function(){var r=e(this),i=r.data("collapse"),s=e.extend({},e.fn.collapse.defaults,r.data(),typeof n=="object"&&n);i||r.data("collapse",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.collapse.defaults={toggle:!0},e.fn.collapse.Constructor=t,e.fn.collapse.noConflict=function(){return e.fn.collapse=n,this},e(document).on("click.collapse.data-api","[data-toggle=collapse]",function(t){var n=e(this),r,i=n.attr("data-target")||t.preventDefault()||(r=n.attr("href"))&&r.replace(/.*(?=#[^\s]+$)/,""),s=e(i).data("collapse")?"toggle":n.data();n[e(i).hasClass("in")?"addClass":"removeClass"]("collapsed"),e(i).collapse(s)})}(window.jQuery),!function(e){"use strict";function r(){e(t).each(function(){i(e(this)).removeClass("open")})}function i(t){var n=t.attr("data-target"),r;n||(n=t.attr("href"),n=n&&/#/.test(n)&&n.replace(/.*(?=#[^\s]*$)/,"")),r=n&&e(n);if(!r||!r.length)r=t.parent();return r}var t="[data-toggle=dropdown]",n=function(t){var n=e(t).on("click.dropdown.data-api",this.toggle);e("html").on("click.dropdown.data-api",function(){n.parent().removeClass("open")})};n.prototype={constructor:n,toggle:function(t){var n=e(this),s,o;if(n.is(".disabled, :disabled"))return;return s=i(n),o=s.hasClass("open"),r(),o||s.toggleClass("open"),n.focus(),!1},keydown:function(n){var r,s,o,u,a,f;if(!/(38|40|27)/.test(n.keyCode))return;r=e(this),n.preventDefault(),n.stopPropagation();if(r.is(".disabled, :disabled"))return;u=i(r),a=u.hasClass("open");if(!a||a&&n.keyCode==27)return n.which==27&&u.find(t).focus(),r.click();s=e("[role=menu] li:not(.divider):visible a",u);if(!s.length)return;f=s.index(s.filter(":focus")),n.keyCode==38&&f>0&&f--,n.keyCode==40&&f').appendTo(document.body),this.$backdrop.click(this.options.backdrop=="static"?e.proxy(this.$element[0].focus,this.$element[0]):e.proxy(this.hide,this)),i&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in");if(!t)return;i?this.$backdrop.one(e.support.transition.end,t):t()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),e.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(e.support.transition.end,t):t()):t&&t()}};var n=e.fn.modal;e.fn.modal=function(n){return this.each(function(){var r=e(this),i=r.data("modal"),s=e.extend({},e.fn.modal.defaults,r.data(),typeof n=="object"&&n);i||r.data("modal",i=new t(this,s)),typeof n=="string"?i[n]():s.show&&i.show()})},e.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},e.fn.modal.Constructor=t,e.fn.modal.noConflict=function(){return e.fn.modal=n,this},e(document).on("click.modal.data-api",'[data-toggle="modal"]',function(t){var n=e(this),r=n.attr("href"),i=e(n.attr("data-target")||r&&r.replace(/.*(?=#[^\s]+$)/,"")),s=i.data("modal")?"toggle":e.extend({remote:!/#/.test(r)&&r},i.data(),n.data());t.preventDefault(),i.modal(s).one("hide",function(){n.focus()})})}(window.jQuery),!function(e){"use strict";var t=function(e,t){this.init("tooltip",e,t)};t.prototype={constructor:t,init:function(t,n,r){var i,s,o,u,a;this.type=t,this.$element=e(n),this.options=this.getOptions(r),this.enabled=!0,o=this.options.trigger.split(" ");for(a=o.length;a--;)u=o[a],u=="click"?this.$element.on("click."+this.type,this.options.selector,e.proxy(this.toggle,this)):u!="manual"&&(i=u=="hover"?"mouseenter":"focus",s=u=="hover"?"mouseleave":"blur",this.$element.on(i+"."+this.type,this.options.selector,e.proxy(this.enter,this)),this.$element.on(s+"."+this.type,this.options.selector,e.proxy(this.leave,this)));this.options.selector?this._options=e.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(t){return t=e.extend({},e.fn[this.type].defaults,this.$element.data(),t),t.delay&&typeof t.delay=="number"&&(t.delay={show:t.delay,hide:t.delay}),t},enter:function(t){var n=e(t.currentTarget)[this.type](this._options).data(this.type);if(!n.options.delay||!n.options.delay.show)return n.show();clearTimeout(this.timeout),n.hoverState="in",this.timeout=setTimeout(function(){n.hoverState=="in"&&n.show()},n.options.delay.show)},leave:function(t){var n=e(t.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!n.options.delay||!n.options.delay.hide)return n.hide();n.hoverState="out",this.timeout=setTimeout(function(){n.hoverState=="out"&&n.hide()},n.options.delay.hide)},show:function(){var t,n,r,i,s,o,u=e.Event("show");if(this.hasContent()&&this.enabled){this.$element.trigger(u);if(u.isDefaultPrevented())return;t=this.tip(),this.setContent(),this.options.animation&&t.addClass("fade"),s=typeof this.options.placement=="function"?this.options.placement.call(this,t[0],this.$element[0]):this.options.placement,t.detach().css({top:0,left:0,display:"block"}),this.options.container?t.appendTo(this.options.container):t.insertAfter(this.$element),n=this.getPosition(),r=t[0].offsetWidth,i=t[0].offsetHeight;switch(s){case"bottom":o={top:n.top+n.height,left:n.left+n.width/2-r/2};break;case"top":o={top:n.top-i,left:n.left+n.width/2-r/2};break;case"left":o={top:n.top+n.height/2-i/2,left:n.left-r};break;case"right":o={top:n.top+n.height/2-i/2,left:n.left+n.width}}this.applyPlacement(o,s),this.$element.trigger("shown")}},applyPlacement:function(e,t){var n=this.tip(),r=n[0].offsetWidth,i=n[0].offsetHeight,s,o,u,a;n.offset(e).addClass(t).addClass("in"),s=n[0].offsetWidth,o=n[0].offsetHeight,t=="top"&&o!=i&&(e.top=e.top+i-o,a=!0),t=="bottom"||t=="top"?(u=0,e.left<0&&(u=e.left*-2,e.left=0,n.offset(e),s=n[0].offsetWidth,o=n[0].offsetHeight),this.replaceArrow(u-r+s,s,"left")):this.replaceArrow(o-i,o,"top"),a&&n.offset(e)},replaceArrow:function(e,t,n){this.arrow().css(n,e?50*(1-e/t)+"%":"")},setContent:function(){var e=this.tip(),t=this.getTitle();e.find(".tooltip-inner")[this.options.html?"html":"text"](t),e.removeClass("fade in top bottom left right")},hide:function(){function i(){var t=setTimeout(function(){n.off(e.support.transition.end).detach()},500);n.one(e.support.transition.end,function(){clearTimeout(t),n.detach()})}var t=this,n=this.tip(),r=e.Event("hide");this.$element.trigger(r);if(r.isDefaultPrevented())return;return n.removeClass("in"),e.support.transition&&this.$tip.hasClass("fade")?i():n.detach(),this.$element.trigger("hidden"),this},fixTitle:function(){var e=this.$element;(e.attr("title")||typeof e.attr("data-original-title")!="string")&&e.attr("data-original-title",e.attr("title")||"").attr("title","")},hasContent:function(){return this.getTitle()},getPosition:function(){var t=this.$element[0];return e.extend({},typeof t.getBoundingClientRect=="function"?t.getBoundingClientRect():{width:t.offsetWidth,height:t.offsetHeight},this.$element.offset())},getTitle:function(){var e,t=this.$element,n=this.options;return e=t.attr("data-original-title")||(typeof n.title=="function"?n.title.call(t[0]):n.title),e},tip:function(){return this.$tip=this.$tip||e(this.options.template)},arrow:function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(t){var n=t?e(t.currentTarget)[this.type](this._options).data(this.type):this;n.tip().hasClass("in")?n.hide():n.show()},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}};var n=e.fn.tooltip;e.fn.tooltip=function(n){return this.each(function(){var r=e(this),i=r.data("tooltip"),s=typeof n=="object"&&n;i||r.data("tooltip",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.tooltip.Constructor=t,e.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'
',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},e.fn.tooltip.noConflict=function(){return e.fn.tooltip=n,this}}(window.jQuery),!function(e){"use strict";var t=function(e,t){this.init("popover",e,t)};t.prototype=e.extend({},e.fn.tooltip.Constructor.prototype,{constructor:t,setContent:function(){var e=this.tip(),t=this.getTitle(),n=this.getContent();e.find(".popover-title")[this.options.html?"html":"text"](t),e.find(".popover-content")[this.options.html?"html":"text"](n),e.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var e,t=this.$element,n=this.options;return e=(typeof n.content=="function"?n.content.call(t[0]):n.content)||t.attr("data-content"),e},tip:function(){return this.$tip||(this.$tip=e(this.options.template)),this.$tip},destroy:function(){this.hide().$element.off("."+this.type).removeData(this.type)}});var n=e.fn.popover;e.fn.popover=function(n){return this.each(function(){var r=e(this),i=r.data("popover"),s=typeof n=="object"&&n;i||r.data("popover",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.popover.Constructor=t,e.fn.popover.defaults=e.extend({},e.fn.tooltip.defaults,{placement:"right",trigger:"click",content:"",template:'

'}),e.fn.popover.noConflict=function(){return e.fn.popover=n,this}}(window.jQuery),!function(e){"use strict";function t(t,n){var r=e.proxy(this.process,this),i=e(t).is("body")?e(window):e(t),s;this.options=e.extend({},e.fn.scrollspy.defaults,n),this.$scrollElement=i.on("scroll.scroll-spy.data-api",r),this.selector=(this.options.target||(s=e(t).attr("href"))&&s.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=e("body"),this.refresh(),this.process()}t.prototype={constructor:t,refresh:function(){var t=this,n;this.offsets=e([]),this.targets=e([]),n=this.$body.find(this.selector).map(function(){var n=e(this),r=n.data("target")||n.attr("href"),i=/^#\w/.test(r)&&e(r);return i&&i.length&&[[i.position().top+(!e.isWindow(t.$scrollElement.get(0))&&t.$scrollElement.scrollTop()),r]]||null}).sort(function(e,t){return e[0]-t[0]}).each(function(){t.offsets.push(this[0]),t.targets.push(this[1])})},process:function(){var e=this.$scrollElement.scrollTop()+this.options.offset,t=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,n=t-this.$scrollElement.height(),r=this.offsets,i=this.targets,s=this.activeTarget,o;if(e>=n)return s!=(o=i.last()[0])&&this.activate(o);for(o=r.length;o--;)s!=i[o]&&e>=r[o]&&(!r[o+1]||e<=r[o+1])&&this.activate(i[o])},activate:function(t){var n,r;this.activeTarget=t,e(this.selector).parent(".active").removeClass("active"),r=this.selector+'[data-target="'+t+'"],'+this.selector+'[href="'+t+'"]',n=e(r).parent("li").addClass("active"),n.parent(".dropdown-menu").length&&(n=n.closest("li.dropdown").addClass("active")),n.trigger("activate")}};var n=e.fn.scrollspy;e.fn.scrollspy=function(n){return this.each(function(){var r=e(this),i=r.data("scrollspy"),s=typeof n=="object"&&n;i||r.data("scrollspy",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.scrollspy.Constructor=t,e.fn.scrollspy.defaults={offset:10},e.fn.scrollspy.noConflict=function(){return e.fn.scrollspy=n,this},e(window).on("load",function(){e('[data-spy="scroll"]').each(function(){var t=e(this);t.scrollspy(t.data())})})}(window.jQuery),!function(e){"use strict";var t=function(t){this.element=e(t)};t.prototype={constructor:t,show:function(){var t=this.element,n=t.closest("ul:not(.dropdown-menu)"),r=t.attr("data-target"),i,s,o;r||(r=t.attr("href"),r=r&&r.replace(/.*(?=#[^\s]*$)/,""));if(t.parent("li").hasClass("active"))return;i=n.find(".active:last a")[0],o=e.Event("show",{relatedTarget:i}),t.trigger(o);if(o.isDefaultPrevented())return;s=e(r),this.activate(t.parent("li"),n),this.activate(s,s.parent(),function(){t.trigger({type:"shown",relatedTarget:i})})},activate:function(t,n,r){function o(){i.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),t.addClass("active"),s?(t[0].offsetWidth,t.addClass("in")):t.removeClass("fade"),t.parent(".dropdown-menu")&&t.closest("li.dropdown").addClass("active"),r&&r()}var i=n.find("> .active"),s=r&&e.support.transition&&i.hasClass("fade");s?i.one(e.support.transition.end,o):o(),i.removeClass("in")}};var n=e.fn.tab;e.fn.tab=function(n){return this.each(function(){var r=e(this),i=r.data("tab");i||r.data("tab",i=new t(this)),typeof n=="string"&&i[n]()})},e.fn.tab.Constructor=t,e.fn.tab.noConflict=function(){return e.fn.tab=n,this},e(document).on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(t){t.preventDefault(),e(this).tab("show")})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.typeahead.defaults,n),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.source=this.options.source,this.$menu=e(this.options.menu),this.shown=!1,this.listen()};t.prototype={constructor:t,select:function(){var e=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(e)).change(),this.hide()},updater:function(e){return e},show:function(){var t=e.extend({},this.$element.position(),{height:this.$element[0].offsetHeight});return this.$menu.insertAfter(this.$element).css({top:t.top+t.height,left:t.left}).show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(t){var n;return this.query=this.$element.val(),!this.query||this.query.length"+t+""})},render:function(t){var n=this;return t=e(t).map(function(t,r){return t=e(n.options.item).attr("data-value",r),t.find("a").html(n.highlighter(r)),t[0]}),t.first().addClass("active"),this.$menu.html(t),this},next:function(t){var n=this.$menu.find(".active").removeClass("active"),r=n.next();r.length||(r=e(this.$menu.find("li")[0])),r.addClass("active")},prev:function(e){var t=this.$menu.find(".active").removeClass("active"),n=t.prev();n.length||(n=this.$menu.find("li").last()),n.addClass("active")},listen:function(){this.$element.on("focus",e.proxy(this.focus,this)).on("blur",e.proxy(this.blur,this)).on("keypress",e.proxy(this.keypress,this)).on("keyup",e.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",e.proxy(this.keydown,this)),this.$menu.on("click",e.proxy(this.click,this)).on("mouseenter","li",e.proxy(this.mouseenter,this)).on("mouseleave","li",e.proxy(this.mouseleave,this))},eventSupported:function(e){var t=e in this.$element;return t||(this.$element.setAttribute(e,"return;"),t=typeof this.$element[e]=="function"),t},move:function(e){if(!this.shown)return;switch(e.keyCode){case 9:case 13:case 27:e.preventDefault();break;case 38:e.preventDefault(),this.prev();break;case 40:e.preventDefault(),this.next()}e.stopPropagation()},keydown:function(t){this.suppressKeyPressRepeat=~e.inArray(t.keyCode,[40,38,9,13,27]),this.move(t)},keypress:function(e){if(this.suppressKeyPressRepeat)return;this.move(e)},keyup:function(e){switch(e.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}e.stopPropagation(),e.preventDefault()},focus:function(e){this.focused=!0},blur:function(e){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(e){e.stopPropagation(),e.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(t){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),e(t.currentTarget).addClass("active")},mouseleave:function(e){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var n=e.fn.typeahead;e.fn.typeahead=function(n){return this.each(function(){var r=e(this),i=r.data("typeahead"),s=typeof n=="object"&&n;i||r.data("typeahead",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.typeahead.defaults={source:[],items:8,menu:'',item:'
  • ',minLength:1},e.fn.typeahead.Constructor=t,e.fn.typeahead.noConflict=function(){return e.fn.typeahead=n,this},e(document).on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(t){var n=e(this);if(n.data("typeahead"))return;n.typeahead(n.data())})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.options=e.extend({},e.fn.affix.defaults,n),this.$window=e(window).on("scroll.affix.data-api",e.proxy(this.checkPosition,this)).on("click.affix.data-api",e.proxy(function(){setTimeout(e.proxy(this.checkPosition,this),1)},this)),this.$element=e(t),this.checkPosition()};t.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var t=e(document).height(),n=this.$window.scrollTop(),r=this.$element.offset(),i=this.options.offset,s=i.bottom,o=i.top,u="affix affix-top affix-bottom",a;typeof i!="object"&&(s=o=i),typeof o=="function"&&(o=i.top()),typeof s=="function"&&(s=i.bottom()),a=this.unpin!=null&&n+this.unpin<=r.top?!1:s!=null&&r.top+this.$element.height()>=t-s?"bottom":o!=null&&n<=o?"top":!1;if(this.affixed===a)return;this.affixed=a,this.unpin=a=="bottom"?r.top-n:null,this.$element.removeClass(u).addClass("affix"+(a?"-"+a:""))};var n=e.fn.affix;e.fn.affix=function(n){return this.each(function(){var r=e(this),i=r.data("affix"),s=typeof n=="object"&&n;i||r.data("affix",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.affix.Constructor=t,e.fn.affix.defaults={offset:0},e.fn.affix.noConflict=function(){return e.fn.affix=n,this},e(window).on("load",function(){e('[data-spy="affix"]').each(function(){var t=e(this),n=t.data();n.offset=n.offset||{},n.offsetBottom&&(n.offset.bottom=n.offsetBottom),n.offsetTop&&(n.offset.top=n.offsetTop),t.affix(n)})})}(window.jQuery); -------------------------------------------------------------------------------- /projects.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Our SDKs and Projects - Windows Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 26 | 27 | 28 | 75 | 76 |
    77 | 78 |

    Projects & SDKs

    79 | 80 |

    This page contains information about the open source aspect of many 81 | of the Windows Azure SDKs, frameworks & tools. If you want to use 82 | the released versions of these products to develop your applications, 83 | please visit //windowsazure.com/documentation/ 84 | to find official installers, documentation, package manager links, samples and videos.

    85 | 86 |

    These products are actively developed by the Windows Azure SDK team in 87 | collaboration with our open source community.

    88 | 89 |

    Together we are dedicated to creating the best possible experience for 90 | developers creating amazing experiences that are built on the world-class 91 | infrastructure, platforms and frameworks that make up Windows Azure.

    92 | 93 |
    94 |

    Open Source SDKs

    95 | 96 |

    Here is an overview of all Windows Azure projects hosted on Github. 97 | For additional information about Windows Azure and the services it offers 98 | you can visit www.windowsazure.com
    99 | If you are interested in contributing to any of the projects below please 100 | read the Contribution Guidelines first.

    101 |
    102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 113 | 114 | 115 | 116 | 138 | 139 | 140 | 141 | 142 | 143 | 155 | 156 | 157 | 158 | 159 | 160 | 183 | 184 | 185 | 186 | 187 | 188 | 194 | 195 | 196 | 197 | 198 | 199 | 205 | 206 | 207 | 208 | 209 | 210 | 216 | 217 | 218 | 219 | 220 | 221 | 228 | 229 | 230 |
    SDKGitHubWindows Azure Services

    .NET

      117 |
    • Storage 118 |
        119 |
      • Blob
      • 120 |
      • Table
      • 121 |
      • Queue
      • 122 |
      123 |
    • 124 |
    • Management Libraries 125 |
        126 |
      • Infrastructure - Affinity Groups, Certificates, etc.
      • 127 |
      • Compute - VMs, Hosted Services
      • 128 |
      • Cloud Services
      • 129 |
      • Web Sites
      • 130 |
      • Virtual Network
      • 131 |
      • Scheduler
      • 132 |
      133 |
    • 134 |
    • .NET Cloud Configuration
    • 135 |
    • Media Services
    • 136 |
    • HDinsight
    • 137 |

    Java

      144 |
    • Storage 145 |
        146 |
      • Blob
      • 147 |
      • Table
      • 148 |
      • Queue
      • 149 |
      150 |
    • 151 |
    • Media Services
    • 152 |
    • Service Bus
    • 153 |
    • Service Runtime
    • 154 |

    Node.js

      161 |
    • Storage 162 |
        163 |
      • Blob
      • 164 |
      • Table
      • 165 |
      • Queue
      • 166 |
      167 |
    • 168 |
    • Service Bus
    • 169 |
    • Service Runtime
    • 170 |
    • Management 171 |
        172 |
      • Compute
      • 173 |
      • Cloud Services
      • 174 |
      • SQL Database
      • 175 |
      • Web Sites
      • 176 |
      177 |
    • 178 |
    • node-sqlserver: A Node.js driver that uses ODBC to communicate with SQL Azure.
    • 179 |
    • socket.io-servicebus: Node.js adapter for Service Bus
    • 180 |
    • wns: Node.js framework for sending Windows Notification Service (WNS) messages to Windows 8 devices.
    • 181 |
    • mpns: Node.js framework for sending Microsoft Push Notification Service (MPNS) messages to Windows Phone devices.
    • 182 |

    PHP

      189 |
    • Storage - Blob, Table, Queue
    • 190 |
    • Service Management - Compute
    • 191 |
    • Service Management - Cloud Services
    • 192 |
    • Service Runtime
    • 193 |

    Python

      200 |
    • Storage - Blob, Table, Queue
    • 201 |
    • Service Bus
    • 202 |
    • Service Management - Compute
    • 203 |
    • Service Management - Cloud Services
    • 204 |

    Ruby

    211 |
      212 |
    • Storage - Blob, Table, Queue
    • 213 |
    • Service Bus
    • 214 |
    215 |

    Mobile Services

      222 |
    • iOS
    • 223 |
    • Android
    • 224 |
    • JavaScript
    • 225 |
    • Windows Phone
    • 226 |
    • Windows Store
    • 227 |
    231 | 232 | 233 |
    234 | 235 |
    236 |

    Command Line Experiences

    237 |
    238 | 239 |
    240 |

    Windows Azure PowerShell

    241 |
      242 |
    • 243 |
    • 244 |
    245 |

    This repository contains a set of PowerShell commandlets that let you 246 | deploy applications to Windows Azure using PowerShell.

    247 |
    248 | 249 |
    250 |

    Windows Azure Cross-platform CLI

    251 |
      252 |
    • 253 |
    • 254 |
    255 |

    The cross-platform command line interface (xplat CLI) is written in 256 | Node.js (JavaScript) and lets you deploy apps to Windows Azure on 257 | your Mac, PC, or Linux box.

    258 |
    259 | 260 |
    261 | 262 |
    263 |

    Other Projects

    264 |
    265 | 266 |
    267 |

    iisnode

    268 |
      269 |
    • 270 |
    • 271 |
    272 |

    This repository contains an IIS extension that allows you to host Node.js 273 | applications on Windows.

    274 |
    275 | 276 |
    277 | 278 |
    279 |

    Open Source Documentation

    280 |
    281 | 282 |
    283 |

    azure-content

    284 |
      285 |
    • 286 |
    • 287 |
    288 |

    Markdown-based documentation for the Windows Azure web site's developer 289 | content.

    290 |
    291 | 292 |
    293 |

    windowsazure.github.com

    294 |
      295 |
    • 296 |
    • 297 |
    298 |

    This site.

    299 |
    300 | 301 |
    302 | 303 |
    304 |

    Other Microsoft Teams

    305 | 306 |

    The Server & Tools business at Microsoft has a lot of great open source products 307 | that you might want to consider contributing to. Note that these products may have different 308 | guidelines for contributions of open source than the Windows Azure SDK.

    309 | 310 |

    ASP.NET Web Stack

    311 |

    The open source home of ASP.NET MVC, Web API, and Web Pages.

    312 | 313 |

    NuGet

    314 |

    Open source developer-focused package management system for the .NET platform.

    315 | 316 |

    Kudu

    317 |

    The engine behind git deployments for the Windows Azure Web Sites feature.

    318 | 319 | 322 | 323 |
    324 | 325 |
    326 | 327 | 343 | 344 |
    345 | 346 | 347 | 348 | 349 | 350 | -------------------------------------------------------------------------------- /robots.txt: -------------------------------------------------------------------------------- 1 | 2 | # This file can be used to affect how search engines and other web site crawlers see your site. 3 | # For more information, please see http://www.w3.org/TR/html4/appendix/notes.html#h-B.4.1.1 4 | # WebMatrix 2.0 5 | -------------------------------------------------------------------------------- /thanks.html: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Contributors, thank you - Windows Azure Open Source 6 | 7 | 8 | 9 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 28 | 29 | 30 | 31 | 35 | 36 | 37 | 84 | 85 |
    86 | 87 |

    Thank you!

    88 | 89 |

    Thanks go to our community of developers who have helped improve the 90 | quality of the Windows Azure open source products by helping with 91 | code contributions.

    92 | 93 |

    Learn how to contribute »

    94 | 95 |


    96 | 97 |

    Community Contributors

    98 | 99 |

    100 | git log --pretty=format:"%aN <%aE>" | sort -u | node process-contributors.js 101 |

    102 | 103 |
    104 |
    105 |

    Node.js SDK

    106 | 107 |

    Pato JutardPato Jutard

    110 |

    einarosEinar Otto Stangvik

    113 |

    Paul O'FallonPaul O'Fallon

    116 |

    Steve MarxSteve Marx

    119 |

    Anu ChandyAnu Chandy

    122 |

    Microsoft Open TechnologiesMicrosoft Open Technologies

    124 | 125 |

    Cross-platform CLI

    126 | 127 |

    Fredrik KjellbergFredrik Kjellberg

    130 |

    Microsoft Open TechnologiesMicrosoft Open Technologies

    132 | 133 | 134 | 135 |
    136 |
    137 | 138 |

    PowerShell

    139 | 140 |

    Tyler DTyler Doerksen

    143 | 144 |

    Python SDK

    145 | 146 |

    David FugateDavid Fugate

    149 | 150 |

    PHP SDK

    151 |

    Rafael DohmsRafael Dohms

    154 | 155 | 156 |

    Java SDK

    157 | 158 |

    Alex RiosAlex Rios

    161 | 162 | 163 |
    164 |
    165 | 166 |

    Content, site, docs

    167 | 168 |

    Ben WenBen Wen, MongoLab

    171 |

    Eric SedorEric Sedor, MongoLab

    174 |

    BlitlineBlitline

    177 |

    Sam GoldsteinSam Goldstein, New Relic

    180 |

    Nick FloydNick Floyd, New Relic

    183 |

    Ben LobaughBen Lobaugh

    186 |

    jamespinchjamespinch

    189 | 190 |
    191 |
    192 | 193 | 194 | 201 | 202 | 203 | 204 |


    205 | 206 |
    207 | 208 |

    If you've contributed to Windows Azure open source and would like to 209 | be listed, please submit a pull request to thanks.html in the 210 | 212 | https://github.com/windowsazure/windowsazure.github.com/ repo.

    213 | 214 |
    215 | 216 |

    Site credits

    217 | 218 | 223 |
    224 | 225 | 241 | 242 |
    243 | 244 | 245 | 246 | 247 | 248 | 249 | --------------------------------------------------------------------------------