-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTestFunctions.cs
131 lines (116 loc) · 4.27 KB
/
TestFunctions.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
using System;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using System.Collections.Generic;
using System.Threading.Tasks;
using StarVoteServer.GoogleFunctions;
namespace StarVote
{
public static class TestFunctions
{
[FunctionName(nameof(Ping))]
public static IActionResult Ping(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
log.LogInformation($"{nameof(Ping)}({Expand(req.Query)})");
string name = req.Query["name"];
string responseMessage = string.IsNullOrEmpty(name)
? "Hi!"
: $"Hello, {name}!";
return new OkObjectResult(responseMessage);
}
[FunctionName(nameof(ReadRange))]
public static async Task<IActionResult> ReadRange(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
log.LogInformation($"{nameof(ReadRange)}({Expand(req.Query)})");
string doc = req.Query["doc"];
string range = req.Query["range"];
using var service = new GoogleService(doc);
try
{
var result = await service.ReadRange(range).ConfigureAwait(false);
return new OkObjectResult(result);
}
catch (Exception ex)
{
log.LogInformation(ex.ToString());
return new BadRequestObjectResult(ex.ToString());
}
}
[FunctionName(nameof(Test1))]
public static async Task<IActionResult> Test1(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
string doc = req.Query["doc"];
string range = req.Query["range"];
using var service = new GoogleService(doc);
IList<IList<object>> list = new List<IList<object>>();
list.Add(new List<object> { "A1", null, "C1" });
list.Add(new List<object> { "A2", "B2", "C2" });
try
{
var result = await service.WriteRange(range, list).ConfigureAwait(false);
return new OkObjectResult(result);
}
catch (Exception ex)
{
log.LogInformation(ex.ToString());
return new BadRequestObjectResult(ex.ToString());
}
}
[FunctionName(nameof(Test2))]
public static async Task<IActionResult> Test2(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
string doc = req.Query["doc"];
using var service = new GoogleService(doc);
try
{
var result = await service.GetSheetInfo().ConfigureAwait(false);
return new OkObjectResult(result);
}
catch (Exception ex)
{
log.LogInformation(ex.ToString());
return new BadRequestObjectResult(ex.ToString());
}
}
static string Expand(IQueryCollection collection)
{
var list = new List<string>();
foreach (var key in collection.Keys)
{
var values = collection[key].ToArray();
var value = String.Join("|", values);
list.Add($"{key}={value}");
}
return String.Join(", ", list.ToArray());
}
[FunctionName(nameof(Test3))]
public static async Task<IActionResult> Test3(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
string doc = req.Query["doc"];
using var service = new GoogleService(doc);
try
{
var result = await service.CreateSheet().ConfigureAwait(false);
return new OkObjectResult(result);
}
catch (Exception ex)
{
log.LogInformation(ex.ToString());
return new BadRequestObjectResult(ex.ToString());
}
}
}
}